自定义控件文本框和隐式样式
本文关键字:样式 文本 自定义控件 | 更新日期: 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
。