PostScript XPS у PDF і Image C++

У моїй попередній публікації я показав вам, як легко програмно створювати або редагувати документи PostScript (PS/EPS) і XPS за допомогою Aspose.Page for C++. У цій статті я покажу, як конвертувати документи PS/EPS або XPS у PDF або растрові формати зображень, включаючи PNG, JPEG, TIFF і BMP, за допомогою C++. Решта статті складається з таких розділів:

Перш ніж почати, я припускаю, що ви завантажили Aspose.Page for C++ і посилалися на нього у своєму проекті C++. Однак, якщо ви цього не зробили, ви можете встановити його з NuGet або завантажити повний пакет разом із консольною програмою plug and play із розділу Завантаження.

Перетворюйте PostScript PS/EPS у PDF на C++

Нижче наведено кроки для перетворення документа PostScript PS/EPS у PDF:

  • Створіть об’єкт FileStream для вихідного файлу PDF.
  • Завантажте вхідний документ PostScript в об’єкт FileStream.
  • Створіть та ініціалізуйте об’єкт PsDocument із вхідним потоком.
  • Створіть та ініціалізуйте об’єкт PdfDevice із вихідним потоком.
  • Обробіть документ і збережіть його як файл PDF за допомогою методу PsDocument->Save.

У наведеному нижче прикладі коду показано, як конвертувати документ PostScript PS у PDF на C++.

// Ініціалізувати вихідний потік PDF
System::SharedPtr<System::IO::FileStream> pdfStream = System::MakeObject<System::IO::FileStream>(value + u"PStoPDF.pdf", System::IO::FileMode::Create, System::IO::FileAccess::Write);
// Ініціалізувати вхідний потік PostScript
System::SharedPtr<System::IO::FileStream> psStream = System::MakeObject<System::IO::FileStream>(value + u"input.ps", System::IO::FileMode::Open, System::IO::FileAccess::Read);
System::SharedPtr<PsDocument> document = System::MakeObject<PsDocument>(psStream);

// Якщо ви хочете конвертувати файл Postscript, незважаючи на незначні помилки, установіть цей прапорець
bool suppressErrors = true;

// Ініціалізація об'єкта опцій необхідними параметрами.
System::SharedPtr<PdfSaveOptions> options = System::MakeObject<PdfSaveOptions>(suppressErrors);
// Якщо ви хочете додати спеціальну папку, де зберігаються шрифти. Папка шрифтів за замовчуванням в ОС завжди включена.
options->set_AdditionalFontsFolders(System::MakeArray<System::String>({ u"{FONT_FOLDER}" }));

// Розмір сторінки за замовчуванням становить 595x842, і не обов’язково встановлювати його в PdfDevice
System::SharedPtr<Aspose::Page::EPS::Device::PdfDevice> device = System::MakeObject<Aspose::Page::EPS::Device::PdfDevice>(pdfStream);
// Але якщо вам потрібно вказати розмір і формат зображення, використовуйте такий рядок:
// Aspose.Page.EPS.Device.PdfDevice пристрій = новий Aspose.Page.EPS.Device.PdfDevice(pdfStream, новий System.Drawing.Size(595, 842));
{
	auto __finally_guard_0 = ::System::MakeScopeGuard([&psStream, &pdfStream]()
		{
			psStream->Close();
			pdfStream->Close();
		});

	try
	{
		document->Save(device, options);
	}
	catch (...)
	{
		throw;
	}
}

// Огляд помилок
if (suppressErrors)
{
	//auto ex_enumerator = (System::DynamicCastEnumerableTo<PsConverterException> (параметри->get_Exceptions()))->GetEnumerator();
	auto ex_enumerator = (options->get_Exceptions())->GetEnumerator();
	decltype(ex_enumerator->get_Current()) ex;
	while (ex_enumerator->MoveNext() && (ex = ex_enumerator->get_Current(), true))
	{
		System::Console::WriteLine(ex->get_Message());
	}
}

Перетворення PostScript PS/EPS на зображення на C++

Нижче наведено кроки для перетворення PS/EPS у формат зображення.

  • Створіть об’єкт ImageFormat, щоб установити формат вихідного зображення, тобто PNG.
  • Завантажте вхідний документ PostScript в об’єкт FileStream.
  • Створіть та ініціалізуйте об’єкт PsDocument із вхідним потоком.
  • Створіть об’єкт ImageDevice.
  • Обробіть документ і збережіть його як зображення за допомогою методу PsDocument->Save.

У наведеному нижче прикладі коду показано, як перетворити PostScript PS/EPS на зображення на C++.

// Ініціалізувати вихідний потік PDF
System::SharedPtr<System::Drawing::Imaging::ImageFormat> imageFormat = System::Drawing::Imaging::ImageFormat::get_Png();
// Ініціалізувати вхідний потік PostScript
System::SharedPtr<System::IO::FileStream> psStream = System::MakeObject<System::IO::FileStream>(value + u"inputForImage.ps", System::IO::FileMode::Open, System::IO::FileAccess::Read);

System::SharedPtr<PsDocument> document = System::MakeObject<PsDocument>(psStream);

// Якщо ви хочете конвертувати файл PostScript, незважаючи на незначні помилки, установіть цей прапорець
bool suppressErrors = true;

// Ініціалізація об'єкта опцій необхідними параметрами.
System::SharedPtr<ImageSaveOptions> options = System::MakeObject<ImageSaveOptions>(suppressErrors);

// Якщо ви хочете додати спеціальну папку, де зберігаються шрифти. Папка шрифтів за замовчуванням в ОС завжди включена.
options->set_AdditionalFontsFolders(System::MakeArray<System::String>({ u"{FONT_FOLDER}" }));

// Стандартним форматом зображення є PNG, і його необов’язково встановлювати в ImageDevice
// Розмір зображення за замовчуванням становить 595x842, і його необов’язково встановлювати в ImageDevice
System::SharedPtr<Aspose::Page::EPS::Device::ImageDevice> device = System::MakeObject<Aspose::Page::EPS::Device::ImageDevice>();
// Але якщо вам потрібно вказати розмір і формат зображення, використовуйте конструктор з параметрами
//ImageDevice device = new ImageDevice(new System.Drawing.Size(595, 842), System.Drawing.Imaging.ImageFormat.Jpeg);

{
	auto __finally_guard_0 = ::System::MakeScopeGuard([&psStream]()
		{
			psStream->Close();
		});

	try
	{
		document->Save(device, options);
	}
	catch (...)
	{
		throw;
	}
}

System::ArrayPtr<System::ArrayPtr<uint8_t>> imagesBytes = device->get_ImagesBytes();

int32_t i = 0;
{
	for (System::ArrayPtr<uint8_t> imageBytes : imagesBytes)
	{
		System::String imagePath = System::IO::Path::GetFullPath(value + System::String(u"out_image") + System::Convert::ToString(i) + u"." + System::ObjectExt::ToString(imageFormat).ToLower());
		{
			System::SharedPtr<System::IO::FileStream> fs = System::MakeObject<System::IO::FileStream>(imagePath, System::IO::FileMode::Create, System::IO::FileAccess::Write);
			// Очищення ресурсів під оператором «використання».
			System::Details::DisposeGuard<1> __dispose_guard_1({ fs });
			try
			{
				fs->Write(imageBytes, 0, imageBytes->get_Length());
			}
			catch (...)
			{
				__dispose_guard_1.SetCurrentException(std::current_exception());
			}
		}
		i++;
	}
}

// Огляд помилок
if (suppressErrors)
{
	//auto ex_enumerator = (System::DynamicCastEnumerableTo<PsConverterException> (параметри->get_Exceptions()))->GetEnumerator();
	//decltype(ex_enumerator->get_Current()) ex;
	//while (ex_enumerator->MoveNext() && (ex = ex_enumerator->get_Current(), true))
	//{
	//	System::Console::WriteLine(ex->get_Message());
	//}
}

Перетворіть XPS у PDF на C++

Нижче наведено кроки для перетворення документа XPS у PDF.

  • Створіть об’єкти FileStream для вхідних файлів XPS і вихідних PDF.
  • Завантажте потік документа XPS в об’єкт XpsDocument.
  • Створіть об’єкт класу PdfDevice та ініціалізуйте його вихідним потоком.
  • Перетворіть документ XPS на PDF за допомогою методу XpsDocument->Save.

У наведеному нижче прикладі коду показано, як конвертувати документ XPS у PDF на C++.

System::SharedPtr<System::IO::Stream> pdfStream = System::IO::File::Open(u"XPStoPDF.pdf", System::IO::FileMode::Create, System::IO::FileAccess::Write);
// Очищення ресурсів під оператором «використання».
System::Details::DisposeGuard<1> __dispose_guard_1({ pdfStream });

try {
	System::SharedPtr<System::IO::Stream> xpsStream = System::IO::File::Open(u"input.xps", System::IO::FileMode::Open, System::IO::FileAccess::Read);
	// Очищення ресурсів під оператором «використання».
	System::Details::DisposeGuard<1> __dispose_guard_0({ xpsStream });
	try
	{
		// Завантажте документ XPS із потоку
		System::SharedPtr<XpsDocument> document = System::MakeObject<XpsDocument>(xpsStream, System::MakeObject<XpsLoadOptions>());
		// або завантажити документ XPS безпосередньо з файлу. Тоді xpsStream не потрібен.
		// XpsDocument document = new XpsDocument(inputFileName, new XpsLoadOptions());

		// Ініціалізація об'єкта опцій необхідними параметрами.
		System::SharedPtr<Aspose::Page::XPS::Presentation::Pdf::PdfSaveOptions> options = [&] { auto tmp_0 = System::MakeObject<Aspose::Page::XPS::Presentation::Pdf::PdfSaveOptions>(); tmp_0->set_JpegQualityLevel(100); tmp_0->set_ImageCompression(Aspose::Page::XPS::Presentation::Pdf::PdfImageCompression::Jpeg); tmp_0->set_TextCompression(Aspose::Page::XPS::Presentation::Pdf::PdfTextCompression::Flate); tmp_0->set_PageNumbers(System::MakeArray<int32_t>({ 1, 2, 6 })); return tmp_0; }();

		// Створіть пристрій візуалізації для формату PDF
		System::SharedPtr<Aspose::Page::XPS::Presentation::Pdf::PdfDevice> device = System::MakeObject<Aspose::Page::XPS::Presentation::Pdf::PdfDevice>(pdfStream);

		document->Save(device, options);
	}
	catch (...)
	{
		__dispose_guard_0.SetCurrentException(std::current_exception());
	}
}
catch (...)
{
	__dispose_guard_1.SetCurrentException(std::current_exception());
}

Перетворення XPS на зображення на C++

Нижче наведено кроки для перетворення документа XPS у формат растрового зображення.

  • Завантажте вхідний документ XPS в об’єкт FileStream.
  • Створіть об’єкт XpsDocument та ініціалізуйте його об’єктом вхідного потоку.
  • Налаштуйте параметри збереження, створивши об’єкт класу PngSaveOptions.
  • Перетворіть XPS на зображення за допомогою методу XpsDocument->Save.

У наведеному нижче прикладі коду показано, як конвертувати зображення XPS у PNG на C++.

// Вхідний файл
System::String inputFileName =  u"input.xps";
// Вихідний файл 
System::String outputFileName =  u"XPStoImage_out.png";
// Ініціалізація вхідного потоку XPS
{
	System::SharedPtr<System::IO::Stream> xpsStream = System::IO::File::Open(inputFileName, System::IO::FileMode::Open, System::IO::FileAccess::Read);
	// Очищення ресурсів під оператором «використання».
	System::Details::DisposeGuard<1> __dispose_guard_1({ xpsStream });
	try
	{
		// Завантажте документ XPS із потоку
		System::SharedPtr<XpsDocument> document = System::MakeObject<XpsDocument>(xpsStream, System::MakeObject<XpsLoadOptions>());
		// або завантажити документ XPS безпосередньо з файлу. Тоді xpsStream не потрібен.
		// XpsDocument document = new XpsDocument(inputFileName, new XpsLoadOptions());

		// Ініціалізація об'єкта опцій необхідними параметрами.
		System::SharedPtr<PngSaveOptions> options = [&] { auto tmp_0 = System::MakeObject<PngSaveOptions>(); tmp_0->set_SmoothingMode(System::Drawing::Drawing2D::SmoothingMode::HighQuality); tmp_0->set_Resolution(300); tmp_0->set_PageNumbers(System::MakeArray<int32_t>({ 1, 2, 6 })); return tmp_0; }();

		// Створіть пристрій візуалізації для формату PDF
		System::SharedPtr<ImageDevice> device = System::MakeObject<ImageDevice>();

		document->Save(device, options);

		// Перегляд розділів документів (фіксовані документи, у термінах XPS)
		for (int32_t i = 0; i < device->get_Result()->get_Length(); i++)
		{
			for (int32_t j = 0; j < device->get_Result()[i]->get_Length(); j++)
			{
				// Ініціалізувати вихідний потік зображення
				{
					System::SharedPtr<System::IO::Stream> imageStream = System::IO::File::Open(System::IO::Path::GetDirectoryName(outputFileName) + u"\\" + System::IO::Path::GetFileNameWithoutExtension(outputFileName) + u"_" + (i + 1) + u"_" + (j + 1) + System::IO::Path::GetExtension(outputFileName), System::IO::FileMode::Create, System::IO::FileAccess::Write);
					// Очищення ресурсів під оператором «використання».
					System::Details::DisposeGuard<1> __dispose_guard_0({ imageStream });
					try
					{
						imageStream->Write(device->get_Result()[i][j], 0, device->get_Result()[i][j]->get_Length());
					}
					catch (...)
					{
						__dispose_guard_0.SetCurrentException(std::current_exception());
					}
				}
			}
		}
	}
	catch (...)
	{
		__dispose_guard_1.SetCurrentException(std::current_exception());
	}
}

Щоб конвертувати документ XPS у формати BMP, TIFF і JPEG, перегляньте цю статтю.

Дізнайтеся більше про Aspose.Page for C++

У цій статті ви побачили, як конвертувати документи PS, EPS і XPS у PDF, PNG, JPEG, TIFF і BMP за допомогою C++. Ви можете дізнатися більше про Aspose.Page for C++, використовуючи документацію і приклади вихідного коду.

Дивись також