设置自定义用户控件样式禁用状态
本文关键字:状态 样式 控件 自定义 用户 设置 | 更新日期: 2023-09-27 18:26:57
如何设置自定义用户控件的"禁用"状态的样式?我不清楚如何为自定义用户控件的各个部分设置样式。例如,我的自定义用户控件由几个组件组成。那么,如何在全局样式表中针对控件的特定部分呢?请记住,如果再次启用,我希望它能恢复到原来的颜色。
这是我的自定义用户控制代码。。。
VNode.xaml
<UserControl x:Class="WpfApplication1.VNode"
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"
xmlns:local="clr-namespace:WpfApplication1"
mc:Ignorable="d"
d:DesignHeight="100" d:DesignWidth="200">
<Grid>
<Rectangle x:Name="Backplate" Fill="Green" Width="100" Height="50" RadiusX="3" RadiusY="3"/>
<Rectangle x:Name="Highlight"
Height="60"
Width="110"
Fill="Transparent"
Stroke="White"
StrokeThickness="2"
RadiusX="6" RadiusY="6">
</Rectangle>
<TextBlock x:Name="Label" Text="Label" TextWrapping="Wrap" Width="100" Height="50"/>
</Grid>
</UserControl>
VNode.xaml.cs
using System.Windows.Controls;
using System.Windows.Media;
namespace WpfApplication1
{
/// <summary>
/// Interaction logic for VNode.xaml
/// </summary>
public partial class VNode : UserControl
{
public VNode()
{
InitializeComponent();
}
public Brush BackplateColor
{
get { return Backplate.Fill; }
set { Backplate.Fill = value; }
}
public string Text
{
get { return Label.Text; }
set { Label.Text = value; }
}
}
}
样式表
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:WpfApplication1">
<Style x:Key="NodeStyle" TargetType="{x:Type local:VNode}">
<Style.Triggers>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Backplate" Value="Red" />
</Trigger>
</Style.Triggers>
</Style>
</ResourceDictionary>
最好为每个Control
创建或覆盖Style
。它为您提供了从代码背后更改Controls
样式的灵活性,并且是一种关注点的分离。
例如,让我们看看TextBlock
的样式,它根据IsMouseOver
或IsEnabled
条件更改其样式:
在App.xaml文件中:
<Application x:Class="UWPWpfApplication.App"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
StartupUri="MainWindow.xaml">
<Application.Resources>
<Style TargetType="TextBlock" x:Key="VNodeTextBlock">
<Setter Property="FontWeight" Value="Bold" />
<Setter Property="FontSize" Value="8"/>
<Style.Triggers>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Foreground" Value="Red" />
</Trigger>
<Trigger Property="IsEnabled" Value="True">
<Setter Property="Foreground" Value="Green" />
</Trigger>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="FontSize" Value="20" />
</Trigger>
</Style.Triggers>
</Style>
</Application.Resources>
</Application>
形式:
<TextBlock Text="Hello World!:)" Style="{StaticResource VNodeTextBlock}"/>