@pdftron/pdfnet-node-samples 10.9.0 → 10.10.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/{samples/AddImageTest → AddImageTest}/AddImageTest.js +115 -115
- package/{samples/AdvancedImagingTest → AdvancedImagingTest}/AdvancedImagingTest.js +78 -78
- package/{samples/AnnotationTest → AnnotationTest}/AnnotationTest.js +641 -641
- package/{samples/BookmarkTest → BookmarkTest}/BookmarkTest.js +219 -219
- package/{samples/CAD2PDFTest → CAD2PDFTest}/CAD2PDFTest.js +79 -79
- package/{samples/ContentReplacerTest → ContentReplacerTest}/ContentReplacerTest.js +75 -75
- package/{samples/ConvertPrintTest → ConvertPrintTest}/ConvertPrintTest.js +153 -153
- package/{samples/ConvertTest → ConvertTest}/ConvertTest.js +203 -203
- package/{samples/DataExtractionTest → DataExtractionTest}/DataExtractionTest.js +214 -214
- package/{samples/DigitalSignaturesTest → DigitalSignaturesTest}/DigitalSignaturesTest.js +622 -527
- package/{samples/DocumentCreationTest → DocumentCreationTest}/DocumentCreationTest.js +409 -409
- package/{samples/ElementBuilderTest → ElementBuilderTest}/ElementBuilderTest.js +513 -513
- package/{samples/ElementEditTest → ElementEditTest}/ElementEditTest.js +110 -110
- package/{samples/ElementReaderAdvTest → ElementReaderAdvTest}/ElementReaderAdvTest.js +305 -305
- package/{samples/ElementReaderTest → ElementReaderTest}/ElementReaderTest.js +77 -77
- package/{samples/EncTest → EncTest}/EncTest.js +175 -175
- package/{samples/FDFTest → FDFTest}/FDFTest.js +218 -218
- package/{samples/HTML2PDFTest → HTML2PDFTest}/HTML2PDFTest.js +164 -164
- package/{samples/HighlightsTest → HighlightsTest}/HighlightsTest.js +97 -97
- package/{samples/ImageExtractTest → ImageExtractTest}/ImageExtractTest.js +129 -129
- package/{samples/ImpositionTest → ImpositionTest}/ImpositionTest.js +86 -86
- package/{samples/InteractiveFormsTest → InteractiveFormsTest}/InteractiveFormsTest.js +381 -381
- package/{samples/JBIG2Test → JBIG2Test}/JBIG2Test.js +88 -88
- package/{samples/LicenseKey → LicenseKey}/LicenseKey.js +11 -11
- package/{samples/LogicalStructureTest → LogicalStructureTest}/LogicalStructureTest.js +250 -250
- package/{samples/OCRTest → OCRTest}/OCRTest.js +235 -235
- package/{samples/OfficeTemplateTest → OfficeTemplateTest}/OfficeTemplateTest.js +79 -79
- package/{samples/OfficeToPDFTest → OfficeToPDFTest}/OfficeToPDFTest.js +125 -125
- package/{samples/OptimizerTest → OptimizerTest}/OptimizerTest.js +191 -191
- package/{samples/PDF2HtmlTest → PDF2HtmlTest}/PDF2HtmlTest.js +123 -123
- package/{samples/PDF2OfficeTest → PDF2OfficeTest}/PDF2OfficeTest.js +158 -158
- package/{samples/PDFATest → PDFATest}/PDFATest.js +85 -85
- package/{samples/PDFDocMemoryTest → PDFDocMemoryTest}/PDFDocMemoryTest.js +84 -84
- package/{samples/PDFDrawTest → PDFDrawTest}/PDFDrawTest.js +305 -305
- package/{samples/PDFLayersTest → PDFLayersTest}/PDFLayersTest.js +294 -294
- package/{samples/PDFPackageTest → PDFPackageTest}/PDFPackageTest.js +111 -111
- package/{samples/PDFPageTest → PDFPageTest}/PDFPageTest.js +189 -189
- package/{samples/PDFRedactTest → PDFRedactTest}/PDFRedactTest.js +74 -74
- package/{samples/PageLabelsTest → PageLabelsTest}/PageLabelsTest.js +138 -138
- package/{samples/PatternTest → PatternTest}/PatternTest.js +226 -226
- package/{samples/RectTest → RectTest}/RectTest.js +40 -40
- package/{samples/SDFTest → SDFTest}/SDFTest.js +87 -87
- package/{samples/StamperTest → StamperTest}/StamperTest.js +255 -255
- package/{samples/TestFiles → TestFiles}/Misc-Fixed.pfa +1166 -1166
- package/{samples/TestFiles → TestFiles}/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +34 -34
- package/{samples/TestFiles → TestFiles}/form1_annots.xfdf +33 -33
- package/{samples/TestFiles → TestFiles}/form1_data.xfdf +139 -139
- package/{samples/TestFiles → TestFiles}/my_stream.txt +2310 -2310
- package/{samples/TestFiles → TestFiles}/tiger.svg +378 -378
- package/{samples/TextExtractTest → TextExtractTest}/TextExtractTest.js +286 -286
- package/{samples/TextSearchTest → TextSearchTest}/TextSearchTest.js +121 -121
- package/{samples/U3DTest → U3DTest}/U3DTest.js +104 -104
- package/{samples/UndoRedoTest → UndoRedoTest}/UndoRedoTest.js +101 -101
- package/{samples/UnicodeWriteTest → UnicodeWriteTest}/UnicodeWriteTest.js +173 -173
- package/{samples/WebViewerConvertTest → WebViewerConvertTest}/WebViewerConvertTest.js +135 -135
- package/legal.txt +632 -0
- package/license.pdf +0 -0
- package/package.json +20 -21
- package/readme.md +38 -13
- package/{samples/runall.bat → runall.bat} +12 -12
- package/{samples/runall.sh → runall.sh} +15 -15
- /package/{samples/TestFiles → TestFiles}/BusinessCardTemplate.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/Fishermen.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/Font_licenses.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/GlobalSignRootForTST.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/License.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/NotoSans_with_hindi.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/Output/empty +0 -0
- /package/{samples/TestFiles → TestFiles}/SYH_Letter.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/TigerText.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/US061222892-a.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/butterfly.png +0 -0
- /package/{samples/TestFiles → TestFiles}/credit card numbers.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.u3d +0 -0
- /package/{samples/TestFiles → TestFiles}/doc_to_sign.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/factsheet_Arabic.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/financial.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/fish.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/font.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1_data.fdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned-withfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/grayscale.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/hindi_sample_utf16le.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/imagemask.dat +0 -0
- /package/{samples/TestFiles → TestFiles}/logo_red.png +0 -0
- /package/{samples/TestFiles → TestFiles}/lorem_ipsum.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/multipage.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.xod +0 -0
- /package/{samples/TestFiles → TestFiles}/numbered.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/op_blend_test.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/palm.jp2 +0 -0
- /package/{samples/TestFiles → TestFiles}/paragraphs_and_tables.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/pdfnet.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.bmp +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.pfx +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron_smart_substitution.plugin +0 -0
- /package/{samples/TestFiles → TestFiles}/peppers.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/signature.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-emf.emf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-excel_2007.xlsx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-outlook.msg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-powerpoint_2007.pptx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-publisher.pub +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-rtf.rtf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-text.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-visio.vsd +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.html +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.mht +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/colorschememapping.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/filelist.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image001.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image002.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image003.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image004.emz +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image005.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image006.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image007.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/oledata.mso +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/themedata.thmx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-word_2007.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-xps.xps +0 -0
- /package/{samples/TestFiles → TestFiles}/table.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/tagged.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/the_rime_of_the_ancient_mariner.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/tiger.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified_approved.pdf +0 -0
|
@@ -1,130 +1,130 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
//-----------------------------------------------------------------------------------
|
|
7
|
-
// This sample illustrates one approach to PDF image extraction
|
|
8
|
-
// using PDFNet.
|
|
9
|
-
//
|
|
10
|
-
// Note: Besides direct image export, you can also convert PDF images
|
|
11
|
-
// to GDI+ Bitmap, or extract uncompressed/compressed image data directly
|
|
12
|
-
// using element.GetImageData() (e.g. as illustrated in ElementReaderAdv
|
|
13
|
-
// sample project).
|
|
14
|
-
//-----------------------------------------------------------------------------------
|
|
15
|
-
|
|
16
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
17
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
18
|
-
|
|
19
|
-
((exports) => {
|
|
20
|
-
'use strict';
|
|
21
|
-
|
|
22
|
-
exports.runImageExtractTest = () => {
|
|
23
|
-
|
|
24
|
-
let image_counter = 0;
|
|
25
|
-
const outputPath = '../TestFiles/Output/';
|
|
26
|
-
|
|
27
|
-
const imageExtract = async (reader) => {
|
|
28
|
-
let element;
|
|
29
|
-
while ((element = await reader.next()) !== null) {
|
|
30
|
-
switch (await element.getType()) {
|
|
31
|
-
case PDFNet.Element.Type.e_image:
|
|
32
|
-
case PDFNet.Element.Type.e_inline_image:
|
|
33
|
-
console.log('--> Image: ' + ++image_counter);
|
|
34
|
-
console.log(' Width: ' + await element.getImageWidth());
|
|
35
|
-
console.log(' Height: ' + await element.getImageHeight());
|
|
36
|
-
console.log(' BPC: ' + await element.getBitsPerComponent());
|
|
37
|
-
|
|
38
|
-
const ctm = await element.getCTM();
|
|
39
|
-
let x2 = 1, y2 = 1;
|
|
40
|
-
const result = await ctm.mult(x2, y2);
|
|
41
|
-
x2 = result.x;
|
|
42
|
-
y2 = result.y;
|
|
43
|
-
console.log(' Coords: x1=' + ctm.m_h.toFixed(2) + ', y1=' + ctm.m_v.toFixed(2)
|
|
44
|
-
+ ', x2=' + x2.toFixed(2) + ', y2=' + y2.toFixed(2));
|
|
45
|
-
|
|
46
|
-
if (await element.getType() == PDFNet.Element.Type.e_image) {
|
|
47
|
-
const image = await PDFNet.Image.createFromObj(await element.getXObject());
|
|
48
|
-
image.export(outputPath + 'image_extract1_' + image_counter);
|
|
49
|
-
}
|
|
50
|
-
break;
|
|
51
|
-
case PDFNet.Element.Type.e_form: // Process form XObjects
|
|
52
|
-
reader.formBegin();
|
|
53
|
-
await imageExtract(reader);
|
|
54
|
-
reader.end();
|
|
55
|
-
break;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
const main = async () => {
|
|
61
|
-
|
|
62
|
-
// Example 1:
|
|
63
|
-
// Extract images by traversing the display list for
|
|
64
|
-
// every page. With this approach it is possible to obtain
|
|
65
|
-
// image positioning information and DPI.
|
|
66
|
-
try {
|
|
67
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
68
|
-
doc.initSecurityHandler();
|
|
69
|
-
|
|
70
|
-
const reader = await PDFNet.ElementReader.create();
|
|
71
|
-
const itr = await doc.getPageIterator(1);
|
|
72
|
-
// Read every page
|
|
73
|
-
for (itr; await itr.hasNext(); await itr.next()) {
|
|
74
|
-
const page = await itr.current();
|
|
75
|
-
reader.beginOnPage(page);
|
|
76
|
-
await imageExtract(reader);
|
|
77
|
-
reader.end();
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
console.log('Done.');
|
|
81
|
-
} catch (err) {
|
|
82
|
-
console.log(err);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
console.log('----------------------------------------------------------------');
|
|
86
|
-
|
|
87
|
-
// Example 2:
|
|
88
|
-
// Extract images by scanning the low-level document.
|
|
89
|
-
try {
|
|
90
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
91
|
-
doc.initSecurityHandler();
|
|
92
|
-
image_counter = 0;
|
|
93
|
-
|
|
94
|
-
const cos_doc = await doc.getSDFDoc();
|
|
95
|
-
const num_objs = await cos_doc.xRefSize();
|
|
96
|
-
for (var i = 0; i < num_objs; i++) {
|
|
97
|
-
const obj = await cos_doc.getObj(i);
|
|
98
|
-
if (obj && !(await obj.isFree()) && await obj.isStream()) {
|
|
99
|
-
// Process only images
|
|
100
|
-
var itr = await obj.find('Type');
|
|
101
|
-
if (!(await itr.hasNext()) || await (await itr.value()).getName() !== 'XObject')
|
|
102
|
-
continue;
|
|
103
|
-
|
|
104
|
-
itr = await obj.find('Subtype');
|
|
105
|
-
if (!(await itr.hasNext()) || await (await itr.value()).getName() !== 'Image')
|
|
106
|
-
continue;
|
|
107
|
-
const image = await PDFNet.Image.createFromObj(obj);
|
|
108
|
-
console.log('--> Image: ' + ++image_counter);
|
|
109
|
-
console.log(' Width: ' + await image.getImageWidth());
|
|
110
|
-
console.log(' Height: ' + await image.getImageHeight());
|
|
111
|
-
console.log(' BPC: ' + await image.getBitsPerComponent());
|
|
112
|
-
|
|
113
|
-
image.export(outputPath + 'image_extract2_' + image_counter);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
console.log('Done.');
|
|
118
|
-
} catch (err) {
|
|
119
|
-
console.log(err);
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
}
|
|
123
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
124
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
125
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
126
|
-
};
|
|
127
|
-
exports.runImageExtractTest();
|
|
128
|
-
})(exports);
|
|
129
|
-
// eslint-disable-next-line spaced-comment
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//-----------------------------------------------------------------------------------
|
|
7
|
+
// This sample illustrates one approach to PDF image extraction
|
|
8
|
+
// using PDFNet.
|
|
9
|
+
//
|
|
10
|
+
// Note: Besides direct image export, you can also convert PDF images
|
|
11
|
+
// to GDI+ Bitmap, or extract uncompressed/compressed image data directly
|
|
12
|
+
// using element.GetImageData() (e.g. as illustrated in ElementReaderAdv
|
|
13
|
+
// sample project).
|
|
14
|
+
//-----------------------------------------------------------------------------------
|
|
15
|
+
|
|
16
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
17
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
18
|
+
|
|
19
|
+
((exports) => {
|
|
20
|
+
'use strict';
|
|
21
|
+
|
|
22
|
+
exports.runImageExtractTest = () => {
|
|
23
|
+
|
|
24
|
+
let image_counter = 0;
|
|
25
|
+
const outputPath = '../TestFiles/Output/';
|
|
26
|
+
|
|
27
|
+
const imageExtract = async (reader) => {
|
|
28
|
+
let element;
|
|
29
|
+
while ((element = await reader.next()) !== null) {
|
|
30
|
+
switch (await element.getType()) {
|
|
31
|
+
case PDFNet.Element.Type.e_image:
|
|
32
|
+
case PDFNet.Element.Type.e_inline_image:
|
|
33
|
+
console.log('--> Image: ' + ++image_counter);
|
|
34
|
+
console.log(' Width: ' + await element.getImageWidth());
|
|
35
|
+
console.log(' Height: ' + await element.getImageHeight());
|
|
36
|
+
console.log(' BPC: ' + await element.getBitsPerComponent());
|
|
37
|
+
|
|
38
|
+
const ctm = await element.getCTM();
|
|
39
|
+
let x2 = 1, y2 = 1;
|
|
40
|
+
const result = await ctm.mult(x2, y2);
|
|
41
|
+
x2 = result.x;
|
|
42
|
+
y2 = result.y;
|
|
43
|
+
console.log(' Coords: x1=' + ctm.m_h.toFixed(2) + ', y1=' + ctm.m_v.toFixed(2)
|
|
44
|
+
+ ', x2=' + x2.toFixed(2) + ', y2=' + y2.toFixed(2));
|
|
45
|
+
|
|
46
|
+
if (await element.getType() == PDFNet.Element.Type.e_image) {
|
|
47
|
+
const image = await PDFNet.Image.createFromObj(await element.getXObject());
|
|
48
|
+
image.export(outputPath + 'image_extract1_' + image_counter);
|
|
49
|
+
}
|
|
50
|
+
break;
|
|
51
|
+
case PDFNet.Element.Type.e_form: // Process form XObjects
|
|
52
|
+
reader.formBegin();
|
|
53
|
+
await imageExtract(reader);
|
|
54
|
+
reader.end();
|
|
55
|
+
break;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
const main = async () => {
|
|
61
|
+
|
|
62
|
+
// Example 1:
|
|
63
|
+
// Extract images by traversing the display list for
|
|
64
|
+
// every page. With this approach it is possible to obtain
|
|
65
|
+
// image positioning information and DPI.
|
|
66
|
+
try {
|
|
67
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
68
|
+
doc.initSecurityHandler();
|
|
69
|
+
|
|
70
|
+
const reader = await PDFNet.ElementReader.create();
|
|
71
|
+
const itr = await doc.getPageIterator(1);
|
|
72
|
+
// Read every page
|
|
73
|
+
for (itr; await itr.hasNext(); await itr.next()) {
|
|
74
|
+
const page = await itr.current();
|
|
75
|
+
reader.beginOnPage(page);
|
|
76
|
+
await imageExtract(reader);
|
|
77
|
+
reader.end();
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
console.log('Done.');
|
|
81
|
+
} catch (err) {
|
|
82
|
+
console.log(err);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
console.log('----------------------------------------------------------------');
|
|
86
|
+
|
|
87
|
+
// Example 2:
|
|
88
|
+
// Extract images by scanning the low-level document.
|
|
89
|
+
try {
|
|
90
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
91
|
+
doc.initSecurityHandler();
|
|
92
|
+
image_counter = 0;
|
|
93
|
+
|
|
94
|
+
const cos_doc = await doc.getSDFDoc();
|
|
95
|
+
const num_objs = await cos_doc.xRefSize();
|
|
96
|
+
for (var i = 0; i < num_objs; i++) {
|
|
97
|
+
const obj = await cos_doc.getObj(i);
|
|
98
|
+
if (obj && !(await obj.isFree()) && await obj.isStream()) {
|
|
99
|
+
// Process only images
|
|
100
|
+
var itr = await obj.find('Type');
|
|
101
|
+
if (!(await itr.hasNext()) || await (await itr.value()).getName() !== 'XObject')
|
|
102
|
+
continue;
|
|
103
|
+
|
|
104
|
+
itr = await obj.find('Subtype');
|
|
105
|
+
if (!(await itr.hasNext()) || await (await itr.value()).getName() !== 'Image')
|
|
106
|
+
continue;
|
|
107
|
+
const image = await PDFNet.Image.createFromObj(obj);
|
|
108
|
+
console.log('--> Image: ' + ++image_counter);
|
|
109
|
+
console.log(' Width: ' + await image.getImageWidth());
|
|
110
|
+
console.log(' Height: ' + await image.getImageHeight());
|
|
111
|
+
console.log(' BPC: ' + await image.getBitsPerComponent());
|
|
112
|
+
|
|
113
|
+
image.export(outputPath + 'image_extract2_' + image_counter);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
console.log('Done.');
|
|
118
|
+
} catch (err) {
|
|
119
|
+
console.log(err);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
}
|
|
123
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
124
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
125
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
126
|
+
};
|
|
127
|
+
exports.runImageExtractTest();
|
|
128
|
+
})(exports);
|
|
129
|
+
// eslint-disable-next-line spaced-comment
|
|
130
130
|
//# sourceURL=ImageExtractTest.js
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
//-----------------------------------------------------------------------------------
|
|
7
|
-
// The sample illustrates how multiple pages can be combined/imposed
|
|
8
|
-
// using PDFNet. Page imposition can be used to arrange/order pages
|
|
9
|
-
// prior to printing or to assemble a 'master' page from several 'source'
|
|
10
|
-
// pages. Using PDFNet API it is possible to write applications that can
|
|
11
|
-
// re-order the pages such that they will display in the correct order
|
|
12
|
-
// when the hard copy pages are compiled and folded correctly.
|
|
13
|
-
//-----------------------------------------------------------------------------------
|
|
14
|
-
|
|
15
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
16
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
17
|
-
|
|
18
|
-
((exports) => {
|
|
19
|
-
'use strict';
|
|
20
|
-
|
|
21
|
-
exports.runImpositionTest = () => {
|
|
22
|
-
const main = async () => {
|
|
23
|
-
try {
|
|
24
|
-
console.log('-------------------------------------------------');
|
|
25
|
-
console.log('Opening the input pdf...');
|
|
26
|
-
const in_doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
27
|
-
in_doc.initSecurityHandler();
|
|
28
|
-
|
|
29
|
-
// Create a list of pages to import from one PDF document to another.
|
|
30
|
-
const import_pages = [];
|
|
31
|
-
for (let itr = await in_doc.getPageIterator(); await itr.hasNext(); await itr.next()) {
|
|
32
|
-
import_pages.push(await itr.current());
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const new_doc = await PDFNet.PDFDoc.create();
|
|
36
|
-
const imported_pages = await new_doc.importPages(import_pages);
|
|
37
|
-
|
|
38
|
-
// Paper dimension for A3 format in points. Because one inch has
|
|
39
|
-
// 72 points, 11.69 inch 72 = 841.69 points
|
|
40
|
-
const media_box = await PDFNet.Rect.init(0, 0, 1190.88, 841.69);
|
|
41
|
-
const mid_point = await media_box.width() / 2;
|
|
42
|
-
const builder = await PDFNet.ElementBuilder.create();
|
|
43
|
-
const writer = await PDFNet.ElementWriter.create();
|
|
44
|
-
for (let i = 0; i < imported_pages.length; ++i) {
|
|
45
|
-
// Create a blank new A3 page and place on it two pages from the input document.
|
|
46
|
-
const new_page = await new_doc.pageCreate(media_box);
|
|
47
|
-
writer.beginOnPage(new_page);
|
|
48
|
-
// Place the first page
|
|
49
|
-
let src_page = imported_pages[i];
|
|
50
|
-
var element = await builder.createFormFromPage(src_page);
|
|
51
|
-
|
|
52
|
-
let sc_x = mid_point / await src_page.getPageWidth();
|
|
53
|
-
let sc_y = await media_box.height() / await src_page.getPageHeight();
|
|
54
|
-
let scale = sc_x < sc_y ? sc_x : sc_y; // min(sc_x, sc_y)
|
|
55
|
-
await element.getGState().then(gstate => gstate.setTransform(scale, 0, 0, scale, 0, 0));
|
|
56
|
-
writer.writePlacedElement(element);
|
|
57
|
-
|
|
58
|
-
// Place the second page
|
|
59
|
-
++i;
|
|
60
|
-
if (i < imported_pages.length) {
|
|
61
|
-
src_page = imported_pages[i];
|
|
62
|
-
element = await builder.createFormFromPage(src_page);
|
|
63
|
-
sc_x = mid_point / await src_page.getPageWidth();
|
|
64
|
-
sc_y = await media_box.height() / await src_page.getPageHeight();
|
|
65
|
-
scale = sc_x < sc_y ? sc_x : sc_y; // min(sc_x, sc_y)
|
|
66
|
-
await element.getGState().then(gstate => gstate.setTransform(scale, 0, 0, scale, mid_point, 0));
|
|
67
|
-
writer.writePlacedElement(element);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
await writer.end();
|
|
71
|
-
new_doc.pagePushBack(new_page);
|
|
72
|
-
}
|
|
73
|
-
await new_doc.save('../TestFiles/Output/newsletter_booklet.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
74
|
-
console.log('Done. Result saved in newsletter_booklet.pdf...');
|
|
75
|
-
|
|
76
|
-
} catch (err) {
|
|
77
|
-
console.log(err);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
81
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
82
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
83
|
-
};
|
|
84
|
-
exports.runImpositionTest();
|
|
85
|
-
})(exports);
|
|
86
|
-
// eslint-disable-next-line spaced-comment
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//-----------------------------------------------------------------------------------
|
|
7
|
+
// The sample illustrates how multiple pages can be combined/imposed
|
|
8
|
+
// using PDFNet. Page imposition can be used to arrange/order pages
|
|
9
|
+
// prior to printing or to assemble a 'master' page from several 'source'
|
|
10
|
+
// pages. Using PDFNet API it is possible to write applications that can
|
|
11
|
+
// re-order the pages such that they will display in the correct order
|
|
12
|
+
// when the hard copy pages are compiled and folded correctly.
|
|
13
|
+
//-----------------------------------------------------------------------------------
|
|
14
|
+
|
|
15
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
16
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
17
|
+
|
|
18
|
+
((exports) => {
|
|
19
|
+
'use strict';
|
|
20
|
+
|
|
21
|
+
exports.runImpositionTest = () => {
|
|
22
|
+
const main = async () => {
|
|
23
|
+
try {
|
|
24
|
+
console.log('-------------------------------------------------');
|
|
25
|
+
console.log('Opening the input pdf...');
|
|
26
|
+
const in_doc = await PDFNet.PDFDoc.createFromFilePath('../TestFiles/newsletter.pdf');
|
|
27
|
+
in_doc.initSecurityHandler();
|
|
28
|
+
|
|
29
|
+
// Create a list of pages to import from one PDF document to another.
|
|
30
|
+
const import_pages = [];
|
|
31
|
+
for (let itr = await in_doc.getPageIterator(); await itr.hasNext(); await itr.next()) {
|
|
32
|
+
import_pages.push(await itr.current());
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const new_doc = await PDFNet.PDFDoc.create();
|
|
36
|
+
const imported_pages = await new_doc.importPages(import_pages);
|
|
37
|
+
|
|
38
|
+
// Paper dimension for A3 format in points. Because one inch has
|
|
39
|
+
// 72 points, 11.69 inch 72 = 841.69 points
|
|
40
|
+
const media_box = await PDFNet.Rect.init(0, 0, 1190.88, 841.69);
|
|
41
|
+
const mid_point = await media_box.width() / 2;
|
|
42
|
+
const builder = await PDFNet.ElementBuilder.create();
|
|
43
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
44
|
+
for (let i = 0; i < imported_pages.length; ++i) {
|
|
45
|
+
// Create a blank new A3 page and place on it two pages from the input document.
|
|
46
|
+
const new_page = await new_doc.pageCreate(media_box);
|
|
47
|
+
writer.beginOnPage(new_page);
|
|
48
|
+
// Place the first page
|
|
49
|
+
let src_page = imported_pages[i];
|
|
50
|
+
var element = await builder.createFormFromPage(src_page);
|
|
51
|
+
|
|
52
|
+
let sc_x = mid_point / await src_page.getPageWidth();
|
|
53
|
+
let sc_y = await media_box.height() / await src_page.getPageHeight();
|
|
54
|
+
let scale = sc_x < sc_y ? sc_x : sc_y; // min(sc_x, sc_y)
|
|
55
|
+
await element.getGState().then(gstate => gstate.setTransform(scale, 0, 0, scale, 0, 0));
|
|
56
|
+
writer.writePlacedElement(element);
|
|
57
|
+
|
|
58
|
+
// Place the second page
|
|
59
|
+
++i;
|
|
60
|
+
if (i < imported_pages.length) {
|
|
61
|
+
src_page = imported_pages[i];
|
|
62
|
+
element = await builder.createFormFromPage(src_page);
|
|
63
|
+
sc_x = mid_point / await src_page.getPageWidth();
|
|
64
|
+
sc_y = await media_box.height() / await src_page.getPageHeight();
|
|
65
|
+
scale = sc_x < sc_y ? sc_x : sc_y; // min(sc_x, sc_y)
|
|
66
|
+
await element.getGState().then(gstate => gstate.setTransform(scale, 0, 0, scale, mid_point, 0));
|
|
67
|
+
writer.writePlacedElement(element);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
await writer.end();
|
|
71
|
+
new_doc.pagePushBack(new_page);
|
|
72
|
+
}
|
|
73
|
+
await new_doc.save('../TestFiles/Output/newsletter_booklet.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
74
|
+
console.log('Done. Result saved in newsletter_booklet.pdf...');
|
|
75
|
+
|
|
76
|
+
} catch (err) {
|
|
77
|
+
console.log(err);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
81
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
82
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
83
|
+
};
|
|
84
|
+
exports.runImpositionTest();
|
|
85
|
+
})(exports);
|
|
86
|
+
// eslint-disable-next-line spaced-comment
|
|
87
87
|
//# sourceURL=ImpositionTest.js
|