PostScript XPS에서 PDF 및 이미지 C++로

이전 게시물에서 Aspose.Page for C++를 사용하여 프로그래밍 방식으로 PostScript(PS/EPS) 및 XPS 문서를 생성하거나 편집하는 것이 얼마나 쉬운지 보여주었습니다. 이 기사에서는 C++를 사용하여 PS/EPS 또는 XPS 문서를 PNG, JPEG, TIFF 및 BMP를 포함한 PDF 또는 래스터 이미지 형식으로 변환하는 방법을 설명합니다. 기사의 나머지 부분은 다음 섹션으로 구성됩니다.

시작하기 전에 C++용 Aspose.Page를 다운로드하고 C++ 프로젝트에서 참조했다고 가정합니다. 그러나 아직 설치하지 않은 경우 NuGet에서 설치하거나 다운로드 섹션에서 플러그 앤 플레이 콘솔 애플리케이션과 함께 전체 패키지를 다운로드할 수 있습니다.

C++에서 PostScript PS/EPS를 PDF로 변환

다음은 PostScript PS/EPS 문서를 PDF로 변환하는 단계입니다.

  • 출력 PDF 파일에 대한 FileStream 개체를 만듭니다.
  • FileStream 객체에 입력 PostScript 문서를 로드합니다.
  • 입력 스트림으로 PsDocument 개체를 만들고 초기화합니다.
  • 출력 스트림으로 PdfDevice 개체를 만들고 초기화합니다.
  • PsDocument->Save 방식으로 문서를 가공하여 PDF 파일로 저장합니다.

다음 코드 샘플은 C++에서 PostScript PS 문서를 PDF로 변환하는 방법을 보여줍니다.

// 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);
// 글꼴이 저장되는 특수 폴더를 추가하려는 경우. OS의 기본 글꼴 폴더는 항상 포함됩니다.
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 장치 = new Aspose.Page.EPS.Device.PdfDevice(pdfStream, new 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 = (시스템::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());
	}
}

C++에서 PostScript PS/EPS를 이미지로 변환

다음은 PS/EPS를 이미지 형식으로 변환하는 단계입니다.

  • ImageFormat의 개체를 만들어 출력 이미지의 형식(예: PNG)을 설정합니다.
  • FileStream 객체에 입력 PostScript 문서를 로드합니다.
  • 입력 스트림으로 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);

// 글꼴이 저장되는 특수 폴더를 추가하려는 경우. OS의 기본 글꼴 폴더는 항상 포함됩니다.
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 장치 = 새로운 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);
			// 'using' 문에서 리소스 지우기
			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 = (시스템::DynamicCastEnumerableTo<PsConverterException> (옵션->get_Exceptions()))->GetEnumerator();
	//decltype(ex_enumerator->get_Current()) 예;
	//동안 (ex_enumerator->MoveNext() && (ex = ex_enumerator->get_Current(), true))
	//{
	//	시스템::콘솔::WriteLine(ex->get_Message());
	//}
}

C++에서 XPS를 PDF로 변환

다음은 XPS 문서를 PDF로 변환하는 단계입니다.

  • 입력 XPS 및 출력 PDF 파일에 대한 FileStream 개체를 만듭니다.
  • XPS 문서 스트림을 XpsDocument 개체로 로드합니다.
  • PdfDevice 클래스의 개체를 만들고 출력 스트림으로 초기화합니다.
  • XpsDocument->Save 방법을 사용하여 XPS 문서를 PDF로 변환합니다.

다음 코드 샘플은 C++에서 XPS 문서를 PDF로 변환하는 방법을 보여줍니다.

System::SharedPtr<System::IO::Stream> pdfStream = System::IO::File::Open(u"XPStoPDF.pdf", System::IO::FileMode::Create, System::IO::FileAccess::Write);
// 'using' 문에서 리소스 지우기
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);
	// 'using' 문에서 리소스 지우기
	System::Details::DisposeGuard<1> __dispose_guard_0({ xpsStream });
	try
	{
		// 스트림에서 XPS 문서 로드
		System::SharedPtr<XpsDocument> document = System::MakeObject<XpsDocument>(xpsStream, System::MakeObject<XpsLoadOptions>());
		// 또는 파일에서 직접 XPS 문서를 로드합니다. 그러면 xpsStream이 필요하지 않습니다.
		// XpsDocument 문서 = 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());
}

C++에서 XPS를 이미지로 변환

다음은 XPS 문서를 래스터 이미지 형식으로 변환하는 단계입니다.

  • 입력 XPS 문서를 FileStream 개체에 로드합니다.
  • XpsDocument의 개체를 만들고 입력 스트림 개체로 초기화합니다.
  • PngSaveOptions 클래스의 객체를 생성하여 저장 옵션을 설정합니다.
  • XpsDocument->Save 방법을 사용하여 XPS를 이미지로 변환합니다.

다음 코드 샘플은 C++에서 XPS를 PNG 이미지로 변환하는 방법을 보여줍니다.

// 입력 파일
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);
	// 'using' 문에서 리소스 지우기
	System::Details::DisposeGuard<1> __dispose_guard_1({ xpsStream });
	try
	{
		// 스트림에서 XPS 문서 로드
		System::SharedPtr<XpsDocument> document = System::MakeObject<XpsDocument>(xpsStream, System::MakeObject<XpsLoadOptions>());
		// 또는 파일에서 직접 XPS 문서를 로드합니다. 그러면 xpsStream이 필요하지 않습니다.
		// XpsDocument 문서 = 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);
					// 'using' 문에서 리소스 지우기
					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로 변환하려면 다음 문서를 참조하십시오.

C++용 Aspose.Page에 대해 자세히 알아보기

이 기사에서는 C++를 사용하여 PS, EPS 및 XPS 문서를 PDF, PNG, JPEG, TIFF 및 BMP로 변환하는 방법을 살펴보았습니다. 문서소스 코드 예제를 사용하여 Aspose.Page for C++에 대해 자세히 알아볼 수 있습니다.

또한보십시오