我有一些文本在运行时显示在文本块中。我希望字体大小尽可能大,以填充给定的区域。我想我的文本块设置正确为“自动调整大小”,我尝试增加字体大小,直到文本块大于其父级,然后将字体大小减小 1。问题是我无法让控件重绘/重新计算它的大小。
有更好的方法吗?或者有什么方法可以让我的方法奏效吗?
TextBlock
将内部包裹起来ViewBox
:
<Grid>
<Viewbox>
<TextBlock TextWrapping="Wrap" Text="Some Text" />
</Viewbox>
</Grid>
我有同样的问题。您可以使用它来调整文本块的字体大小以在溢出时填充该区域。
<Viewbox StretchDirection="DownOnly" Stretch="Uniform">
<TextBlock Text="{Binding Path=Title}" HorizontalAlignment="Center"/>
</Viewbox>
WPFViewBox
控件可以随其内容增长/缩小到可用空间。
只需将您的TextBlock
放在一个ViewBox
as 中;
<Viewbox Stretch="Uniform" Width="50" Height="50">
<TextBlock Text="Test" />
</Viewbox>
ViewBox
通常由其容器缩放。
我找到了一个很好的方法来做到这一点ViewBox
:
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="Auto" />
<RowDefinition Height="*" />
<RowDefinition Height="50" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="100" />
</Grid.ColumnDefinitions>
<Viewbox Grid.Row="0" Grid.Column="0" Stretch="Uniform">
<TextBlock Name="tbTest" Background="Yellow" Text="This is some text" />
</Viewbox>
<ContentControl Grid.Column="0" Grid.Row="2">
<TextBlock>This is some text</TextBlock>
</ContentControl>
</Grid>
好吧,这不是一个“完美”的答案,但这是一个快速破解(您可以将其放入 kaxaml 并进行测试):
<Page
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<Grid Height="300" Background="green">
<Viewbox>
<TextBlock Background="red" Text="Hurr"/>
</Viewbox>
</Grid>
</Page>
将ViewBox
放大任何内容以填充其容器。问题是TextBlock
,虽然它的大小与文本相符,但在顶部和底部都有您无法摆脱的填充(无需做一些繁重的工作)。这可能会让你更接近你想要的东西。
为了确保包装,您需要设置MaxWidth
和/MaxHeight
或TextBlock
<Viewbox StretchDirection="DownOnly" Stretch="Uniform">
<TextBlock MaxWidth="500" TextWrapping="Wrap" FontSize="30" VerticalAlignment="Center"
Text="Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."/>