วิธีจัดรูปแบบข้อความใน Java

วิธีจัดรูปแบบข้อความใน Java

Aspose.Slides FOSS for Java provides fine-grained text formatting through the PortionFormat class. A Portion เป็นหน่วยข้อความอิสระที่เล็กที่สุด; มันแมปไปยังการจัดรูปแบบเดียวภายในย่อหน้า คู่มือฉบับนี้แสดงวิธีการใช้การจัดรูปแบบ bold, italic, font size, และ color formatting กับข้อความในงานนำเสนอ.

คู่มือแบบขั้นตอนต่อขั้นตอน

ขั้นตอนที่ 1: เพิ่มการพึ่งพา Maven

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

ขั้นตอนที่ 2: เพิ่มรูปทรงพร้อมกรอบข้อความ

ก่อนทำการจัดรูปแบบข้อความ, shape ต้องมี a TextFrame. ใช้ shape.addTextFrame() เพื่อสร้างหนึ่ง.

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);
}

ขั้นตอนที่ 3: เข้าถึง TextFrame

shape.addTextFrame() คืนค่า TextFrame object. คุณยังสามารถดึงคืนได้ในภายหลังผ่าน shape.getTextFrame().

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

A TextFrame มีรายการของ Paragraph objects (tf.getParagraphs()). แต่ละ Paragraph มี Portion objects (paragraph.getPortions()).


ขั้นตอนที่ 4: ใช้การจัดรูปแบบตัวหนาและตัวเอียง

ใช้ portionFormat.setFontBold() และ portionFormat.setFontItalic(). วิธีการเหล่านี้รับ NullableBool.TRUE, NullableBool.FALSE, หรือ NullableBool.NOT_DEFINED (สืบทอดจาก 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);
}

ขั้นตอนที่ 5: ตั้งค่าขนาดฟอนต์และสี

ตั้งค่า portionFormat.setFontHeight() สำหรับขนาด (เป็นจุด) และใช้ getFillFormat() สำหรับสี.

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) รับค่าตั้งแต่ 0-255 สำหรับแต่ละช่อง.


ขั้นตอนที่ 6: หลาย Portion ในย่อหน้าเดียว

ย่อหน้าเดียวสามารถมีหลายส่วนที่มีการจัดรูปแบบต่างกันได้ เพิ่มใหม่ Portion ไปยังย่อหน้าของ getPortions() คอลเลกชัน:

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);
}

ปัญหาทั่วไปและวิธีแก้

ข้อความยังคงเป็นสีดำแม้ตั้งค่าสีแล้ว

ตรวจสอบให้แน่ใจ getFillFormat().setFillType(FillType.SOLID) จะต้องถูกเรียกก่อนกำหนดสี หากไม่ได้ตั้งค่าชนิดการเติม สีอาจไม่มีผล.

NullableBool.TRUE เทียบกับ true

portionFormat.setFontBold() คาดหวัง NullableBool.TRUE, ไม่ใช่ Java’s true. การส่งค่า boolean จะทำให้เกิดข้อผิดพลาดในการคอมไพล์เนื่องจากเมธอดคาดหวัง NullableBool enum.

แบบอักษรไม่ปรากฏในไฟล์ที่บันทึก

เมธอด setLatinFont() ตั้งค่าฟอนต์แบบละติน หากไม่ได้ตั้งค่า ฟอนต์ของธีมการนำเสนอจะถูกใช้ ฟอนต์ที่กำหนดเองต้องฝังไว้หรือมีอยู่บนเครื่องที่ดู.


คำถามที่พบบ่อย

ฉันจะเปลี่ยนครอบครัวแบบอักษรได้อย่างไร?

ตั้งค่า portionFormat.setLatinFont():

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

FontData รับชื่อฟอนต์เป็นสตริง.

ฉันจะตั้งค่าการจัดแนวย่อหน้าได้อย่างไร?

ใช้ paragraphFormat.setAlignment():

import org.aspose.slides.foss.TextAlignment;

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

ค่าที่รองรับ: LEFT, CENTER, RIGHT, JUSTIFY.

ฉันจะตั้งค่าระยะห่างบรรทัดได้อย่างไร?

ใช้ paragraphFormat.setSpaceBefore() (จุดก่อนย่อหน้า) หรือ paragraphFormat.setSpaceAfter() (จุดหลังย่อหน้า):

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

ดูเพิ่มเติม

 ภาษาไทย