Write page content to PDF on iOS

To write page content to a new document.

1PTPDFDoc *doc = [[PTPDFDoc alloc] init];
2
3// ElementBuilder is used to build new Element objects
4PTElementBuilder *builder = [[PTElementBuilder alloc] init];
5
6// ElementWriter is used to write Elements to the page
7PTElementWriter *writer = [[PTElementWriter alloc] init];
8
9// Start a new page
10PTPage *page = [doc PageCreate: [[PTPDFRect alloc] initWithX1: 0 y1: 0 x2: 612 y2: 794]];
11
12// begin writing to the page
13[writer WriterBeginWithPage: page placement: e_ptoverlay page_coord_sys: YES compress: YES];
14
15// Create an Image that can be reused multiple times in the document or multiple on the same page.
16PTImage *img = [PTImage Create: [doc GetSDFDoc] filename: imagename];
17PTElement *element = [builder CreateImageWithMatrix:img mtx: [[PTMatrix2D alloc] initWithA: 200 b: -145 c: 20 d: 300 h: 200 v: 150]];
18[writer WritePlacedElement: element];
19
20// use the same image (just change its matrix)
21PTGState *gstate = [element GetGState];
22[gstate SetTransform: 200 b: 0 c: 0 d: 300 h: 50 v: 450];
23[writer WritePlacedElement: element];
24
25// use the same image again (just change its matrix).
26[writer WritePlacedElement: [builder CreateImageWithCornerAndScale: img x: 300 y: 600 hscale: 200 vscale: -150]];
27
28// save changes to the current page
29[writer End];
30
31// Add the new page to the document sequence
32[doc PagePushBack: page];

Build, Write, Embed Elements in PDF Pages
Full code sample which illustrates how to use PDFNet page writing API, how to embed fonts and images and how to copy graphical elements from one page to another.

About writing page content

New page content can be added to an existing page or a blank new page using ElementBuilder and ElementWriter. ElementBuilder is used to instantiate one or more Elements that can be written to one or more pages using ElementWriter:

Apryse Docs Image

Note that once the Element is instantiated using ElementBuilder, you have full control over its properties and graphics state.

Page content can also come from existing pages. For example, you can use ElementReader to read paths, text, and images from existing pages and copy them to the current page. Note that, along the way, you can fully modify an Element's properties or its graphics state. This is how to perform page content editing. For example, the following copies all Elements from an existing page and changes text color to blue:

1PTPDFDoc *doc = [[PTPDFDoc alloc] initWithFilepath: filename];
2PTPage *first_page = [doc GetPage:1];
3
4PTElementWriter *writer = [[PTElementWriter alloc] init];
5PTElementReader *reader = [[PTElementReader alloc] init];
6[reader Begin: page];
7[writer Begin: page placement: e_ptreplacement page_coord_sys: NO];
8
9PTElement *element;
10while ((element = [reader Next])) // Read page contents
11{
12 switch ([element GetType])
13 {
14 case e_pttext_obj:
15 {
16 // Set all text to blue color.
17 PTGState *gs = [element GetGState];
18 [gs SetFillColorSpace: [PTColorSpace CreateDeviceRGB]];
19 PTColorPt *cp = [[PTColorPt alloc] initWithX: 0 y: 0 z: 1 w: 0];
20 [gs SetFillColorWithColorPt: cp];
21 [writer WriteElement: element];
22 break;
23 }
24 default:
25 [writer WriteElement: element];
26 }
27}
28
29[writer End];
30[reader End];

PDF Editor (Programmatic)
Full code sample which strips all images from the page and changes text color to blue.

Did you find this helpful?

Trial setup questions?

Ask experts on Discord

Need other help?

Contact Support

Pricing or product questions?

Contact Sales