在uwp中动态设置字体大小为richtexblock

本文关键字:小为 richtexblock 字体 设置 uwp 动态 | 更新日期: 2023-09-27 18:01:30

我有以下代码:

<ScrollViewer x:Name="swipeBetweenPages" Grid.Row="1">
    <Pivot DataContext="{StaticResource ViewModel}" x:Name="pivot" Margin="0,-45,0,0" 
                     HeaderTemplate="{StaticResource headerTest}" 
           ItemTemplate="{StaticResource pivotTemplate}" ItemsSource="{Binding Articles}" SelectionChanged="pivot_SelectionChanged">
    </Pivot>
</ScrollViewer>
<Page.Resources>
    <ViewModels:ArticleViewModel x:Key="ViewModel" />
    <DataTemplate x:Key="headerTest">
    </DataTemplate>
    <DataTemplate x:Key="pivotTemplate">
        <StackPanel Margin="-15 0 -15 0">
            <Grid>
                <Grid.Background>
                    <ImageBrush AlignmentX="Center" AlignmentY="Center" ImageSource="Assets/PlaceHolder.jpg"></ImageBrush>
                </Grid.Background>
                <Image q42controls:ImageExtensions.CacheUri="{Binding ImageURL}" Tag="{Binding ImageURL}" Tapped="ImageView"></Image>
            </Grid>
            <StackPanel Background="White">
                <TextBlock x:Name="HeadLine" Text="{Binding HeadLine}"  
                                           Margin="10 5 0 -5" TextWrapping="Wrap" 
                                           FontSize="20" Foreground="Black"
                                           FontFamily="{StaticResource HeadlineCommonFamiy}"
                                           Pivot.SlideInAnimationGroup="GroupTwo" Height="63"
                                           FontWeight="Bold" TextTrimming="CharacterEllipsis"/>
                <TextBlock Text="{Binding Abstract}" TextWrapping="Wrap" FontSize="15" FontStyle="Italic"
                               Pivot.SlideInAnimationGroup="GroupTwo" Margin="10 5 0 10"
                                       FontFamily="{StaticResource AbstractCommonFamily}"/>                   
            </StackPanel>
            <StackPanel x:Name="descriptionSP" Background="White">
            <RichTextBlock IsTextSelectionEnabled="False" x:Name="richTextBlock" 
                           local:Properties.Html="{Binding ArticleDetail}" TextWrapping="Wrap"
                           Pivot.SlideInAnimationGroup="GroupTwo" Margin="10 5 0 10"
                                   FontFamily="{StaticResource ContentControlThemeFontFamily}">
            </RichTextBlock>
        </StackPanel>
        </StackPanel>
    </DataTemplate>
</Page.Resources>

我正在尝试动态地设置后端富文本块的字体大小。

现在,我正在尝试使用c#结尾的以下代码:

 private T FindElementInVisualTree<T>(DependencyObject parentElement) where T : DependencyObject
{
    var count = VisualTreeHelper.GetChildrenCount(parentElement);
    if (count == 0) return null;
    for (int i = 0; i < count; i++)
    {
        var child = VisualTreeHelper.GetChild(parentElement, i);
        if (child != null && child is T)
            return (T)child;
        else
        {
            var result = FindElementInVisualTree<T>(child);
            if (result != null)
                return result;
        }
    }
    return null;
}        
RichTextBlock richTextBlock = new RichTextBlock();
StackPanel rootStackPanel = new StackPanel();
StackPanel childStackPanel = new StackPanel();
PivotItem item = (sender as Pivot).ContainerFromItem((sender as Pivot).SelectedItem) as PivotItem;
rootStackPanel = item.ContentTemplate.LoadContent() as StackPanel;
childStackPanel = rootStackPanel.FindName("descriptionSP") as StackPanel;
richTextBlock = rootStackPanel.FindName("richTextBlock") as RichTextBlock;
Paragraph paragraph = new Paragraph();
Run run = new Run();
// Customize some properties on the RichTextBlock.
richTextBlock.IsTextSelectionEnabled = true;
richTextBlock.SelectionHighlightColor = new SolidColorBrush(Windows.UI.Colors.Pink);
richTextBlock.Foreground = new SolidColorBrush(Windows.UI.Colors.Blue);
richTextBlock.FontWeight = Windows.UI.Text.FontWeights.Light;
richTextBlock.FontFamily = new FontFamily("Arial");
richTextBlock.FontStyle = Windows.UI.Text.FontStyle.Italic;
richTextBlock.FontSize = 50;
//run.Text = "This is some sample text to demonstrate some properties.";          
paragraph.Inlines.Add(run);
richTextBlock.Blocks.Add(paragraph);
// Add the RichTextBlock to the visual tree (assumes stackPanel is decalred in XAML).
//childStackPanel.Children.Add(richTextBlock);
//rootStackPanel.Children.Add(richTextBlock);

但是,它不影响字体大小。

请帮帮我。谢谢。

在uwp中动态设置字体大小为richtexblock

您可以在ViewModel或代码文件中创建一个属性,并使用数据绑定将其连接到FontSize属性。

private double _myFontSize;    
public double MyFontSize
{
   get{ return _myFontSize;  }
   set{ _myFontSize = value; }
}

现在在富文本框字体大小的数据模板中,

FontSize="{Binding MyFontSize, ElementName=page/viewModel}"

并记住使用'INotifyPropertyChanged'通知UI时,您的属性值的变化。本网站提供实施'INotifyPropertyChanged'的指引