Hogyan formázzuk a szöveget a .NET
Aspose.Slides FOSS for .NET provides fine-grained text formatting through the PortionFormat class. A Portion a legkisebb önálló szövegegység; egyetlen formázási futamra térképezhető egy bekezdésen belül. Ez az útmutató bemutatja, hogyan lehet félkövér, dőlt, betűméret és szín formázást alkalmazni a szövegre egy prezentációban.
Lépésről-lépésre útmutató
1. lépés: A csomag telepítése
dotnet add package Aspose.Slides.Foss2. lépés: Adjunk hozzá egy alakzatot szövegkerettel
A szöveg formázása előtt egy alakzatnak tartalmaznia kell egy TextFrame. Használja shape.AddTextFrame() egy létrehozásához.
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. lépés: A TextFrame elérése
shape.AddTextFrame() visszaadja a TextFrame objektumot. Később is lekérhető a shape.TextFrame.
var tf = shape.TextFrame; // if the frame already exists
var tf = shape.AddTextFrame(""); // creates a new frameA TextFrame tartalmaz egy listát Paragraph objektumok (tf.Paragraphs). Minden Paragraph tartalmaz Portion objektumok (paragraph.Portions).
4. lépés: Félkövér és dőlt formázás alkalmazása
Használja PortionFormat.FontBold és PortionFormat.FontItalic. Ezek a tulajdonságok elfogadják NullableBool.True, NullableBool.False, vagy NullableBool.NotDefined (öröklődik a masterből).
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. lépés: Betűméret és szín beállítása
Állítsa be PortionFormat.FontHeight a mérethez (pontban) és használja FillFormat színhez.
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) elfogad 0-255 értékeket minden csatornára.
6. lépés: Több rész egy bekezdésben
Egy bekezdés több részt is tartalmazhat különböző formázással. Adj hozzá egy új Portion a bekezdés Portions gyűjteményéhez:
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);Gyakori problémák és megoldások
A szöveg fekete marad a szín beállítása után is
Biztosítsa FillFormat.FillType = FillType.Solid be van állítva a szín hozzárendelése előtt. A kitöltéstípus beállítása nélkül a színváltozás hatástalan lehet.
NullableBool.True vs true
PortionFormat.FontBold elvárja NullableBool.True, nem a C# true. A C# hozzárendelése true nem fog lefordulni, mert a típusok nem kompatibilisek.
A betűtípus nem jelenik meg a mentett fájlban
A LatinFont A tulajdonság beállítja a latin betűcsaládot. Ha nincs beállítva, a bemutató téma betűtípusa lesz használva. Az egyedi betűtípusokat be kell ágyazni, vagy elérhetőnek kell lenniük a megtekintő gépen.
Gyakran Ismételt Kérdések
Hogyan változtathatom meg a betűtípuscsaládot?
Állítsa be PortionFormat.LatinFont:
fmt.LatinFont = new FontData("Arial");FontData elfogadja a betűcsalád nevét karakterláncként.
Hogyan állítható be a bekezdés igazítása?
Használja ParagraphFormat.Alignment:
tf.Paragraphs[0].ParagraphFormat.Alignment = TextAlignment.Center;Támogatott értékek: Left, Center, Right, Justify.
Hogyan állítható be a sorköz?
Használja ParagraphFormat.SpaceBefore (pontok a bekezdés előtt) vagy ParagraphFormat.SpaceAfter (pontok a bekezdés után):
tf.Paragraphs[0].ParagraphFormat.SpaceBefore = 12; // 12pt before
tf.Paragraphs[0].ParagraphFormat.SpaceAfter = 6; // 6pt after