Πώς να μορφοποιήσετε κείμενο στο .NET

Πώς να μορφοποιήσετε κείμενο στο .NET

Aspose.Slides FOSS for .NET provides fine-grained text formatting through the PortionFormat class. A Portion είναι η μικρότερη ανεξάρτητη μονάδα κειμένου· αντιστοιχεί σε μια μοναδική εκτέλεση μορφοποίησης μέσα σε μια παράγραφο. Αυτός ο οδηγός δείχνει πώς να εφαρμόσετε έντονη, πλάγια, μέγεθος γραμματοσειράς και χρωματική μορφοποίηση στο κείμενο σε μια παρουσίαση.

Οδηγός βήμα προς βήμα

Βήμα 1: Εγκατάσταση του πακέτου

dotnet add package Aspose.Slides.Foss

Βήμα 2: Προσθήκη σχήματος με πλαίσιο κειμένου

Πριν μορφοποιήσετε το κείμενο, ένα σχήμα πρέπει να περιέχει ένα TextFrame. Χρησιμοποιήστε shape.AddTextFrame() για να δημιουργήσετε ένα.

using Aspose.Slides.Foss;
using Aspose.Slides.Foss.Export;

using var prs = new Presentation();
var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 500, 150);
var tf = shape.AddTextFrame("Default text: will be formatted");
prs.Save("output.pptx", SaveFormat.Pptx);

Βήμα 3: Πρόσβαση στο TextFrame

shape.AddTextFrame() επιστρέφει το TextFrame object. Μπορείτε επίσης να το ανακτήσετε αργότερα μέσω shape.TextFrame.

var tf = shape.TextFrame;          // if the frame already exists
var tf = shape.AddTextFrame("");   // creates a new frame

A TextFrame περιέχει μια λίστα με Paragraph αντικείμενα (tf.Paragraphs). Κάθε Paragraph περιέχει Portion αντικείμενα (paragraph.Portions).


Βήμα 4: Εφαρμογή έντονης και πλάγιας μορφοποίησης

Χρησιμοποιήστε PortionFormat.FontBold και PortionFormat.FontItalic. Αυτές οι ιδιότητες δέχονται NullableBool.True, NullableBool.False, ή NullableBool.NotDefined (κληρονομεί από το master).

using Aspose.Slides.Foss;
using Aspose.Slides.Foss.Export;

using var prs = new Presentation();
var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 500, 150);
var tf = shape.AddTextFrame("Bold and italic text");

var fmt = tf.Paragraphs[0].Portions[0].PortionFormat;
fmt.FontBold = NullableBool.True;
fmt.FontItalic = NullableBool.True;

prs.Save("bold-italic.pptx", SaveFormat.Pptx);

Βήμα 5: Ορισμός μεγέθους γραμματοσειράς και χρώματος

Ορισμός PortionFormat.FontHeight για μέγεθος (σε σημεία) και χρήση FillFormat για χρώμα.

using Aspose.Slides.Foss;
using Aspose.Slides.Foss.Drawing;
using Aspose.Slides.Foss.Export;

using var prs = new Presentation();
var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 500, 150);
var tf = shape.AddTextFrame("Large corporate-blue heading");

var fmt = tf.Paragraphs[0].Portions[0].PortionFormat;
fmt.FontHeight = 32;                          // 32pt font
fmt.FontBold = NullableBool.True;
fmt.FillFormat.FillType = FillType.Solid;
fmt.FillFormat.SolidFillColor.Color = Color.FromArgb(255, 0, 70, 127);

prs.Save("colored-text.pptx", SaveFormat.Pptx);

Color.FromArgb(alpha, red, green, blue) δέχεται τιμές 0-255 για κάθε κανάλι.


Βήμα 6: Πολλαπλά τμήματα σε μία παράγραφο

Μια μόνο παράγραφος μπορεί να περιέχει πολλαπλά τμήματα με διαφορετική μορφοποίηση. Προσθέστε ένα νέο Portion σε μια παράγραφο Portions συλλογή:

using Aspose.Slides.Foss;
using Aspose.Slides.Foss.Drawing;
using Aspose.Slides.Foss.Export;

using var prs = new Presentation();
var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 600, 100);
var tf = shape.AddTextFrame("");  // start with empty frame

var paragraph = tf.Paragraphs[0];

// First portion: normal text
var portion1 = paragraph.Portions[0];
portion1.Text = "Normal text followed by ";
portion1.PortionFormat.FontHeight = 20;

// Second portion: bold red text
var portion2 = new Portion();
portion2.Text = "bold red text";
portion2.PortionFormat.FontHeight = 20;
portion2.PortionFormat.FontBold = NullableBool.True;
portion2.PortionFormat.FillFormat.FillType = FillType.Solid;
portion2.PortionFormat.FillFormat.SolidFillColor.Color = Color.FromArgb(255, 200, 0, 0);
paragraph.Portions.Add(portion2);

prs.Save("mixed-format.pptx", SaveFormat.Pptx);

Κοινά προβλήματα και διορθώσεις

Το κείμενο εμφανίζεται μαύρο ακόμη και μετά τον ορισμό του χρώματος

Βεβαιωθείτε FillFormat.FillType = FillType.Solid είναι ορισμένο πριν την ανάθεση του χρώματος. Χωρίς ορισμό του τύπου γεμίσματος, η αλλαγή χρώματος μπορεί να μην έχει αποτέλεσμα.

NullableBool.True εναντίον true

PortionFormat.FontBold αναμένει NullableBool.True, όχι το C# true. Η ανάθεση του C# true δεν θα μεταγλωττιστεί επειδή οι τύποι είναι ασύμβατοι.

Η γραμματοσειρά δεν εμφανίζεται στο αποθηκευμένο αρχείο

Το LatinFont η ιδιότητα ορίζει την οικογένεια γραμματοσειρών Latin. Εάν δεν οριστεί, χρησιμοποιείται η γραμματοσειρά του θέματος παρουσίασης. Οι προσαρμοσμένες γραμματοσειρές πρέπει να ενσωματωθούν ή να είναι διαθέσιμες στο μηχάνημα προβολής.


Συχνές Ερωτήσεις

Πώς μπορώ να αλλάξω την οικογένεια γραμματοσειρών;?

Ορίστε PortionFormat.LatinFont:

fmt.LatinFont = new FontData("Arial");

FontData δέχεται το όνομα της οικογένειας γραμματοσειρών ως συμβολοσειρά.

Πώς μπορώ να ορίσω την στοίχιση παραγράφου;?

Χρήση ParagraphFormat.Alignment:

tf.Paragraphs[0].ParagraphFormat.Alignment = TextAlignment.Center;

Υποστηριζόμενες τιμές: Left, Center, Right, Justify.

Πώς μπορώ να ορίσω το διάστημα γραμμών;?

Χρήση ParagraphFormat.SpaceBefore (σημεία πριν από την παράγραφο) ή ParagraphFormat.SpaceAfter (σημεία μετά την παράγραφο):

tf.Paragraphs[0].ParagraphFormat.SpaceBefore = 12;   // 12pt before
tf.Paragraphs[0].ParagraphFormat.SpaceAfter = 6;     // 6pt after

Δείτε επίσης

 Ελληνικά