.NET でテキストをフォーマットする方法
Aspose.Slides FOSS for .NET provides fine-grained text formatting through the PortionFormat クラス。A Portion テキストの最小の独立単位です。段落内の単一の書式ランにマッピングされます。このガイドでは、プレゼンテーションのテキストに太字、斜体、フォントサイズ、カラー書式を適用する方法を示します。.
ステップバイステップ ガイド
ステップ 1: パッケージをインストールする
dotnet add package Aspose.Slides.Fossステップ 2: テキストフレームを持つシェイプを追加する
テキストをフォーマットする前に、シェイプは a を含んでいる必要があります。 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 オブジェクトです。後で via を使用して取得することもできます。 shape.TextFrame.
var tf = shape.TextFrame; // if the frame already exists
var tf = shape.AddTextFrame(""); // creates a new frameA TextFrame はリストを含んでいます Paragraph オブジェクト (tf.Paragraphs). 各 Paragraph 含む Portion オブジェクト (paragraph.Portions).
ステップ 4: 太字と斜体の書式を適用する
使用 PortionFormat.FontBold と PortionFormat.FontItalic.。これらのプロパティは受け入れます NullableBool.True, NullableBool.False,、または NullableBool.NotDefined (マスターから継承)。.
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: 1 つの段落に複数のポーションを配置する
単一の段落は、異なる書式設定を持つ複数の部分を含むことができます。新しい 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 vs true
PortionFormat.FontBold 期待します NullableBool.True,、C#ではなく true.。C# を割り当てる true 型が互換性がないため、コンパイルできません。.
保存されたファイルにフォントが表示されません
その LatinFont property はラテンフォントファミリーを設定します。設定されていない場合、プレゼンテーションテーマのフォントが使用されます。カスタムフォントは埋め込むか、閲覧側のマシンにインストールされている必要があります。.
よくある質問
フォントファミリはどうやって変更しますか??
設定 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