Product: Web viewer
Product Version: 11.0.0
I am creating signatures from signature UI but in the Signature tool, every signature has different size
I want to fix the size of all signatures (before drop on pdf file), so all signatures have same height and width. You can see in below image as there are 2 signatures which have diff sizes.
I want to set the size before the drop on the file. When user select signature on mouse left click then signature width and height should be same for all. So, user can drop the signature on the specific place on the document.
1 Like
Hello Rahul,
Thank you for contacting us.
You can listen to the annotationChanged event and change the height and width values whenever you add a new signature to the PDF.
annotationManager.addEventListener('annotationChanged', (annotations, action) => {
if (action === 'add') {
annotations.forEach(annotation => {
console.log(annotation);
if (annotation instanceof Annotations.FreeHandAnnotation && annotation.Subject === 'Signature') {
annotation.Height = 300;
annotation.Width = 300;
}
});
}
});
Best Regards,
Darian
1 Like
Hello Rahul,
Apologies for any misunderstanding. What you can do in this case is retrieve all the saved signatures from the tool using the getSavedSignatures API. Once you make the necessary adjustments, you can save the signatures to the tool using saveSignatures.
1 Like
Hi,
Thanks for reply. I have implemented as you suggested but signatures have still diff sizes.
I have set the height and width with below code but it is not working.
const signatures = signatureTool.getSavedSignatures();
for (var i = 0; i < signatures.length; i++) {
signatures[i].Width = 150;
signatures[i].Height = 30;
}
signatureTool.saveSignatures(signatures);
Please let me know If I am missing something.
1 Like
Hello Rahul,
Could you try calling deleteAllSavedSignatures before calling saveSignatures?
const signatureTool = instance.Core.documentViewer.getTool('AnnotationCreateSignature');
const signatures = signatureTool.getSavedSignatures();
console.log(signatures);
for (var i = 0; i < signatures.length; i++) {
signatures[i].Width = 150;
signatures[i].Height = 30;
}
signatureTool.deleteAllSavedSignatures();
signatureTool.saveSignatures(signatures);
1 Like
Hi,
Unfortunately, It is also not working. It’s still same. Still All signature has different sizes. I have noticed one more thing. When I get all signatures from ‘signatureTool.getSavedSignatures()’ function then all signature annotation has 0 height and 0 width. So, I guess the size of annotation has decided on diff parameters, not width and height.
Hello Rahul,
When you are running this code? Are you doing it after the signatures are created?
Yes, this code is running after signature created.
Hello Rahul,
That is strange. Would you be able to provide a sample project that demonstrates this issue? You can use this here as template: Apryse Developer Portal
Hi,
Here is the code, How I am importing signature and set width and height. I am fetching signature from database as base64 string. I am giving you base64 hardcode value for troubleshooting. Please let me know if you need anything else.
WebViewer(
{
path: "../../../js/lib/PdfTronWebViewer11.1.1/",
enableMeasurement: true,
licenseKey: my license key(it's commercial)
backendType: 'ems',
fullAPI: true,
annotationUser: 12345
isAdminUser:true
}, viewer
).then(instance => {
instance.UI.enableFeatures([instance.UI.Feature.Initials]);
const { VerificationOptions, openElements, loadDocument } = instance.UI;
const { PDFNet, documentViewer } = instance.Core;
const { annotationManager, Annotations } = instance.Core;
const { WidgetFlags } = Annotations;
const signatureTool = documentViewer.getTool('AnnotationCreateSignature');
documentViewer.addEventListener('documentLoaded', () => {
var firstSign = "";
var secondSign= "";
var thirdSign = "";
signatureTool.importSignatures([firstSign, secondSign, thirdSign]);
}
setTimeout(function () {
const signatures = signatureTool.getSavedSignatures();
console.log(signatures);
for (var i = 0; i < signatures.length; i++) {
signatures[i].Width = 150;
signatures[i].Height = 30;
}
signatureTool.deleteAllSavedSignatures();
signatureTool.saveSignatures(signatures);
}, 3000);
});
instance.UI.loadDocument('My documen path');
});
Is it working for you? If it is working, please provide me link where it is working So I can see what you are doing.
Thanks
Hello Rahul,
Thank you for the code snippet. There appears to be an issue with saving signatures this way, which might be related to the base64 data. When I create signatures in the UI and then run this code, it works fine. I have submitted a report to the product team for review.
Best Regards,
Darian