วิธีจัดรูปแบบข้อความใน 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 frameA 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