动态地将字体大小设置为uwp中的richtexblock

时间:2016-08-09 08:15:15

标签: c# uwp

我有以下代码:

<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#end中的以下代码:

 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);

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

请帮帮我。 感谢。

1 个答案:

答案 0 :(得分:0)

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

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

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

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

请记住,当您的媒体资源价值发生变化时,请使用'INotifyPropertyChanged'通知用户界面。此web site提供了有关实施'INotifyPropertyChanged'

的指南