Объединение файлов PostScript в PDF с помощью C++
Вы можете проверить качество слияния Aspose.Page PS и просмотреть результаты через бесплатный онлайн-сервис PostScipt Merger
Aspose.Page для слияния C++ PS позволяет объединять файлы PostScript (PS) с документами PDF в Windows и Linux.
Для объединения PS в PDF необходимо выполнить несколько шагов:
- Инициализируйте входной поток для первого входного файла PS.
- Инициализируйте выходной поток для выходного PDF-документа.
- Создайте массив PS-файлов, который будет объединен с первым.
- Создайте экземпляр PsDocument из созданного ранее входного потока.
- Используйте PdfSaveOptions, чтобы указать логические значения AdditionalFontsFolder и SuppressError.
- Создайте экземпляр PdfDevice из созданного ранее выходного потока.
- Объедините документ PostScript в формате PDF с возможностью сохранения PDF.
- Если значение SuppressErrors было истинным, как это установлено по умолчанию, можно увидеть, какие ошибки были выданы во время слияния PS с PDF и сохранены в списке Исключения.
В следующем фрагменте кода показано, как объединить файлы PS с документом PDF на C++:
1For complete examples and data files, please go to https://github.com/aspose-page/Aspose.Page-for-C
2// Initialize PDF output stream
3System::SharedPtr<System::IO::FileStream> pdfStream = System::MakeObject<System::IO::FileStream>(outDir() + u"outputPDF_out.pdf", System::IO::FileMode::Create, System::IO::FileAccess::Write);
4// Initialize PostScript input stream
5System::SharedPtr<System::IO::FileStream> psStream = System::MakeObject<System::IO::FileStream>(dataDir() + u"input.ps", System::IO::FileMode::Open, System::IO::FileAccess::Read);
6System::SharedPtr<PsDocument> document = System::MakeObject<PsDocument>(psStream);
7
8// Create an array of PostScript file that will be merged with the first one
9System::ArrayPtr<System::String> filesForMerge = System::MakeArray<System::String>({dataDir() + u"input2.ps", dataDir() + u"input3.ps"});
10
11// If you want to convert Postscript file despite of minor errors set this flag
12bool suppressErrors = true;
13
14//Initialize options object with necessary parameters.
15System::SharedPtr<PdfSaveOptions> options = System::MakeObject<PdfSaveOptions>(suppressErrors);
16// If you want to add special folder where fonts are stored. Default fonts folder in OS is always included.
17options->set_AdditionalFontsFolders(System::MakeArray<System::String>({FONT_FOLDER}));
18
19// Default page size is 595x842 and it is not mandatory to set it in PdfDevice
20System::SharedPtr<Aspose::Page::EPS::Device::PdfDevice> device = System::MakeObject<Aspose::Page::EPS::Device::PdfDevice>(pdfStream);
21// But if you need to specify size and image format use following line
22//System::SharedPtr<Aspose::Page::EPS::Device::PdfDevice> device = System::MakeObject<Aspose::Page::EPS::Device::PdfDevice>(pdfStream, System::Drawing::Size(595, 842));
23
24
25{
26 auto __finally_guard_0 = ::System::MakeScopeGuard([&psStream, &pdfStream]()
27 {
28 psStream->Close();
29 pdfStream->Close();
30 });
31
32 try
33 {
34 document->Merge(filesForMerge, device, options);
35 }
36 catch (...)
37 {
38 throw;
39 }
40}
Давайте рассмотрим PdfSaveOptions. Используя этот класс, мы можем назначать различные параметры преобразования при объединении PS в PDF.
- AdditionalFontsFolder указывает места, где можно найти шрифты. Папки системных шрифтов всегда включены по умолчанию.
- SuppressError контролирует поведение слияния PS и PDF при появлении некритических ошибок. Если значение истинно, то можно просмотреть список таких ошибок после слияния в поле Исключения. Значение по умолчанию — правда.
- Debug позволяет выводить отладочную информацию на консоль. Значение по умолчанию — ложь.