2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【XAML】1つのTextBlockで複数の書式(部分的にFontSize・FontWeightを異なるText)をいれる

Posted at

背景

1つのTextBlockのなかに"xxx yyy zzz"という文字列を入れて、"yyy"だけFontSizeを大きくするとか、"zzz"だけBoldするという場合の方法を調べたので、まとめておきます。

複数のTextBlockを並べる場合

StackPanelを使ってTextBloclを複数並べて、実現してみます。

<StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Bottom" Margin="5">
    <StackPanel.Resources>
        <Style TargetType="TextBlock">
            <Setter Property="VerticalAlignment" Value="Bottom"/>
        </Style>
    </StackPanel.Resources>
    <TextBlock>デフォルトのサイズ1</TextBlock>
    <TextBlock>デフォルトのサイズ2</TextBlock>
    <TextBlock FontSize="40">大きいサイズ</TextBlock>
    <TextBlock FontWeight="Bold">太字</TextBlock>
    <TextBlock FontSize="10">小さいサイズ</TextBlock>
</StackPanel>

image.png
それっぽくできていますが、フォントサイズが異なっているので、余白が異なり(?)、下端がそろっていないように見えます。

TextBlockのInlinesプロパティを使用する場合

TextBlockにはInlinesプロパティというものがあり、そこに複数の書式の文字列を入れることができます。
InlinesプロパティはInlieクラスのコレクション型のようで、Inlineクラスを継承したRunクラスを格納でき、このRunクラスにそれぞれフォーマットを指定していきます。

Inlinesプロパティは読み取り専用(getterのみ)で、DependencyPropertyでもないので、直接バインドすることはできないようです。

XAMLでの記述

XAMLで記述する場合はTextBlockのTextに<Run>Text</Run>を追加していけばよいです。
ハイパーリンクなどもこれで実現できるようです。

<TextBlock HorizontalAlignment="Center" VerticalAlignment="Top" Margin="5">
    <Run>デフォルトのサイズ1</Run>
    <Run>デフォルトのサイズ2</Run>
    <Run FontSize="40">大きいサイズ</Run>
    <Run FontWeight="Bold">太字</Run>
    <Run FontSize="10">小さいサイズ</Run>
</TextBlock>

image.png
しっかり下端がそろっているように見えます。
RunとRunの間にスペースが少し入るようです。(WinUI3)

コードビハインドでの記述

Inlinesプロパティをコードビハインドから操作する方法です。
XAML上でTextBlockコントロールに名前を付けて、コードビハインドから操作します。

<TextBlock x:Name="myTexxtBlock" HorizontalAlignment="Center" VerticalAlignment="Top" Margin="5"/>
コードビハインド
myTexxtBlock.Inlines.Clear();
var default1 = new Run() { Text = "デフォルトのサイズ2" };
var default2 = new Run() { Text = "デフォルトのサイズ2" };
var large = new Run() { Text = "大きいサイズ", FontSize = 40 };
var bold = new Run() { Text = "太字", FontWeight = FontWeights.Bold };
var small = new Run() { Text = "小さいサイズ", FontSize = 10 };
myTexxtBlock.Inlines.Add(default1);
myTexxtBlock.Inlines.Add(default2);
myTexxtBlock.Inlines.Add(large);
myTexxtBlock.Inlines.Add(bold);
myTexxtBlock.Inlines.Add(small);

image.png
下端もそろっていますし、スペースも入りませんでした。

まとめ

1つのTextBlockで複数の書式を入れるにはTextBlockのInlinesを使うのがよさそうです。
Inlinesを使用すると、最終的には1つのTextに結合されるようなので、ナレーター対応とかも考える必要がなさそうです。

今回作成したコードのリポジトリを置いておきます。WinUI3で作成しています。
Unpackagedをスタートアップにして実行すると動作すると思います。

参考

2
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?