Trabalhar com Imagens em PostScript | .NET

Adicionar Imagem em Documento PS

A biblioteca Aspose.Page para .NET oferece dois métodos para adicionar imagens a um documento PS:

Isto foi feito porque o PostScript não suporta transparência, mas as imagens translúcidas podem ser renderizadas como um conjunto de pixels totalmente transparentes e totalmente opacos. Estas imagens são chamadas de máscaras. Se quisermos ver a imagem translúcida no documento PS como máscara, que refletirá melhor a transparência da imagem, devemos realizar alguma verificação e pré-processamento dessa imagem.

A verificação e o pré-processamento demoram tempo. Portanto, se alguém tiver a certeza de que a imagem é totalmente opaca, é melhor utilizar o primeiro método, pois poupa tempo de execução.

O segundo método reconhece se a imagem é totalmente opaca, totalmente transparente ou translúcida. Se for totalmente opaca, será adicionada como a imagem opaca no primeiro método; se for totalmente transparente, não será adicionada ao documento; se for a imagem translúcida, será adicionada como uma máscara de imagem PostScript.

No exemplo abaixo, demonstramos como adicionar uma imagem totalmente opaca. A adição de uma imagem transparente será demonstrada no artigo “Trabalhar com Transparência”.

Para adicionar uma imagem a um novo PsDocument com a biblioteca Aspose.Page para .NET, neste exemplo, seguimos os seguintes passos:

  1. Crie um fluxo de saída para o ficheiro PS resultante.
  2. Crie o objeto PsSaveOptions com as opções padrão.
  3. Crie um PsDocument de 1 página com um fluxo de saída já criado e guarde as opções.
  4. Crie um novo estado gráfico.
  5. Crie System.Drawing.Bitmap a partir do ficheiro de imagem.
  6. Crie a transformação necessária para a imagem.
  7. Adicione a imagem ao objeto PsDocument.
  8. Saia do estado gráfico atual para o nível superior.
  9. Feche a página.
  10. Guarde o documento.
 1// Add image to PS document.
 2
 3string outputFileName = "AddImage_outPS.ps";
 4
 5//Create save options with A4 size
 6PsSaveOptions options = new PsSaveOptions();
 7
 8// Create new 1-paged PS Document
 9PsDocument document = new PsDocument(OutputDir + outputFileName, options, false);
10
11document.WriteGraphicsSave();
12document.Translate(100, 100);
13
14//Create a Bitmap object from image file
15using (Bitmap image = new Bitmap(DataDir + "TestImage Format24bppRgb.jpg"))
16{
17    //Create image transform
18    Matrix transform = new Matrix();
19    transform.Translate(35, 300);
20    transform.Scale(3, 3);
21    transform.Rotate(-45);
22
23    //Add image to document
24    document.DrawImage(image, transform, Color.Empty);
25}
26
27document.WriteGraphicsRestore();
28
29//Close current page
30document.ClosePage();
31
32//Save the document
33document.Save();
Example-AddImagePS.cs hosted with ❤ by GitHub

Para Linux, MacOS e outros sistemas operativos não Windows, oferecemos a utilização do nosso pacote NuGet Aspose.Page.Drawing. Utiliza o backend Aspose.Drawing em vez da biblioteca de sistema System.Drawing.

Assim, importe o namespace Aspose.Page.Drawing em vez do System.Drawing. No excerto de código acima, será utilizado o Aspose.Page.Drawing.Bitmap em vez do System.Drawing.Bitmap, Aspose.Page.Drawing.Drawing2D.Matrix será utilizado em vez de System.Drawing.Drawing2D.Matrix e assim por diante. Os nossos exemplos de código no GitHub contêm todas as substituições necessárias.

Veja como trabalhar com imagens em documentos PS em Java.

O resultado da execução deste código é apresentado como

Adicionar Imagem

Pode descarregar exemplos e ficheiros de dados do GitHub.

Have any questions about Aspose.Page?



Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.