如何覆盖自定义用户控件中的文本样式?

How to override the text style in a custom user control?

  1. 我有一个用户控件,它包含 一种。内容绑定到 UserLabel 的文本块 b.内容绑定到 UserValue.

    的文本框
  2. 当我将这个用户控件添加到Main Window时,我想在UserLabel中添加一个下标,但不知道该怎么做。

  3. 我想做这样的事情(以下代码不起作用。这是我想做的):

<Window 
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:local="clr-namespace:MyNamespace"
  Title="MyControl Sample" 
  Height="300" 
  Width="300">
  <StackPanel>
    <local:MyControl>
        <UserLabel.Text>
            Subscript<Run BaselineAlignment="Subscript" FontSize="12pt">This</Run> 
        <UserLabel.Text>
    <local:MyControl>
  </StackPanel>
</Window>
  1. 我怎样才能实现这样的目标?

  2. 这里是XAML:

<UserControl x:Class="TEST.MyControl"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008"              
             mc:Ignorable="d" 
             d:DesignHeight="450" d:DesignWidth="800"
             x:Name="parent">
    <StackPanel Width="100" Orientation="Horizontal"                 
                DataContext="{Binding ElementName=parent}">
        
        <!-- User Label -->
        <TextBlock Width="200" Name="UserLabel"                                                        
                   Text="{Binding Path=UserLabel}" >            
        </TextBlock>
        
        <!-- User Input -->
        <TextBox Width="100" Name="MetricValue"                  
                 Text="{Binding Path=UserValue}"/>
        
    </StackPanel>
</UserControl>

  1. 下面是代码:
/// <summary>
    /// Interaction logic for MyControl.xaml
    /// </summary>
    public partial class MyControl: UserControl
    {
        public MyControl()
        {
            InitializeComponent();
        }

        #region User Label DP
        public static readonly DependencyProperty UserLabelProperty =
            DependencyProperty.Register("UserLabel",
                typeof(string),
                typeof(MyControl),
                new PropertyMetadata(""));
        public string UserLabel
        {
            get { return GetValue(UserLabelProperty) as String; }
            set { SetValue(UserLabelProperty, value); }
        }
        #endregion // User Label DP

        #region UserValue DP
        public static readonly DependencyProperty UserValueProperty =
            DependencyProperty.Register("UserValue",
                typeof(string),
                typeof(MyControl),
                new PropertyMetadata(""));
        public string UserValue
        {
            get { return GetValue(UserValueProperty) as String; }
            set { SetValue(UserValueProperty, value); }
        }
        #endregion // UserValue DP        
    }

使 UserLabel 成为 TextBlock 而不是没有 Run 元素概念的 string:

#region User Label DP
public static readonly DependencyProperty UserLabelProperty =
    DependencyProperty.Register("UserLabel",
        typeof(TextBlock),
        typeof(MyControl));

public TextBlock UserLabel
{
    get { return GetValue(UserLabelProperty) as TextBlock; }
    set { SetValue(UserLabelProperty, value); }
}
#endregion // User Label DP

用户控件XAML:

<!-- User Label -->
<ContentControl Width="200" Content="{Binding UserLabel, ElementName=parent}" />

Window XAML:

<StackPanel>
    <local:MyControl>
        <local:MyControl.UserLabel>
            <TextBlock>
                <Run FontSize="12pt">Subscript</Run>
                <Run BaselineAlignment="Subscript" FontSize="12pt">This</Run>
            </TextBlock>
        </local:MyControl.UserLabel>
    </local:MyControl>
</StackPanel>