@pdftron/pdfnet-node-samples 9.4.2 → 9.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +18 -18
- package/readme.md +12 -12
- package/samples/AddImageTest/AddImageTest.js +1 -1
- package/samples/AddImageTest/NODEJS/AddImageTest.js +116 -0
- package/samples/AddImageTest/NODEJS/RunTest.sh +2 -0
- package/samples/AdvancedImagingTest/AdvancedImagingTest.js +1 -1
- package/samples/AdvancedImagingTest/NODEJS/AdvancedImagingTest.js +78 -0
- package/samples/AdvancedImagingTest/NODEJS/RunTest.sh +2 -0
- package/samples/AnnotationTest/AnnotationTest.js +1 -1
- package/samples/AnnotationTest/NODEJS/AnnotationTest.js +642 -0
- package/samples/AnnotationTest/NODEJS/RunTest.sh +2 -0
- package/samples/BookmarkTest/BookmarkTest.js +1 -1
- package/samples/BookmarkTest/NODEJS/BookmarkTest.js +220 -0
- package/samples/BookmarkTest/NODEJS/RunTest.sh +2 -0
- package/samples/CAD2PDFTest/CAD2PDFTest.js +79 -79
- package/samples/CAD2PDFTest/NODEJS/CAD2PDFTest.js +80 -0
- package/samples/CAD2PDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/ContentReplacerTest/ContentReplacerTest.js +1 -1
- package/samples/ContentReplacerTest/NODEJS/ContentReplacerTest.js +75 -0
- package/samples/ContentReplacerTest/NODEJS/RunTest.sh +2 -0
- package/samples/ConvertTest/ConvertTest.js +270 -256
- package/samples/ConvertTest/NODEJS/ConvertTest.js +270 -0
- package/samples/ConvertTest/NODEJS/RunTest.sh +2 -0
- package/samples/DataExtractionTest/DataExtractionTest.js +180 -0
- package/samples/DataExtractionTest/NODEJS/DataExtractionTest.js +180 -0
- package/samples/DataExtractionTest/NODEJS/RunTest.sh +2 -0
- package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +526 -526
- package/samples/DigitalSignaturesTest/NODEJS/DigitalSignaturesTest.js +527 -0
- package/samples/DigitalSignaturesTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementBuilderTest/ElementBuilderTest.js +1 -1
- package/samples/ElementBuilderTest/NODEJS/ElementBuilderTest.js +514 -0
- package/samples/ElementBuilderTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementEditTest/ElementEditTest.js +1 -1
- package/samples/ElementEditTest/NODEJS/ElementEditTest.js +111 -0
- package/samples/ElementEditTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +1 -1
- package/samples/ElementReaderAdvTest/NODEJS/ElementReaderAdvTest.js +305 -0
- package/samples/ElementReaderAdvTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementReaderTest/ElementReaderTest.js +1 -1
- package/samples/ElementReaderTest/NODEJS/ElementReaderTest.js +77 -0
- package/samples/ElementReaderTest/NODEJS/RunTest.sh +2 -0
- package/samples/EncTest/EncTest.js +1 -1
- package/samples/EncTest/NODEJS/EncTest.js +176 -0
- package/samples/EncTest/NODEJS/RunTest.sh +2 -0
- package/samples/FDFTest/FDFTest.js +218 -218
- package/samples/FDFTest/NODEJS/FDFTest.js +219 -0
- package/samples/FDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/HTML2PDFTest/HTML2PDFTest.js +165 -165
- package/samples/HTML2PDFTest/NODEJS/HTML2PDFTest.js +166 -0
- package/samples/HTML2PDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/HighlightsTest/HighlightsTest.js +1 -1
- package/samples/HighlightsTest/NODEJS/HighlightsTest.js +97 -0
- package/samples/HighlightsTest/NODEJS/RunTest.sh +2 -0
- package/samples/ImageExtractTest/ImageExtractTest.js +129 -129
- package/samples/ImageExtractTest/NODEJS/ImageExtractTest.js +130 -0
- package/samples/ImageExtractTest/NODEJS/RunTest.sh +2 -0
- package/samples/ImpositionTest/ImpositionTest.js +86 -86
- package/samples/ImpositionTest/NODEJS/ImpositionTest.js +87 -0
- package/samples/ImpositionTest/NODEJS/RunTest.sh +2 -0
- package/samples/InteractiveFormsTest/InteractiveFormsTest.js +381 -381
- package/samples/InteractiveFormsTest/NODEJS/InteractiveFormsTest.js +382 -0
- package/samples/InteractiveFormsTest/NODEJS/RunTest.sh +2 -0
- package/samples/JBIG2Test/JBIG2Test.js +88 -88
- package/samples/JBIG2Test/NODEJS/JBIG2Test.js +89 -0
- package/samples/JBIG2Test/NODEJS/RunTest.sh +2 -0
- package/samples/LicenseKey/NODEJS/LicenseKey.js +11 -0
- package/samples/LogicalStructureTest/LogicalStructureTest.js +1 -1
- package/samples/LogicalStructureTest/NODEJS/LogicalStructureTest.js +251 -0
- package/samples/LogicalStructureTest/NODEJS/RunTest.sh +2 -0
- package/samples/OCRTest/NODEJS/OCRTest.js +235 -0
- package/samples/OCRTest/NODEJS/RunTest.sh +2 -0
- package/samples/OCRTest/OCRTest.js +234 -234
- package/samples/OfficeTemplateTest/NODEJS/OfficeTemplateTest.js +79 -0
- package/samples/OfficeTemplateTest/NODEJS/RunTest.sh +2 -0
- package/samples/OfficeTemplateTest/OfficeTemplateTest.js +79 -77
- package/samples/OfficeToPDFTest/NODEJS/OfficeToPDFTest.js +125 -0
- package/samples/OfficeToPDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/OfficeToPDFTest/OfficeToPDFTest.js +125 -125
- package/samples/OptimizerTest/NODEJS/OptimizerTest.js +192 -0
- package/samples/OptimizerTest/NODEJS/RunTest.sh +2 -0
- package/samples/OptimizerTest/OptimizerTest.js +191 -191
- package/samples/PDF2HtmlTest/NODEJS/PDF2HtmlTest.js +123 -0
- package/samples/PDF2HtmlTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDF2HtmlTest/PDF2HtmlTest.js +1 -1
- package/samples/PDF2OfficeTest/NODEJS/PDF2OfficeTest.js +158 -0
- package/samples/PDF2OfficeTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDF2OfficeTest/PDF2OfficeTest.js +1 -1
- package/samples/PDFATest/NODEJS/PDFATest.js +85 -0
- package/samples/PDFATest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFATest/PDFATest.js +1 -1
- package/samples/PDFDocMemoryTest/NODEJS/PDFDocMemoryTest.js +85 -0
- package/samples/PDFDocMemoryTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +84 -84
- package/samples/PDFDrawTest/NODEJS/PDFDrawTest.js +306 -0
- package/samples/PDFDrawTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFDrawTest/PDFDrawTest.js +1 -1
- package/samples/PDFLayersTest/NODEJS/PDFLayersTest.js +295 -0
- package/samples/PDFLayersTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFLayersTest/PDFLayersTest.js +1 -1
- package/samples/PDFPackageTest/NODEJS/PDFPackageTest.js +112 -0
- package/samples/PDFPackageTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFPackageTest/PDFPackageTest.js +111 -111
- package/samples/PDFPageTest/NODEJS/PDFPageTest.js +190 -0
- package/samples/PDFPageTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFPageTest/PDFPageTest.js +1 -1
- package/samples/PDFRedactTest/NODEJS/PDFRedactTest.js +75 -0
- package/samples/PDFRedactTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFRedactTest/PDFRedactTest.js +1 -1
- package/samples/PageLabelsTest/NODEJS/PageLabelsTest.js +139 -0
- package/samples/PageLabelsTest/NODEJS/RunTest.sh +2 -0
- package/samples/PageLabelsTest/PageLabelsTest.js +138 -138
- package/samples/PatternTest/NODEJS/PatternTest.js +227 -0
- package/samples/PatternTest/NODEJS/RunTest.sh +2 -0
- package/samples/PatternTest/PatternTest.js +226 -226
- package/samples/RectTest/NODEJS/RectTest.js +41 -0
- package/samples/RectTest/NODEJS/RunTest.sh +2 -0
- package/samples/RectTest/RectTest.js +1 -1
- package/samples/SDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/SDFTest/NODEJS/SDFTest.js +88 -0
- package/samples/SDFTest/SDFTest.js +2 -3
- package/samples/StamperTest/NODEJS/RunTest.sh +2 -0
- package/samples/StamperTest/NODEJS/StamperTest.js +256 -0
- package/samples/StamperTest/StamperTest.js +1 -1
- package/samples/TestFiles/financial.pdf +0 -0
- package/samples/TestFiles/formfields-scanned.pdf +0 -0
- package/samples/TestFiles/formfields.pdf +0 -0
- package/samples/TestFiles/table.pdf +0 -0
- package/samples/TestFiles/tiger.svg +378 -0
- package/samples/TextExtractTest/NODEJS/RunTest.sh +2 -0
- package/samples/TextExtractTest/NODEJS/TextExtractTest.js +287 -0
- package/samples/TextExtractTest/TextExtractTest.js +1 -1
- package/samples/TextSearchTest/NODEJS/RunTest.sh +2 -0
- package/samples/TextSearchTest/NODEJS/TextSearchTest.js +122 -0
- package/samples/TextSearchTest/TextSearchTest.js +1 -1
- package/samples/U3DTest/NODEJS/RunTest.sh +2 -0
- package/samples/U3DTest/NODEJS/U3DTest.js +105 -0
- package/samples/U3DTest/U3DTest.js +104 -104
- package/samples/UndoRedoTest/NODEJS/RunTest.sh +2 -0
- package/samples/UndoRedoTest/NODEJS/UndoRedoTest.js +101 -0
- package/samples/UndoRedoTest/UndoRedoTest.js +1 -1
- package/samples/UnicodeWriteTest/NODEJS/RunTest.sh +2 -0
- package/samples/UnicodeWriteTest/NODEJS/UnicodeWriteTest.js +174 -0
- package/samples/UnicodeWriteTest/UnicodeWriteTest.js +1 -1
- package/samples/WebViewerConvertTest/NODEJS/RunTest.sh +2 -0
- package/samples/WebViewerConvertTest/NODEJS/WebViewerConvertTest.js +136 -0
- package/samples/WebViewerConvertTest/WebViewerConvertTest.js +135 -135
- package/samples/runall.bat +12 -12
|
@@ -0,0 +1,306 @@
|
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//---------------------------------------------------------------------------------------
|
|
7
|
+
// The following sample illustrates how to convert PDF documents to various raster image
|
|
8
|
+
// formats (such as PNG, JPEG, BMP, TIFF, etc), as well as how to convert a PDF page to
|
|
9
|
+
// GDI+ Bitmap for further manipulation and/or display in WinForms applications.
|
|
10
|
+
//---------------------------------------------------------------------------------------
|
|
11
|
+
|
|
12
|
+
const fs = require('fs');
|
|
13
|
+
const { PDFNet } = require('../../../lib/pdfnet.js');
|
|
14
|
+
const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
|
|
15
|
+
|
|
16
|
+
((exports) => {
|
|
17
|
+
|
|
18
|
+
exports.runPDFDrawTest = () => {
|
|
19
|
+
|
|
20
|
+
const main = async () => {
|
|
21
|
+
// Relative path to the folder containing test files.
|
|
22
|
+
const inputPath = '../../TestFiles/';
|
|
23
|
+
const outputPath = inputPath + 'Output/';
|
|
24
|
+
|
|
25
|
+
try {
|
|
26
|
+
|
|
27
|
+
// Optional: Set ICC color profiles to fine tune color conversion
|
|
28
|
+
// for PDF 'device' color spaces...
|
|
29
|
+
|
|
30
|
+
// PDFNet.setResourcesPath('../../resources');
|
|
31
|
+
// PDFNet.setColorManagement(PDFNet.CMSType.e_lcms);
|
|
32
|
+
// PDFNet.setDefaultDeviceCMYKProfile('D:/Misc/ICC/USWebCoatedSWOP.icc');
|
|
33
|
+
// PDFNet.setDefaultDeviceRGBProfile('AdobeRGB1998.icc'); // will search in PDFNet resource folder.
|
|
34
|
+
|
|
35
|
+
// ----------------------------------------------------
|
|
36
|
+
// Optional: Set predefined font mappings to override default font
|
|
37
|
+
// substitution for documents with missing fonts...
|
|
38
|
+
|
|
39
|
+
// PDFNet.addFontSubst('StoneSans-Semibold', 'C:/WINDOWS/Fonts/comic.ttf');
|
|
40
|
+
// PDFNet.addFontSubst('StoneSans', 'comic.ttf'); // search for 'comic.ttf' in PDFNet resource folder.
|
|
41
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_Identity, 'C:/WINDOWS/Fonts/arialuni.ttf');
|
|
42
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_Japan1, 'C:/Program Files/Adobe/Acrobat 7.0/Resource/CIDFont/KozMinProVI-Regular.otf');
|
|
43
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_Japan2, 'c:/myfonts/KozMinProVI-Regular.otf');
|
|
44
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_Korea1, 'AdobeMyungjoStd-Medium.otf');
|
|
45
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_CNS1, 'AdobeSongStd-Light.otf');
|
|
46
|
+
// PDFNet.addFontSubst(PDFNet.CharacterOrdering.e_GB1, 'AdobeMingStd-Light.otf');
|
|
47
|
+
|
|
48
|
+
const draw = await PDFNet.PDFDraw.create(); // PDFDraw class is used to rasterize PDF pages.
|
|
49
|
+
|
|
50
|
+
//--------------------------------------------------------------------------------
|
|
51
|
+
// Example 1) Convert the first page to PNG and TIFF at 92 DPI.
|
|
52
|
+
// A three step tutorial to convert PDF page to an image.
|
|
53
|
+
try {
|
|
54
|
+
// A) Open the PDF document.
|
|
55
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'tiger.pdf');
|
|
56
|
+
|
|
57
|
+
// Initialize the security handler, in case the PDF is encrypted.
|
|
58
|
+
doc.initSecurityHandler();
|
|
59
|
+
|
|
60
|
+
// B) The output resolution is set to 92 DPI.
|
|
61
|
+
draw.setDPI(92);
|
|
62
|
+
|
|
63
|
+
const firstPage = await (await doc.getPageIterator()).current();
|
|
64
|
+
// C) Rasterize the first page in the document and save the result as PNG.
|
|
65
|
+
await draw.export(firstPage, outputPath + 'tiger_92dpi.png');
|
|
66
|
+
|
|
67
|
+
console.log('Example 1: tiger_92dpi.png');
|
|
68
|
+
|
|
69
|
+
// Export the same page as TIFF
|
|
70
|
+
await draw.export(firstPage, outputPath + 'tiger_92dpi.tif', 'TIFF');
|
|
71
|
+
} catch (err) {
|
|
72
|
+
console.log(err);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
//--------------------------------------------------------------------------------
|
|
76
|
+
// Example 2) Convert the all pages in a given document to JPEG at 72 DPI.
|
|
77
|
+
console.log('Example 2:');
|
|
78
|
+
const hint_set = await PDFNet.ObjSet.create(); // A collection of rendering 'hits'.
|
|
79
|
+
try {
|
|
80
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
|
|
81
|
+
// Initialize the security handler, in case the PDF is encrypted.
|
|
82
|
+
doc.initSecurityHandler();
|
|
83
|
+
|
|
84
|
+
draw.setDPI(72); // Set the output resolution is to 72 DPI.
|
|
85
|
+
|
|
86
|
+
// Use optional encoder parameter to specify JPEG quality.
|
|
87
|
+
const encoderParam = await hint_set.createDict();
|
|
88
|
+
await encoderParam.putNumber('Quality', 80);
|
|
89
|
+
|
|
90
|
+
// Traverse all pages in the document.
|
|
91
|
+
for (const itr = await doc.getPageIterator(); await itr.hasNext(); await itr.next()) {
|
|
92
|
+
const currPage = await itr.current();
|
|
93
|
+
const currPageIdx = await currPage.getIndex();
|
|
94
|
+
const path = outputPath + 'newsletter' + currPageIdx + '.jpg';
|
|
95
|
+
console.log('newsletter' + currPageIdx + '.jpg');
|
|
96
|
+
|
|
97
|
+
await draw.export(currPage, path, 'JPEG', encoderParam);
|
|
98
|
+
}
|
|
99
|
+
console.log('Done.');
|
|
100
|
+
} catch (err) {
|
|
101
|
+
console.log(err);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// Examples 3-6
|
|
105
|
+
try {
|
|
106
|
+
// Common code for remaining samples.
|
|
107
|
+
const tiger_doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'tiger.pdf');
|
|
108
|
+
// Initialize the security handler, in case the PDF is encrypted.
|
|
109
|
+
tiger_doc.initSecurityHandler();
|
|
110
|
+
const page = await tiger_doc.getPage(1);
|
|
111
|
+
|
|
112
|
+
//--------------------------------------------------------------------------------
|
|
113
|
+
// Example 3) Convert the first page to raw bitmap. Also, rotate the
|
|
114
|
+
// page 90 degrees and save the result as RAW.
|
|
115
|
+
draw.setDPI(100); // Set the output resolution is to 100 DPI.
|
|
116
|
+
draw.setRotate(PDFNet.Page.Rotate.e_90); // Rotate all pages 90 degrees clockwise.
|
|
117
|
+
|
|
118
|
+
const bitmapInfo = await draw.getBitmap(page, PDFNet.PDFDraw.PixelFormat.e_rgb, false);
|
|
119
|
+
const buf = Buffer.from(bitmapInfo.buf, 0, bitmapInfo.height * bitmapInfo.stride)
|
|
120
|
+
|
|
121
|
+
// Save the raw RGB data to disk.
|
|
122
|
+
fs.appendFileSync(outputPath + 'tiger_100dpi_rot90.raw', buf, 'binary');
|
|
123
|
+
|
|
124
|
+
console.log('Example 3: tiger_100dpi_rot90.raw');
|
|
125
|
+
draw.setRotate(PDFNet.Page.Rotate.e_0); // Disable image rotation for remaining samples.
|
|
126
|
+
|
|
127
|
+
//--------------------------------------------------------------------------------
|
|
128
|
+
// Example 4) Convert PDF page to a fixed image size. Also illustrates some
|
|
129
|
+
// other features in PDFDraw class such as rotation, image stretching, exporting
|
|
130
|
+
// to grayscale, or monochrome.
|
|
131
|
+
|
|
132
|
+
// Initialize render 'gray_hint' parameter, that is used to control the
|
|
133
|
+
// rendering process. In this case we tell the rasterizer to export the image as
|
|
134
|
+
// 1 Bit Per Component (BPC) image.
|
|
135
|
+
const mono_hint = await hint_set.createDict();
|
|
136
|
+
await mono_hint.putNumber('BPC', 1);
|
|
137
|
+
|
|
138
|
+
// SetImageSize can be used instead of SetDPI() to adjust page scaling
|
|
139
|
+
// dynamically so that given image fits into a buffer of given dimensions.
|
|
140
|
+
draw.setImageSize(1000, 1000); // Set the output image to be 1000 wide and 1000 pixels tall
|
|
141
|
+
draw.export(page, outputPath + 'tiger_1000x1000.png', 'PNG', mono_hint);
|
|
142
|
+
console.log('Example 4: tiger_1000x1000.png');
|
|
143
|
+
|
|
144
|
+
draw.setImageSize(200, 400); // Set the output image to be 200 wide and 300 pixels tall
|
|
145
|
+
draw.setRotate(PDFNet.Page.Rotate.e_180); // Rotate all pages 90 degrees clockwise.
|
|
146
|
+
|
|
147
|
+
// 'gray_hint' tells the rasterizer to export the image as grayscale.
|
|
148
|
+
const gray_hint = await hint_set.createDict();
|
|
149
|
+
await gray_hint.putName('ColorSpace', 'Gray');
|
|
150
|
+
|
|
151
|
+
await draw.export(page, outputPath + 'tiger_200x400_rot180.png', 'PNG', gray_hint);
|
|
152
|
+
console.log('Example 4: tiger_200x400_rot180.png');
|
|
153
|
+
|
|
154
|
+
draw.setImageSize(400, 200, false); // The third parameter sets 'preserve-aspect-ratio' to false.
|
|
155
|
+
draw.setRotate(PDFNet.Page.Rotate.e_0); // Disable image rotation.
|
|
156
|
+
await draw.export(page, outputPath + 'tiger_400x200_stretch.jpg', 'JPEG');
|
|
157
|
+
console.log('Example 4: tiger_400x200_stretch.jpg');
|
|
158
|
+
|
|
159
|
+
//--------------------------------------------------------------------------------
|
|
160
|
+
// Example 5) Zoom into a specific region of the page and rasterize the
|
|
161
|
+
// area at 200 DPI and as a thumbnail (i.e. a 50x50 pixel image).
|
|
162
|
+
const zoom_rect = await PDFNet.Rect.init(216, 522, 330, 600);
|
|
163
|
+
await page.setCropBox(zoom_rect); // Set the page crop box.
|
|
164
|
+
|
|
165
|
+
// Select the crop region to be used for drawing.
|
|
166
|
+
draw.setPageBox(PDFNet.Page.Box.e_crop);
|
|
167
|
+
draw.setDPI(900); // Set the output image resolution to 900 DPI.
|
|
168
|
+
await draw.export(page, outputPath + 'tiger_zoom_900dpi.png', 'PNG');
|
|
169
|
+
console.log('Example 5: tiger_zoom_900dpi.png');
|
|
170
|
+
|
|
171
|
+
// -------------------------------------------------------------------------------
|
|
172
|
+
// Example 6)
|
|
173
|
+
draw.setImageSize(50, 50); // Set the thumbnail to be 50x50 pixel image.
|
|
174
|
+
await draw.export(page, outputPath + 'tiger_zoom_50x50.png', 'PNG');
|
|
175
|
+
console.log('Example 6: tiger_zoom_50x50.png');
|
|
176
|
+
} catch (err) {
|
|
177
|
+
console.log(err);
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
//--------------------------------------------------------------------------------
|
|
181
|
+
// Example 7) Convert the first PDF page to CMYK TIFF at 92 DPI.
|
|
182
|
+
// A three step tutorial to convert PDF page to an image
|
|
183
|
+
try {
|
|
184
|
+
const cmyk_hint = await hint_set.createDict();
|
|
185
|
+
await cmyk_hint.putName('ColorSpace', 'CMYK');
|
|
186
|
+
// A) Open the PDF document.
|
|
187
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'tiger.pdf');
|
|
188
|
+
// Initialize the security handler, in case the PDF is encrypted.
|
|
189
|
+
doc.initSecurityHandler();
|
|
190
|
+
|
|
191
|
+
// B) The output resolution is set to 92 DPI.
|
|
192
|
+
draw.setDPI(92);
|
|
193
|
+
|
|
194
|
+
// C) Rasterize the first page in the document and save the result as TIFF.
|
|
195
|
+
const pg = await doc.getPage(1);
|
|
196
|
+
await draw.export(pg, outputPath + 'out1.tif', 'TIFF', cmyk_hint);
|
|
197
|
+
console.log('Example 7: out1.tif');
|
|
198
|
+
} catch (err) {
|
|
199
|
+
console.log(err);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
//--------------------------------------------------------------------------------
|
|
203
|
+
// Example 8) PDFRasterizer can be used for more complex rendering tasks, such as
|
|
204
|
+
// strip by strip or tiled document rendering. In particular, it is useful for
|
|
205
|
+
// cases where you cannot simply modify the page crop box (interactive viewing,
|
|
206
|
+
// parallel rendering). This example shows how you can rasterize the south-west
|
|
207
|
+
// quadrant of a page.
|
|
208
|
+
try {
|
|
209
|
+
// A) Open the PDF document.
|
|
210
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'tiger.pdf');
|
|
211
|
+
// Initialize the security handler, in case the PDF is encrypted.
|
|
212
|
+
doc.initSecurityHandler();
|
|
213
|
+
|
|
214
|
+
// B) Get the page matrix
|
|
215
|
+
const pg = await doc.getPage(1);
|
|
216
|
+
const box = PDFNet.Page.Rotate.e_crop;
|
|
217
|
+
let mtx = await pg.getDefaultMatrix(true, box);
|
|
218
|
+
// We want to render a quadrant, so use half of width and height
|
|
219
|
+
const pg_w = await pg.getPageWidth(box) / 2;
|
|
220
|
+
const pg_h = await pg.getPageHeight(box) / 2;
|
|
221
|
+
|
|
222
|
+
// C) Scale matrix from PDF space to buffer space
|
|
223
|
+
const dpi = 96.0;
|
|
224
|
+
const scale = dpi / 72.0; // PDF space is 72 dpi
|
|
225
|
+
const buf_w = Math.floor(scale * pg_w);
|
|
226
|
+
const buf_h = Math.floor(scale * pg_h);
|
|
227
|
+
const bytes_per_pixel = 4; // BGRA buffer
|
|
228
|
+
await mtx.translate(0, -pg_h); // translate by '-pg_h' since we want south-west quadrant
|
|
229
|
+
const scale_mtx = await PDFNet.Matrix2D.create(scale, 0, 0, scale, 0, 0);
|
|
230
|
+
await scale_mtx.multiply(mtx);
|
|
231
|
+
mtx = scale_mtx;
|
|
232
|
+
|
|
233
|
+
// D) Rasterize page into memory buffer, according to our parameters
|
|
234
|
+
const rast = await PDFNet.PDFRasterizer.create();
|
|
235
|
+
const buf = await rast.rasterize(pg, buf_w, buf_h, buf_w * bytes_per_pixel, bytes_per_pixel, true, mtx);
|
|
236
|
+
|
|
237
|
+
// buf now contains raw BGRA bitmap.
|
|
238
|
+
console.log('Example 8: Successfully rasterized into memory buffer.');
|
|
239
|
+
} catch (err) {
|
|
240
|
+
console.log(err);
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
//--------------------------------------------------------------------------------
|
|
244
|
+
// Example 9) Export raster content to PNG using different image smoothing settings.
|
|
245
|
+
try {
|
|
246
|
+
const text_doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'lorem_ipsum.pdf');
|
|
247
|
+
text_doc.initSecurityHandler();
|
|
248
|
+
const itr = await text_doc.getPageIterator();
|
|
249
|
+
const page = await itr.current();
|
|
250
|
+
|
|
251
|
+
draw.setImageSmoothing(false, false);
|
|
252
|
+
let filename = 'raster_text_no_smoothing.png';
|
|
253
|
+
await draw.export(page, outputPath + filename);
|
|
254
|
+
console.log('Example 9 a): ' + filename + '. Done.');
|
|
255
|
+
|
|
256
|
+
filename = 'raster_text_smoothed.png';
|
|
257
|
+
draw.setImageSmoothing(true, false /*default quality bilinear resampling*/);
|
|
258
|
+
await draw.export(page, outputPath + filename);
|
|
259
|
+
console.log('Example 9 b): ' + filename + '. Done.');
|
|
260
|
+
|
|
261
|
+
filename = 'raster_text_high_quality.png';
|
|
262
|
+
draw.setImageSmoothing(true, true /*high quality area resampling*/);
|
|
263
|
+
await draw.export(page, outputPath + filename);
|
|
264
|
+
console.log('Example 9 c): ' + filename + '. Done.');
|
|
265
|
+
} catch (err) {
|
|
266
|
+
console.log(err);
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
//--------------------------------------------------------------------------------
|
|
270
|
+
// Example 10) Export separations directly, without conversion to an output colorspace
|
|
271
|
+
try {
|
|
272
|
+
const separation_doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'op_blend_test.pdf');
|
|
273
|
+
separation_doc.initSecurityHandler();
|
|
274
|
+
const separation_hint = await hint_set.createDict();
|
|
275
|
+
await separation_hint.putName('ColorSpace', 'Separation');
|
|
276
|
+
draw.setDPI(96);
|
|
277
|
+
draw.setImageSmoothing(true, true);
|
|
278
|
+
draw.setOverprint(PDFNet.PDFRasterizer.OverprintPreviewMode.e_op_on);
|
|
279
|
+
|
|
280
|
+
const itr = await separation_doc.getPageIterator();
|
|
281
|
+
const page = await itr.current();
|
|
282
|
+
let filename = 'merged_separations.png';
|
|
283
|
+
await draw.export(page, outputPath + filename, 'PNG');
|
|
284
|
+
console.log('Example 10 a): ' + filename + '. Done.');
|
|
285
|
+
|
|
286
|
+
filename = 'separation';
|
|
287
|
+
await draw.export(page, outputPath + filename, 'PNG', separation_hint);
|
|
288
|
+
console.log('Example 10 b): ' + filename + '_[ink].png. Done.');
|
|
289
|
+
|
|
290
|
+
filename = 'separation_NChannel.tif';
|
|
291
|
+
await draw.export(page, outputPath + filename, 'TIFF', separation_hint);
|
|
292
|
+
console.log('Example 10 c): ' + filename + '. Done.');
|
|
293
|
+
} catch (err) {
|
|
294
|
+
console.log(err);
|
|
295
|
+
}
|
|
296
|
+
} catch (err) {
|
|
297
|
+
console.log(err);
|
|
298
|
+
}
|
|
299
|
+
};
|
|
300
|
+
|
|
301
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
|
|
302
|
+
};
|
|
303
|
+
exports.runPDFDrawTest();
|
|
304
|
+
})(exports);
|
|
305
|
+
// eslint-disable-next-line spaced-comment
|
|
306
|
+
//# sourceURL=PDFDrawTest.js
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -0,0 +1,295 @@
|
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//-----------------------------------------------------------------------------------
|
|
7
|
+
// This sample demonstrates how to create layers in PDF.
|
|
8
|
+
// The sample also shows how to extract and render PDF layers in documents
|
|
9
|
+
// that contain optional content groups (OCGs)
|
|
10
|
+
//
|
|
11
|
+
// With the introduction of PDF version 1.5 came the concept of Layers.
|
|
12
|
+
// Layers, or as they are more formally known Optional Content Groups (OCGs),
|
|
13
|
+
// refer to sections of content in a PDF document that can be selectively
|
|
14
|
+
// viewed or hidden by document authors or consumers. This capability is useful
|
|
15
|
+
// in CAD drawings, layered artwork, maps, multi-language documents etc.
|
|
16
|
+
//
|
|
17
|
+
// Notes:
|
|
18
|
+
// ---------------------------------------
|
|
19
|
+
// - This sample is using CreateLayer() utility method to create new OCGs.
|
|
20
|
+
// CreateLayer() is relatively basic, however it can be extended to set
|
|
21
|
+
// other optional entries in the 'OCG' and 'OCProperties' dictionary. For
|
|
22
|
+
// a complete listing of possible entries in OC dictionary please refer to
|
|
23
|
+
// section 4.10 'Optional Content' in the PDF Reference Manual.
|
|
24
|
+
// - The sample is grouping all layer content into separate Form XObjects.
|
|
25
|
+
// Although using PDFNet is is also possible to specify Optional Content in
|
|
26
|
+
// Content Streams (Section 4.10.2 in PDF Reference), Optional Content in
|
|
27
|
+
// XObjects results in PDFs that are cleaner, less-error prone, and faster
|
|
28
|
+
// to process.
|
|
29
|
+
//-----------------------------------------------------------------------------------
|
|
30
|
+
|
|
31
|
+
const { PDFNet } = require('../../../lib/pdfnet.js');
|
|
32
|
+
const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
|
|
33
|
+
|
|
34
|
+
((exports) => {
|
|
35
|
+
|
|
36
|
+
exports.runPDFLayersTest = () => {
|
|
37
|
+
const inputPath = '../../TestFiles/';
|
|
38
|
+
const outputPath = inputPath + 'Output/';
|
|
39
|
+
|
|
40
|
+
// A utility function used to add new Content Groups (Layers) to the document.
|
|
41
|
+
const CreateLayer = async(doc, layerName) => {
|
|
42
|
+
await PDFNet.startDeallocateStack();
|
|
43
|
+
const grp = await PDFNet.OCG.create(doc, layerName);
|
|
44
|
+
let cfg = await doc.getOCGConfig();
|
|
45
|
+
if (cfg == null) {
|
|
46
|
+
cfg = await PDFNet.OCGConfig.create(doc, true);
|
|
47
|
+
cfg.setName('Default');
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Add the new OCG to the list of layers that should appear in PDF viewer GUI.
|
|
51
|
+
let layerOrderArray = await cfg.getOrder();
|
|
52
|
+
if (layerOrderArray == null) {
|
|
53
|
+
layerOrderArray = await doc.createIndirectArray();
|
|
54
|
+
cfg.setOrder(layerOrderArray);
|
|
55
|
+
}
|
|
56
|
+
const grpSDFObj = await grp.getSDFObj();
|
|
57
|
+
layerOrderArray.pushBack(grpSDFObj);
|
|
58
|
+
|
|
59
|
+
await PDFNet.endDeallocateStack();
|
|
60
|
+
return grp;
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
// Creates some content (3 images) and associate them with the image layer
|
|
64
|
+
const CreateGroup1 = async(doc, layer) => {
|
|
65
|
+
await PDFNet.startDeallocateStack();
|
|
66
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
67
|
+
writer.begin(doc);
|
|
68
|
+
|
|
69
|
+
// Create an Image that can be reused in the document or on the same page.
|
|
70
|
+
const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
|
|
71
|
+
|
|
72
|
+
const builder = await PDFNet.ElementBuilder.create();
|
|
73
|
+
const imgWidth = await img.getImageWidth();
|
|
74
|
+
const imgHeight = await img.getImageHeight();
|
|
75
|
+
const imgMatrix = new PDFNet.Matrix2D(imgWidth / 2, -145, 20, imgHeight / 2, 200, 150);
|
|
76
|
+
const element = await builder.createImageFromMatrix(img, imgMatrix);
|
|
77
|
+
writer.writePlacedElement(element);
|
|
78
|
+
|
|
79
|
+
const gstate = await element.getGState(); // use the same image (just change its matrix)
|
|
80
|
+
gstate.setTransform(200, 0, 0, 300, 50, 450);
|
|
81
|
+
writer.writePlacedElement(element);
|
|
82
|
+
|
|
83
|
+
// use the same image again (just change its matrix).
|
|
84
|
+
writer.writePlacedElement(await builder.createImageScaled(img, 300, 600, 200, -150));
|
|
85
|
+
|
|
86
|
+
const grpObj = await writer.end();
|
|
87
|
+
|
|
88
|
+
// Indicate that this form (content group) belongs to the given layer (OCG).
|
|
89
|
+
grpObj.putName('Subtype', 'Form');
|
|
90
|
+
grpObj.put('OC', layer);
|
|
91
|
+
grpObj.putRect('BBox', 0, 0, 1000, 1000); // Set the clip box for the content.
|
|
92
|
+
await PDFNet.endDeallocateStack();
|
|
93
|
+
|
|
94
|
+
return grpObj;
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
const CreateGroup2 = async(doc, layer) => {
|
|
98
|
+
await PDFNet.startDeallocateStack();
|
|
99
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
100
|
+
writer.begin(doc);
|
|
101
|
+
|
|
102
|
+
// Create a path object in the shape of a heart.
|
|
103
|
+
const builder = await PDFNet.ElementBuilder.create();
|
|
104
|
+
builder.pathBegin(); // start constructing the path
|
|
105
|
+
builder.moveTo(306, 396);
|
|
106
|
+
builder.curveTo(681, 771, 399.75, 864.75, 306, 771);
|
|
107
|
+
builder.curveTo(212.25, 864.75, -69, 771, 306, 396);
|
|
108
|
+
builder.closePath();
|
|
109
|
+
const element = await builder.pathEnd(); // the path geometry is now specified.
|
|
110
|
+
|
|
111
|
+
// Set the path FILL color space and color.
|
|
112
|
+
element.setPathFill(true);
|
|
113
|
+
const gstate = await element.getGState();
|
|
114
|
+
const CMYKSpace = await PDFNet.ColorSpace.createDeviceCMYK();
|
|
115
|
+
gstate.setFillColorSpace(CMYKSpace);
|
|
116
|
+
const cyanColorPt = await PDFNet.ColorPt.init(1, 0, 0, 0); // CMYK
|
|
117
|
+
gstate.setFillColorWithColorPt(cyanColorPt); // cyan
|
|
118
|
+
|
|
119
|
+
// Set the path STROKE color space and color.
|
|
120
|
+
element.setPathStroke(true);
|
|
121
|
+
const RGBSpace = await PDFNet.ColorSpace.createDeviceRGB();
|
|
122
|
+
gstate.setStrokeColorSpace(RGBSpace);
|
|
123
|
+
const redColorPt = await PDFNet.ColorPt.init(1, 0, 0); // RGB
|
|
124
|
+
gstate.setStrokeColorWithColorPt(redColorPt); // red
|
|
125
|
+
gstate.setLineWidth(20);
|
|
126
|
+
|
|
127
|
+
gstate.setTransform(0.5, 0, 0, 0.5, 280, 300);
|
|
128
|
+
|
|
129
|
+
writer.writeElement(element);
|
|
130
|
+
|
|
131
|
+
const grpObj = await writer.end();
|
|
132
|
+
|
|
133
|
+
// Indicate that this form (content group) belongs to the given layer (OCG).
|
|
134
|
+
grpObj.putName('Subtype', 'Form');
|
|
135
|
+
grpObj.put('OC', layer);
|
|
136
|
+
grpObj.putRect('BBox', 0, 0, 1000, 1000); // Set the clip box for the content.
|
|
137
|
+
|
|
138
|
+
await PDFNet.endDeallocateStack();
|
|
139
|
+
return grpObj;
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
const CreateGroup3 = async(doc, layer) => {
|
|
143
|
+
await PDFNet.startDeallocateStack();
|
|
144
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
145
|
+
writer.begin(doc);
|
|
146
|
+
|
|
147
|
+
const builder = await PDFNet.ElementBuilder.create();
|
|
148
|
+
|
|
149
|
+
// Begin writing a block of text
|
|
150
|
+
const textFont = await PDFNet.Font.create(doc, PDFNet.Font.StandardType1Font.e_times_roman);
|
|
151
|
+
let element = await builder.createTextBeginWithFont(textFont, 120);
|
|
152
|
+
writer.writeElement(element);
|
|
153
|
+
|
|
154
|
+
element = await builder.createNewTextRun('A text layer!');
|
|
155
|
+
|
|
156
|
+
// Rotate text 45 degrees, than translate 180 pts horizontally and 100 pts vertically.
|
|
157
|
+
const transform = await PDFNet.Matrix2D.createRotationMatrix(-45 * (3.1415 / 180.0));
|
|
158
|
+
await transform.concat(1, 0, 0, 1, 180, 100);
|
|
159
|
+
await element.setTextMatrix(transform);
|
|
160
|
+
|
|
161
|
+
await writer.writeElement(element);
|
|
162
|
+
await writer.writeElement(await builder.createTextEnd());
|
|
163
|
+
|
|
164
|
+
const grpObj = await writer.end();
|
|
165
|
+
|
|
166
|
+
// Indicate that this form (content group) belongs to the given layer (OCG).
|
|
167
|
+
grpObj.putName('Subtype', 'Form');
|
|
168
|
+
grpObj.put('OC', layer);
|
|
169
|
+
grpObj.putRect('BBox', 0, 0, 1000, 1000); // Set the clip box for the content.
|
|
170
|
+
await PDFNet.endDeallocateStack();
|
|
171
|
+
return grpObj;
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
const main = async() => {
|
|
176
|
+
try {
|
|
177
|
+
const doc = await PDFNet.PDFDoc.create();
|
|
178
|
+
doc.initSecurityHandler();
|
|
179
|
+
|
|
180
|
+
const imageLayer = await CreateLayer(doc, 'Image Layer');
|
|
181
|
+
const textLayer = await CreateLayer(doc, 'Text Layer');
|
|
182
|
+
const vectorLayer = await CreateLayer(doc, 'Vector Layer');
|
|
183
|
+
|
|
184
|
+
// Start a new page ------------------------------------
|
|
185
|
+
const page = await doc.pageCreate();
|
|
186
|
+
|
|
187
|
+
const builder = await PDFNet.ElementBuilder.create(); // ElementBuilder is used to build new Element objects
|
|
188
|
+
const writer = await PDFNet.ElementWriter.create(); // ElementWriter is used to write Elements to the page
|
|
189
|
+
writer.beginOnPage(page); // Begin writing to the page
|
|
190
|
+
|
|
191
|
+
const groupObj = await CreateGroup1(doc, (await imageLayer.getSDFObj()));
|
|
192
|
+
let element = await builder.createFormFromStream(groupObj);
|
|
193
|
+
writer.writeElement(element);
|
|
194
|
+
|
|
195
|
+
const groupObj2 = await CreateGroup2(doc, (await vectorLayer.getSDFObj()));
|
|
196
|
+
element = await builder.createFormFromStream(groupObj2);
|
|
197
|
+
writer.writeElement(element);
|
|
198
|
+
|
|
199
|
+
// eslint-disable-next-line no-constant-condition
|
|
200
|
+
if (false) {
|
|
201
|
+
// A bit more advanced example of how to create an OCMD text layer that
|
|
202
|
+
// is visible only if text, image and path layers are all 'ON'.
|
|
203
|
+
// An example of how to set 'Visibility Policy' in OCMD.
|
|
204
|
+
const ocgs = doc.createIndirectArray();
|
|
205
|
+
ocgs.pushBack(await imageLayer.getSDFObj());
|
|
206
|
+
ocgs.pushBack(await vectorLayer.getSDFObj());
|
|
207
|
+
ocgs.PushBack(await textLayer.getSDFObj());
|
|
208
|
+
const textOcmd = await PDFNet.OCMD.create(doc, ocgs, PDFNet.OCMD.VisibilityPolicyType.e_AllOn);
|
|
209
|
+
element = await builder.createFormFromStream(await CreateGroup3(doc, (await textOcmd.getSDFObj())));
|
|
210
|
+
} else {
|
|
211
|
+
// let SDFObj = await textLayer.getSDFObj();
|
|
212
|
+
element = await builder.createFormFromStream(await CreateGroup3(doc, (await textLayer.getSDFObj())));
|
|
213
|
+
}
|
|
214
|
+
writer.writeElement(element);
|
|
215
|
+
|
|
216
|
+
// Add some content to the page that does not belong to any layer...
|
|
217
|
+
// In this case this is a rectangle representing the page border.
|
|
218
|
+
element = await builder.createRect(0, 0, (await page.getPageWidth()), (await page.getPageHeight()));
|
|
219
|
+
element.setPathFill(false);
|
|
220
|
+
element.setPathStroke(true);
|
|
221
|
+
const elementGState = await element.getGState();
|
|
222
|
+
elementGState.setLineWidth(40);
|
|
223
|
+
writer.writeElement(element);
|
|
224
|
+
|
|
225
|
+
writer.end(); // save changes to the current page
|
|
226
|
+
doc.pagePushBack(page);
|
|
227
|
+
|
|
228
|
+
// Set the default viewing preference to display 'Layer' tab.
|
|
229
|
+
const prefs = await doc.getViewPrefs();
|
|
230
|
+
prefs.setPageMode(PDFNet.PDFDocViewPrefs.PageMode.e_UseOC);
|
|
231
|
+
|
|
232
|
+
await doc.save(outputPath + 'pdf_layers.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
233
|
+
console.log('Done.');
|
|
234
|
+
} catch (err) {
|
|
235
|
+
// console.log(err);
|
|
236
|
+
console.log(err.stack);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
// The following is a code snippet shows how to selectively render
|
|
240
|
+
// and export PDF layers.
|
|
241
|
+
try {
|
|
242
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(outputPath + 'pdf_layers.pdf');
|
|
243
|
+
doc.initSecurityHandler();
|
|
244
|
+
|
|
245
|
+
if (!(await doc.hasOC())) {
|
|
246
|
+
console.log("The document does not contain 'Optional Content'");
|
|
247
|
+
} else {
|
|
248
|
+
const initCfg = await doc.getOCGConfig();
|
|
249
|
+
const ctx = await PDFNet.OCGContext.createFromConfig(initCfg);
|
|
250
|
+
|
|
251
|
+
const pdfdraw = await PDFNet.PDFDraw.create();
|
|
252
|
+
pdfdraw.setImageSize(1000, 1000);
|
|
253
|
+
pdfdraw.setOCGContext(ctx);
|
|
254
|
+
|
|
255
|
+
const page = await doc.getPage(1);
|
|
256
|
+
|
|
257
|
+
await pdfdraw.export(page, outputPath + 'pdf_layers_default.png');
|
|
258
|
+
|
|
259
|
+
// Disable drawing of content that is not optional (i.e. is not part of any layer).
|
|
260
|
+
ctx.setNonOCDrawing(false);
|
|
261
|
+
|
|
262
|
+
// Now render each layer in the input document to a separate image.
|
|
263
|
+
const ocgs = await doc.getOCGs();
|
|
264
|
+
if (ocgs !== null) {
|
|
265
|
+
let i;
|
|
266
|
+
const sz = await ocgs.size();
|
|
267
|
+
for (i = 0; i < sz; ++i) {
|
|
268
|
+
const ocg = await PDFNet.OCG.createFromObj(await ocgs.getAt(i));
|
|
269
|
+
ctx.resetStates(false);
|
|
270
|
+
await ctx.setState(ocg, true);
|
|
271
|
+
let fname = 'pdf_layers_';
|
|
272
|
+
fname += await ocg.getName();
|
|
273
|
+
fname += '.png';
|
|
274
|
+
console.log(fname);
|
|
275
|
+
await pdfdraw.export(page, outputPath + fname);
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Now draw content that is not part of any layer...
|
|
280
|
+
ctx.setNonOCDrawing(true);
|
|
281
|
+
await ctx.setOCDrawMode(PDFNet.OCGContext.OCDrawMode.e_NoOC);
|
|
282
|
+
await pdfdraw.export(page, outputPath + 'pdf_layers_non_oc.png');
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
console.log('Done.');
|
|
286
|
+
} catch (err) {
|
|
287
|
+
console.log(err.stack);
|
|
288
|
+
}
|
|
289
|
+
};
|
|
290
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
|
|
291
|
+
};
|
|
292
|
+
exports.runPDFLayersTest();
|
|
293
|
+
})(exports);
|
|
294
|
+
// eslint-disable-next-line spaced-comment
|
|
295
|
+
//# sourceURL=PDFLayersTest.js
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|