PDF Add Text, Signatures and Images to PDF
Add text, images, signatures, other pdfs, links to external sites and external PDF files. You can update or modify PDF and scanned PDF files.
Interactive helper tool: PDF viewer displaying X and Y coordinates.
Available Methods
- [POST] /pdf/edit/add (adding text and images)
- [POST] /pdf/edit/add (adding text and images with simplified parameters)
[POST] /pdf/edit/add (adding text and images)
Add text, images, other pdfs, signatures, text fields, unchecked checkbox, checked checkbox to existing PDF file. You can fill out out existing PDF forms and documents and create new fillable PDF forms using this method.
To find X
and Y
coordinates for placing text, images or objects please use special PDF viewer displaying X and Y coordinates.
To save an image or pdf for reuse as a template please use a link from Dropbox or Google Drive or from other storage. Or use built-in PDF.co Files storage. If you need to draw a signature and save it as an image then use this page.
Parameters
url
required. URL to the source file. Supports links from Google Drive, Dropbox and from built-in PDF.co files storage. For uploading files via API please check Files Upload section. If you are randomly gettingToo Many Requests
orAccess Denied
error for your input url, please try to addcache:
to enable built-in url caching. You can also encrypt data for output files and decrypt data input files with user-controlled data encryption (uses strongAES
encryption with your own keys). [Click here](/kb/User%20Controlled%20encryption/encryption-and-decryption-options) to learn more.httpusername
(optional) - http auth user name if required to access sourceurl
.httppassword
(optional) - http auth password if required to access sourceurl
.annotations[]
. optional. Array of text objects to be added on top of pdf. Text objects can be ready-only ("type": "text"
by default) or interactive as input fields ("type": "textField"
) or checkboxes ("type": "checkbox"
).
Annotations (to add text)
text
- string to add. If you need to insert a line break then use\n
or{{$$newLine}}
.
You can also use built-in macros like {{$$PageNumber}}
and custom data macros. Check [this knowledgebase article](/kb/Fill PDF and Add Text or Images to PDF/macros) for more details on macros.
x
- X coordinate (zero point is in the top left corner, use this viewer to measure coordinates).y
- X coordinate (zero point is in the top left corner, use this viewer to measure coordinates).width
(optional) - width of the text box (zero point is in the top left corner, use this viewer to measure coordinates).height
(optional) - width of the text box (zero point is in the top left corner, use this viewer to measure coordinates).alignment
(optional, default isleft
). Sets text alignment withinwidth
of the text box. Valid values:left
,center
,right
.pages
- comma-separated indices of pages (or page ranges) that you want to use. The first page index is always0
. For example, if you have a 7 page document that you want split into 3 separate PDFs but different number of pages it would go like this:0, 1, 2-
or1, 2, 3-7
which will result in 1 PDF with page one, 1 PDF with page two and one PDF with the rest of the pages. You can also use inverted page numbers adding ‘!’ before the number. E.g. “!0” means “the last page”, “1-!1” means “from the second to the penultimate page”, “!1-“ - last two pages”. Also, you can use a single asterisk (“*”) character as the range to split the document into separate pages. SPECIAL CASES: You can use a single asterisk*
symbol to split the document into separate pages. Parameter must be a String.color
(optional, default is black) - color for the text.link
(optional) - sets link on click for text.size
(optional, default is12
) - set font size.transparent
(optional) - set tofalse
to disable transparency and use white background under your text.fontName
(optional, default isArial
) - sets font name to use.fontBold
(optional, default isfalse
) - set totrue
to enable bold font style.fontStrikeout
(optional, default isfalse
) - set totrue
to enable strikeout font style.fontUnderline
(optional, default isfalse
) - set totrue
to enable underline font style.type
(optional, default istext
). Set object type, available types:text
= text object,textfield
= text input field,checkbox
= checkbox field.id
(optional) - sets id of the form field iftype
is nottext
.
See the font list for all PDF.co supported fonts.
Adding Images and embedded PDF
images[]
optional. Array of objects with information about images and PDF embeds to add(also can be a link to Files storage or datauri link) to be added on top of source PDF file. Images can be loaded from URL or from URLs for internal file storage.
Parameters for Images objects:
url
- url to image or pdf as http link, filetoken ordatauri:..
url (with base64 encoded image).x
- X coordinate (zero point at left top, use this viewer to measure coordinates.y
- X coordinate (zero point at left top, use this viewer to measure coordinates.width
(optional) - width of the text box (zero point at left top, use this viewer to measure coordinates.height
(optional) - width of the text box (zero point at left top, use this viewer to measure coordinates.pages
- comma-separated indices of pages (or page ranges) that you want to use. The first page indice is always0
. For example, if you have a 7 page document that you want split into 3 separate PDFs but different number of pages it would go like this:0, 1, 2-
or1, 2, 3-7
which will result in 1 PDF with page one, 1 PDF with page two and one PDF with the rest of the pages. You can also use inverted page numbers adding ‘!’ before the number. E.g. “!0” means “the last page”, “1-!1” means “from the second to the penultimate page”, “!1-“ - last two pages”. Also, you can use a single asterisk (“*”) character as the range to split the document into separate pages. SPECIAL CASES: You can use a single asterisk*
symbol to split the document into separate pages. Parameter must be a String.link
(optional) - link to open on click.keepAspectRatio
(optional,true
by default). Set tofalse
if don’t need to keep aspect ratio for image/pdf added. In this case it will usewidth
andheight
parameters provided.
Parameters for Fields objects
fieldName
- name of the form field. Find form field names using this pdf info toolpages
- page index where this form field appears.text
- value to set for this field. If you have checkbox, setX
,true
,1
or another text which is different fromfalse
to enable checkbox. For radiobuttons and comboboxes you need to set index of the item to select. Explore pdf form fields in your pdf using this pdf info toolfontName
(optional). name of the font to use to fill out input fieldsize
(optional). Override font size of the text inside given input field.fontBold
(optional). Override font bold style of text input field.fontItalic
(optional). Override font italic style of text input field.fontStrikeout
(optional). Override font strikeout style of text input field.fontUnderline
(optional). Override font underline style of text input field.
Tip: to turn all fillable fields into read-only fields, just set the profiles
parameter (of the endpoint) to this value:
{ 'FlattenDocument()': [] }
Other Parameters
password
optional. Password of PDF file. Must be a Stringasync
optional. Runs processing asynchronously. ReturnsJobId
that you may use with/job/check
to check the state of the processing (possible states:working
,failed
,aborted
andsuccess
). Must be one of:true
,false
. IMPORTANT: Also setinline
param totrue
to get direct link to final output pdf in both sync and async modes. Otherwise, you will be getting direct link to pdf in sync mode but also link to.json
file in the async mode.inline
optional. Set totrue
to get direct link to output pdf in async mode (otherwise you will get link to json with url inside when you use async mode).name
optional. File name for generated output. Must be a String.expiration
(optional). Output link expiration in minutes. Default is60
(i.e. 60 minutes or 1 hour). After this delay generated output file(s) (if any) will be auto-removed from PDF.co temporary files storage. Max allowed expiration period depends on your current subscription plan. To store permanent input files (e.g. re-usable images, pdf, documents), please use PDF.co built-in Files Storage instead.async
optional. Runs processing asynchronously. ReturnsJobId
that you may use with/job/check
to check state of the background job (possible states:working
,failed
,aborted
andsuccess
). Must be one of:true
,false
.profiles
optional. Must be a String. You can set additional and extra options using this parameter that allows you to set custom configuration.
For example, to flatten pdf form, set profiles
to this value:
{ 'FlattenDocument()': [] }
See profiles samples for examples.
templateData
optional. Set JSON as escaped string for use as custom macros. See [this knowledgebase article](https://apidocs.pdf.co/kb/Fill%20PDF%20and%20Add%20Text%20or%20Images%20(pdf-edit-add)/macros#custom-macros) for more details.- Method: POST
- URL: /v1/pdf/edit/add
Query parameters
No query parameters accepted.
Body payload
{
"async": false,
"encrypt": true,
"inline": true,
"name": "newDocument",
"url": "https://bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/sample.pdf",
"annotations": [
{
"text": "Sample Text 1",
"x": 150,
"y": 100,
"size": 20,
"pages": "0-"
},
{
"text": "sample text that is centered (can also set right or left alignment) ",
"x": "10",
"y": "10",
"width": "500",
"height": "200",
"size": "7",
"pages": "0",
"alignment": "center"
},
{
"text": "Sample Text 2 - Click here to test link\r\n(CLICK ME!)",
"x": 250,
"y": 240,
"size": 24,
"pages": "0-",
"color": "CCBBAA",
"link": "https://bytescout.com/",
"fontName": "Comic Sans MS",
"fontItalic": true,
"fontBold": true,
"fontStrikeout": false,
"fontUnderline": true
},
{
"text": "Simple text 3",
"x": 100,
"y": 230,
"size": 12,
"pages": "0-",
"type": "Text"
},
{
"text": "sample text 3 - input text field",
"x": 100,
"y": 170,
"size": 16,
"pages": "0-",
"type": "TextField",
"id": "textfield1"
},
{
"x": 200,
"y": 120,
"size": 16,
"pages": "0-",
"type": "Checkbox",
"id": "checkbox2"
},
{
"x": 200,
"y": 140,
"size": 16,
"pages": "0-",
"type": "CheckboxChecked",
"id": "checkbox3"
}
],
"images": [
{
"url": "https://bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png",
"x": 270,
"y": 150,
"width": 159,
"height": 43,
"pages": "0"
},
{
"url": "",
"x": 10,
"y": 230,
"pages": "0-"
}
]
}
Example responses
/pdf/edit/add
{
"hash": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
"url": "https://pdf-temp-files.s3-us-west-2.amazonaws.com/0c336bfcef1a473d98492bda25d8da03/newDocument.pdf?X-Amz-Expires=3600&x-amz-security-token=FwoGZXIvYXdzEO7%2F%2F%2F%2F%2F%2F%2F%2F%2F%2FwEaDHWK1dY4d4lOgsheliKBATwE%2FZewASPTEnPxTn%2BOdYhP4h3gljAJfqbRvQptDX7wdWLmrBS7Tg4qTU6pAbxIdXChGPjBWpSbtiADJKmqkmyhkUmE8GSM1%2FGtJO6bga2pgzvFLXmzxjTf3%2BFNqwYOvbyApIZdVLoPpEKY6PlCflQtLTd30dhelm6xpB8pitbdhSjdz8KCBjIobVy%2Fjwybwp6OQgB%2FT6QkIo2dU07gtFREdn5jhRyvnS5lkccweBV1%2Bw%3D%3D&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=ASIA4NRRSZPHMV5P3JOS/20210316/us-west-2/s3/aws4_request&X-Amz-Date=20210316T124309Z&X-Amz-SignedHeaders=host;x-amz-security-token&X-Amz-Signature=95287bf3c007fed4c2c5aeea1ce75c846cc6c68b22aaf35175ebe41a105f54e1",
"pageCount": 1,
"error": false,
"status": 200,
"name": "newDocument",
"remainingCredits": 9913694,
"credits": 3
}
Code Snippet
CURL
curl --location --request POST 'https://api.pdf.co/v1/pdf/edit/add' \
--header 'Content-Type: application/json' \
--header 'x-api-key: ' \
--data-raw '{
"async": false,
"encrypt": true,
"inline": true,
"name": "newDocument",
"url": "https://bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/sample.pdf",
"annotations": [
{
"text": "Sample Text 1",
"x": 150,
"y": 100,
"size": 20,
"pages": "0-"
},
{
"text": "sample text that is centered (can also set right or left alignment) ",
"x": "10",
"y": "10",
"width": "500",
"height": "200",
"size": "7",
"pages": "0",
"alignment": "center"
},
{
"text": "Sample Text 2 - Click here to test link\r\n(CLICK ME!)",
"x": 250,
"y": 240,
"size": 24,
"pages": "0-",
"color": "CCBBAA",
"link": "https://bytescout.com/",
"fontName": "Comic Sans MS",
"fontItalic": true,
"fontBold": true,
"fontStrikeout": false,
"fontUnderline": true
},
{
"text": "Simple text 3",
"x": 100,
"y": 230,
"size": 12,
"pages": "0-",
"type": "Text"
},
{
"text": "sample text 3 - input text field",
"x": 100,
"y": 170,
"size": 16,
"pages": "0-",
"type": "TextField",
"id": "textfield1"
},
{
"x": 200,
"y": 120,
"size": 16,
"pages": "0-",
"type": "Checkbox",
"id": "checkbox2"
},
{
"x": 200,
"y": 140,
"size": 16,
"pages": "0-",
"type": "CheckboxChecked",
"id": "checkbox3"
}
],
"images": [
{
"url": "https://bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png",
"x": 270,
"y": 150,
"width": 159,
"height": 43,
"pages": "0"
},
{
"url": "",
"x": 10,
"y": 230,
"pages": "0-"
}
]
}'
[POST] /pdf/edit/add (adding text and images with simplified parameters)
You can add text, images, other pdfs, signatures to pdf and also can fill interactive pdf forms. This method uses simplified version of /pdf/edit/add
that allows you to add multiple text, images, fill pdf fields using simplified string representations
To find X
and Y
coordinates for placing text, images or objects please use special PDF viewer displaying X and Y coordinates.
To save image or pdf for re-use as a template please use link from Dropbox or Google Drive or from other storage. Or use built-in PDF.co Files storage. If you need to draw a signature and save as image then use this page.
url
required. URL to the source file. Supports links from Google Drive, Dropbox and from built-in PDF.co files storage. For uploading files via API please check Files Upload section. If you are randomly gettingToo Many Requests
orAccess Denied
error for your input url, please try to addcache:
to enable built-in url caching. You can also encrypt data for output files and decrypt data input files with user-controlled data encryption (uses strongAES
encryption with your own keys). Click here to learn more.httpusername
(optional) - http auth user name if required to access sourceurl
.httppassword
(optional) - http auth password if required to access sourceurl
.annotationsString
optional. This parameter represents one or more text objects to add into pdf. Each text object is made of parameter separated by;
symbol:
x;y;pages;text;fontsize;fontname;fontcolor;link;transparent;width;height;alignment
.
Example: 20;20;0-;Testing Text;24;Arial;FF0000;www.pdf.co;false;300;200;right
.
where 24+bold
is the font size. You can also add styles font size using the following modifiers:
- +bold
for bold style
- +italic
for italic style
- +underline
for underline style
- +strikeout
for strikeout style
For example: 20;20;0-;Testing Text;24+bold+italic;Arial
.
Example 2 with bold
, italic
, underline
and strikeout
styles:
250;20;0-;PDF form filled with PDF.co API;24+bold+italic+underline+strikeout;Arial;FF0000;www.pdf.co;true
To put multiple objects, just use |
separator between objects. Example:
250;20;0-;Text1|250;30;0-;Text2|250;50;0-;Text3
You can also use different fonts, check the full list of fonts supported.
If you need to insert a line break then use \n
or {{$$newLine}}
.
You can also use built-in macros like {{$$PageNumber}}
and custom data macros. Check this knowledgebase article for more details on macros.
imagesString
optional. Adds one or more images or other pdfs on top of source pdf. Each image or pdf object can be defined asx;y;pages;urltoimageOrPdf;linkToOpen;width;height
Example: 20;80;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png;www.pdf.co;200;200
.
To separate multiple objects, use |
separator.
Sample:
100;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png|400;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png;www.pdf.co;200;200
You can also use base64 datauri embedded image or filetoken://
link to a file from PDF.co storage.
fieldsString
optional. Set values for fillable pdf fields (i.e. fill pdf fields in pdf forms). To fill fields in PDF form, use the following formatpage;fieldName;value
.
Also, advanced format can be used to override font name, size and style:
0;fieldName;Field Text;12+bold+italic+underline+strikeout;FontName
Example: 0;editbox1;text is here
. To fill the checkbox, use true
, for example: 0;checkbox1;true
. To separate multiple objects, use |
separator. To get the list of all fillable fields in PDF form please use /pdf/info/fields
endpoint.
password
optional. Password of PDF file. Must be a Stringasync
optional. Runs processing asynchronously. ReturnsJobId
that you may use with/job/check
to check the state of the processing (possible states:working
,failed
,aborted
andsuccess
). Must be one of:true
,false
. IMPORTANT: Also setinline
param totrue
to get direct link to final output pdf in both sync and async modes. Otherwise, you will be getting direct link to pdf in sync mode but also link to.json
file in the async mode.inline
optional. Set totrue
to get direct link to output pdf in async mode (otherwise you will get link to json with url inside when you use async mode).name
optional. File name for generated output. Must be a String.expiration
(optional). Output link expiration in minutes. Default is60
(i.e. 60 minutes or 1 hour). After this delay generated output file(s) (if any) will be auto-removed from PDF.co temporary files storage. Max allowed expiration period depends on your current subscription plan. To store permanent input files (e.g. re-usable images, pdf, documents), please use PDF.co built-in Files Storage instead.async
optional. Runs processing asynchronously. ReturnsJobId
that you may use with/job/check
to check state of the background job (possible states:working
,failed
,aborted
andsuccess
). Must be one of:true
,false
.profiles
optional. Must be a String. You can set additional and extra options using this parameter that allows you to set custom configuration.
For example, to flatten pdf form, set profiles
to this value:
{ 'FlattenDocument()': [] }
See profiles samples for examples.
templateData
optional. Set JSON as escaped string for use as custom macros. See [this knowledgebase article](https://apidocs.pdf.co/kb/Fill%20PDF%20and%20Add%20Text%20or%20Images%20(pdf-edit-add)/macros#custom-macros) for more details.- Method: POST
- URL: /v1/pdf/edit/add
Query parameters
No query parameters accepted.
Body payload
{
"async": false,
"encrypt": false,
"inline": true,
"name": "f1040-form-filled",
"url": "bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-form/f1040.pdf",
"annotationsString": "250;20;0-;PDF form filled with PDF.co API;24+bold+italic+underline+strikeout;Arial;FF0000;www.pdf.co;true",
"imagesString": "100;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png|400;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png;www.pdf.co;200;200",
"fieldsString": "1;topmostSubform[0].Page1[0].f1_02[0];John A. Doe|1;topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1];true|1;topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0];123456789"
}
Example responses
JSON simplified /pdf/edit/add
{
"url": "https://pdf-temp-files.s3.amazonaws.com/03c5c55183c74f8d94a4ec952e4e32ad/f1040-form-filled.pdf",
"pageCount": 3,
"error": false,
"status": 200,
"name": "f1040-form-filled",
"remainingCredits": 60822
}
Code Snippet
CURL
curl --location --request POST 'https://api.pdf.co/v1/pdf/edit/add' \
--header 'Content-Type: application/json' \
--header 'x-api-key: ' \
--data-raw '{
"async": false,
"encrypt": false,
"inline": true,
"name": "f1040-form-filled",
"url": "bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-form/f1040.pdf",
"annotationsString": "250;20;0-;PDF form filled with PDF.co API;24+bold+italic+underline+strikeout;Arial;FF0000;www.pdf.co;true",
"imagesString": "100;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png|400;180;0-;bytescout-com.s3-us-west-2.amazonaws.com/files/demo-files/cloud-api/pdf-edit/logo.png;www.pdf.co;200;200",
"fieldsString": "1;topmostSubform[0].Page1[0].f1_02[0];John A. Doe|1;topmostSubform[0].Page1[0].FilingStatus[0].c1_01[1];true|1;topmostSubform[0].Page1[0].YourSocial_ReadOrderControl[0].f1_04[0];123456789"
}'
Samples
- AWS Lambda - Add Image to Existing PDF (Node.js)
- AWS Lambda - Add Text to Existing PDF (Node.js)
- C# - Add Image by finding target coordinates
- C# - Add Images to Existing PDF
- C# - Add Text by finding target coordinates
- C# - Add Text to Existing PDF
- Delphi - Add Text And Images To PDF
- GoogleAppScript - Add Image to PDF
- GoogleAppScript - Add Text to PDF
- Java - Add Image by finding target coordinates
- Java - Add Images to Existing PDF
- Java - Add Text by finding target coordinates
- Java - Add Text to Existing PDF
- JavaScript - Add Image by finding target coordinates (Node.js)
- JavaScript - Add Image to Existing PDF (Node.js)
- JavaScript - Add Image to Existing PDF (jQuery)
- JavaScript - Add Image to Existing PDF Base64 (Node.js)
- JavaScript - Add Page Numbers and Page Count to Existing PDF (Node.js)
- JavaScript - Add Template Text With Data to Existing PDF (Node.js)
- JavaScript - Add Text With Line Breaks to Existing PDF (Node.js)
- JavaScript - Add Text by finding target coordinates (Node.js)
- JavaScript - Add Text to Existing PDF (Node.js)
- JavaScript - Add Text to Existing PDF (jQuery)
- JavaScript - Add Text to Existing PDF Base64 (Node.js)
- PHP - Add Page Numbers and Page Count to Existing PDF
- PHP - Add Template Text With Data to Existing PDF
- PHP - Add Text Image to PDF Simplified
- PHP - Add Text Images to PDF
- PHP - Add Text With Line Breaks to Existing PDF
- PowerShell - Add Image by finding target coordinates
- PowerShell - Add Images to Existing PDF
- PowerShell - Add Text by finding target coordinates
- PowerShell - Add Text to Existing PDF
- Python - Add Image by finding target coordinates
- Python - Add Images to Existing PDF
- Python - Add Text And Image To PDF
- Python - Add Text by finding target coordinates
- Python - Add Text to Existing PDF
- Salesforce - Add Text Image Signature to PDF
- Salesforce - Add Text Image Signature to PDF With Simplified Parameter
- Salesforce - Add Text To Existing PDF
- Salesforce - Legacy - Add Image To PDF
- Salesforce - Legacy - Add Image To PDF From Uploaded File
- Salesforce - Legacy - Add Text To PDF
- SharePoint - Add Text and Images to PDF
- VB.NET - Add Image by finding target coordinates
- VB.NET - Add Images to Existing PDF
- VB.NET - Add Text by finding target coordinates
- VB.NET - Add Text to Existing PDF
- Zapier - PDF.co to Dropbox
- Zapier - PDF.co to Google Drive
- cURL - PDF Add Text, Images, Text Fields, Checkboxes
- cURL - PDF Add Text, Images, Text Fields, Checkboxes - Simplified
Copyright © 2016 - 2023 PDF.co