自定义控件文本框和隐式样式

本文关键字:样式 文本 自定义控件 | 更新日期: 2023-09-27 18:34:51

我们正在尝试为我们创建的自定义文本块控件创建隐含样式。
此自定义控件基于文本块,并添加了一些 DP 和逻辑。
当我们在本地使用该样式时,一切正常。此外,当我们给样式一个键时,它也可以工作。

这是自定义控件继承代码:

public class HighlightTextBlock : TextBlock

这是样式:

    <Style TargetType="UI:HighlightTextBlock"
       x:Name="LocalHighlightTextBlockStyle"
       BasedOn="{StaticResource StyleHighlightTextBlockDefault}">
  <Setter Property="HighlightedText"
          Value="{Binding ElementName=txtSearchBox, Path=Text}"></Setter> 
  <Setter Property="Background" Value="Tomato"></Setter>
  <!--<Setter Property="HighlightedText" Value="{Binding UpdateSourceTrigger=PropertyChanged,
              Mode=TwoWay, RelativeSource={RelativeSource FindAncestor, 
              AncestorType={x:Type UI:GenericWatchControl}}, Path=SearchTextBoxContent}" />-->
  <!--<Style.Triggers>
    <Trigger Property="Text" Value="{x:Static ProfilingServerShared:MissingDataValue.NotAvailableText}">
      <Setter Property="Foreground" Value="LightGray" />
    </Trigger>
  </Style.Triggers>-->
</Style>

谢谢大家

自定义控件文本框和隐式样式

> 您应该覆盖静态构造函数HighlightTextBlock元数据,如下所示:

public partial class HighlightTextBlock : TextBlock
{
    static HighlightTextBlock()
    {
        DefaultStyleKeyProperty.OverrideMetadata(typeof(HighlightTextBlock), 
          new FrameworkPropertyMetadata(typeof(HighlightTextBlock)));
    }
}

如果不这样做,默认情况下,HighlightTextBlock将尝试查找TextBlock的隐式样式,而不是HighglightTextBlock