Hey Guys,
I'm looking to import images and use them as custom stamps. I understand that the PDF Viewer has this functionality? Is there a way to hide the current default stamps in the add stamps menu and load my own as preset options to click?
Also is there a way to select a stamp and copy it to multiple pages with the same proportions and coordinates?
Any help would be appreciated.
Thanks in advance,
Barney Hornsby
Hi Barney,
Thank you for contacting Syncfusion support.
|
I'm looking to import images and use them as custom stamps. I understand that the PDF Viewer has this functionality? Is there a way to hide the current default stamps in the add stamps menu and load my own as preset options to click? |
You can create the custom toolbar using the available PDF Viewer APIs as per your requirement. We have shared the documentation for your reference. Kindly refer to it and revert to us if you have any concerns about it.
Sample for Custom Toolbar: https://ej2.syncfusion.com/aspnetmvc/PdfViewer/CustomToolbar#/fluent
Documentation for Toolbar Customization: https://ej2.syncfusion.com/aspnetmvc/documentation/pdfviewer/how-to/toolbar-customization
Note - We do not have support to customize the built-in toolbars (Main Toolbar, Annotation Toolbar, or Form Designer Toolbar) in the PDF Viewer. But you can hide the unwanted tools. |
|
Also is there a way to select a stamp and copy it to multiple pages with the same proportions and coordinates? |
Currently, we do not have support for it. |
Regards,
Sinthiya K
Hey Sinthiya,
In regards to the bulk stamping, since there is no support for this feature, would it be possible to create a workaround which does the same thing? Such as getting a selected stamp's details and generating one on each page or maybe even doing this same thing but on stamp placement.
Is that something that is definitely not possible?
Thanks in advance,
Barney Hornsby
Hi Barney,
Kindly refer to the below sample for adding the custom stamp to the multiple pages with the same proportions and coordinates.
Code Snippet:
|
function addAnnotation() { var viewer = document.getElementById('pdfViewer').ej2_instances[0]; var pageCount = viewer.viewerBase.pageCount; for(var x=0; x<pageCount; x++){ viewer.annotation.addAnnotation("Stamp", { offset: {x: 200, y: 100}, pageNumber: x+1, customStamps: [ { customStampName: "Image", customStampImageSource: "" } ] }); } } |
Sample: https://www.syncfusion.com/downloads/support/directtrac/general/ze/GettingStarted_MVC1536505493.zip
Regards,
CCM Karthik
Hey guys,
Thanks for the code sample it helped a lot but there are still a couple things I would like to do.
Is there any way to get the details of a selected stamp (offset, height, width, and source) so I can use that to stamp every page?
To add custom stamps to the toolbar, is it true I would have to create my own custom toolbar?
If so, is it possible to add back all the functionality the PDF Viewer toolbar currently has? (such as the annotations)
Thanks again,
Barney Hornsby
Hi Barney,
We have an annotationselect API which is used to get details of the selected annotation. We have shared the sample and documentation for this.
Sample: https://www.syncfusion.com/downloads/support/directtrac/general/ze/annotationselectapi-893014752.zip
Steps to get the selected annotation details:
Screenshot:
Note: The stampAnnotationPath is the source of the selected image.
And also you need not create your own custom toolbar for a custom stamp, you can use the existing custom stamp option in the annotation toolbar. Kindly refer to the below screenshot.
Regards,
CCM Karthik
Hey guys,
Everything is starting to work now. There are a couple issues though:
When passing in a base64 string image to the addAnnotation function and adding it to the document, it seems to ignore the size of the image and resize it itself. Is there a way for it to keep its original height and width?
Also, if I specify the height and width in the addAnnotation function it seems to increase the given width and height by 33 percent. Is there a way to stop this from happening?
Thanks in advance,
Barney Hornsby
Hi Barney,
We were able to reproduce the reported issue “Custom stamp annotation size is increased while adding programmatically” and suspect this to be a defect. We will validate it and update further details in two business days on November 01, 2022.
Regards,
CCM Karthik
Hi Barney,
On further analysis, you can able to set the width and height values for the custom stamp while adding programmatically. We have shared the code snippet for your reference. If the width and height values are not given while adding programmatically, the default value of 100 is set.
Code Snippet:
|
function addAnnotation() { var viewer = document.getElementById('pdfViewer').ej2_instances[0]; var pageCount = viewer.viewerBase.pageCount; for(var x=0; x<pageCount; x++){ viewer.annotation.addAnnotation("Stamp", { offset: {x: 200, y: 100},
pageNumber: x+1, height: 20, customStamps: [ { customStampName: "Image", customStampImageSource: "" } ] }); } }
|
Please let us know if you have any concerns on this.
Regards,
CCM Karthik
Hey guys,
So, I guess you need to specify the width and height then, I understand.
But the issue with the width, height, top and left increasing when specifying them is still there. It happens in your example you sent as well (it returns a stamp with height: 26.6, left 266.6, top 133.3 and width 26.6).
Thanks in advance,
Barney Hornsby
The bound values for the stamp annotation in the addAnnotation API is converted into pixels, while adding the stamp annotation in the PDF Viewer. So, While selecting the annotation the converted values are returned in the bound’s parameter. If you want the original values while selecting the annotation, then change the bound value to the point. Use the below code to change a bound value pixel to point and point to pixel.
|
private ConvertPixelToPoint = function (number) { return (number * (72 / 96)); };
private ConvertPointToPixel = function (number) { return (number * (96 / 72)); };
|