Como formatar texto em Java

Como formatar texto em Java

O Aspose.Slides FOSS for Java fornece formatação de texto de granularidade fina por meio da classe PortionFormat. Um Portion é a menor unidade independente de texto; ele corresponde a uma única execução de formatação dentro de um parágrafo. Este guia mostra como aplicar formatação em negrito, itálico, tamanho de fonte e cor ao texto em uma apresentação.

Guia passo a passo

Etapa 1: Adicionar a dependência Maven

<dependency>
  <groupId>org.aspose.slides.foss</groupId>
  <artifactId>aspose-slides-foss</artifactId>
  <version>1.0.0</version>
</dependency>

Etapa 2: Adicionar uma Forma com um Quadro de Texto

Antes de formatar o texto, uma forma deve conter um TextFrame. Use shape.addTextFrame() para criar um.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IParagraph;
import org.aspose.slides.foss.IPortion;
import org.aspose.slides.foss.Portion;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 500, 150
    );
    ITextFrame tf = shape.addTextFrame("Default text: will be formatted");
    prs.save("output.pptx", SaveFormat.PPTX);
}

Etapa 3: Acessar o TextFrame

shape.addTextFrame() retorna o objeto TextFrame. Você também pode recuperá‑lo mais tarde via shape.getTextFrame().

ITextFrame tf = shape.getTextFrame();          // if the frame already exists
ITextFrame tf = shape.addTextFrame("");        // creates a new frame

Um TextFrame contém uma lista de objetos Paragraph (tf.getParagraphs()). Cada Paragraph contém objetos Portion (paragraph.getPortions()).


Etapa 4: Aplicar Formatação em Negrito e Itálico

Use portionFormat.setFontBold() e portionFormat.setFontItalic(). Esses métodos aceitam NullableBool.TRUE, NullableBool.FALSE ou NullableBool.NOT_DEFINED (herdado do master).

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IParagraph;
import org.aspose.slides.foss.IPortion;
import org.aspose.slides.foss.Portion;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 500, 150
    );
    ITextFrame tf = shape.addTextFrame("Bold and italic text");

    IPortionFormat fmt = tf.getParagraphs().get(0)
        .getPortions().get(0).getPortionFormat();
    fmt.setFontBold(NullableBool.TRUE);
    fmt.setFontItalic(NullableBool.TRUE);

    prs.save("bold-italic.pptx", SaveFormat.PPTX);
}

Etapa 5: Definir Tamanho da Fonte e Cor

Defina portionFormat.setFontHeight() para tamanho (em pontos) e use getFillFormat() para cor.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IParagraph;
import org.aspose.slides.foss.IPortion;
import org.aspose.slides.foss.Portion;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 500, 150
    );
    ITextFrame tf = shape.addTextFrame("Large corporate-blue heading");

    IPortionFormat fmt = tf.getParagraphs().get(0)
        .getPortions().get(0).getPortionFormat();
    fmt.setFontHeight(32);                          // 32pt font
    fmt.setFontBold(NullableBool.TRUE);
    fmt.getFillFormat().setFillType(FillType.SOLID);
    fmt.getFillFormat().getSolidFillColor().setColor(
        Color.fromArgb(255, 0, 70, 127)
    );

    prs.save("colored-text.pptx", SaveFormat.PPTX);
}

Color.fromArgb(alpha, red, green, blue) aceita valores de 0 a 255 para cada canal.


Etapa 6: Várias Partes em Um Parágrafo

Um único parágrafo pode conter várias porções com formatação diferente. Adicione um novo Portion à coleção getPortions() de um parágrafo:

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IParagraph;
import org.aspose.slides.foss.IPortion;
import org.aspose.slides.foss.Portion;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 600, 100
    );
    ITextFrame tf = shape.addTextFrame("");  // start with empty frame

    IParagraph paragraph = tf.getParagraphs().get(0);

    // First portion: normal text
    IPortion portion1 = paragraph.getPortions().get(0);
    portion1.setText("Normal text followed by ");
    portion1.getPortionFormat().setFontHeight(20);

    // Second portion: bold red text
    Portion portion2 = new Portion("bold red text");
    portion2.getPortionFormat().setFontHeight(20);
    portion2.getPortionFormat().setFontBold(NullableBool.TRUE);
    portion2.getPortionFormat().getFillFormat().setFillType(FillType.SOLID);
    portion2.getPortionFormat().getFillFormat().getSolidFillColor().setColor(
        Color.fromArgb(255, 200, 0, 0)
    );
    paragraph.getPortions().add(portion2);

    prs.save("mixed-format.pptx", SaveFormat.PPTX);
}

Problemas Comuns e Soluções

O texto aparece preto mesmo após definir a cor

Certifique‑se de que getFillFormat().setFillType(FillType.SOLID) seja chamado antes de atribuir a cor. Sem definir o tipo de preenchimento, a mudança de cor pode não ter efeito.

NullableBool.TRUE vs true

portionFormat.setFontBold() espera NullableBool.TRUE, não o true do Java. Passar um boolean causará um erro de compilação, pois o método espera o enum NullableBool.

Fonte não aparece no arquivo salvo

O método setLatinFont() define a família de fontes latinas. Se não for definido, a fonte do tema da apresentação será usada. Fontes personalizadas devem ser incorporadas ou estar disponíveis na máquina de visualização.


Perguntas Frequentes

Como altero a família de fontes?

Definir portionFormat.setLatinFont():

fmt.setLatinFont(new FontData("Arial"));

FontData aceita o nome da família de fontes como uma string.

Como definir o alinhamento de parágrafo?

Use paragraphFormat.setAlignment():

import org.aspose.slides.foss.TextAlignment;

tf.getParagraphs().get(0).getParagraphFormat()
    .setAlignment(TextAlignment.CENTER);

Valores suportados: LEFT, CENTER, RIGHT, JUSTIFY.

Como definir o espaçamento entre linhas?

Use paragraphFormat.setSpaceBefore() (pontos antes do parágrafo) ou paragraphFormat.setSpaceAfter() (pontos depois do parágrafo):

tf.getParagraphs().get(0).getParagraphFormat().setSpaceBefore(12);  // 12pt before
tf.getParagraphs().get(0).getParagraphFormat().setSpaceAfter(6);    // 6pt after

Veja também

 Português