291 lines
18 KiB
XML
291 lines
18 KiB
XML
<ResourceDictionary
|
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
xmlns:controls="clr-namespace:Melskin.Controls"
|
|
xmlns:decorations="clr-namespace:Melskin.Controls.Decorations"
|
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
|
|
|
|
<Style TargetType="{x:Type CheckBox}" x:Key="EmbossCheckBoxStyle">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource FocusVisual}" />
|
|
<Setter Property="Background" Value="{DynamicResource ControlBackgroundNormalBrush}" />
|
|
<Setter Property="Foreground" Value="{DynamicResource TextPrimaryBrush}" />
|
|
<Setter Property="BorderThickness" Value="1" />
|
|
<Setter Property="FontSize" Value="14" />
|
|
<Setter Property="VerticalContentAlignment" Value="Center" />
|
|
|
|
<Setter Property="Template">
|
|
<Setter.Value>
|
|
<ControlTemplate TargetType="{x:Type CheckBox}">
|
|
<Grid SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" x:Name="templateRoot">
|
|
<Grid.ColumnDefinitions>
|
|
<ColumnDefinition Width="Auto" />
|
|
<ColumnDefinition Width="*" />
|
|
</Grid.ColumnDefinitions>
|
|
|
|
<decorations:EmbossBorder
|
|
Background="{TemplateBinding Background}"
|
|
CornerRadius="4"
|
|
Height="24"
|
|
Intensity="0.4"
|
|
RenderTransformOrigin="0.5,0.5"
|
|
Width="24"
|
|
x:Name="checkBoxEmboss" />
|
|
<decorations:SlotBorder
|
|
Background="{TemplateBinding Background}"
|
|
BorderThickness="{TemplateBinding BorderThickness}"
|
|
CornerRadius="4"
|
|
Grid.Column="0"
|
|
Height="24"
|
|
Intensity="0.2"
|
|
Visibility="Collapsed"
|
|
Width="24"
|
|
x:Name="markSlot">
|
|
<controls:IconElement
|
|
Foreground="{DynamicResource PrimaryNormalBrush}"
|
|
Margin="1"
|
|
Symbol="Check"
|
|
x:Name="checkMark" />
|
|
</decorations:SlotBorder>
|
|
<ContentPresenter
|
|
Focusable="False"
|
|
Grid.Column="1"
|
|
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
|
|
Margin="{TemplateBinding Padding}"
|
|
RecognizesAccessKey="True"
|
|
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"
|
|
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
|
|
x:Name="contentPresenter" />
|
|
</Grid>
|
|
<ControlTemplate.Triggers>
|
|
<Trigger Property="HasContent" Value="True">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource OptionMarkFocusVisual}" />
|
|
<Setter Property="Padding" Value="4,0,0,0" />
|
|
</Trigger>
|
|
<Trigger Property="IsChecked" Value="True">
|
|
<Setter Property="Visibility" TargetName="markSlot" Value="Visible" />
|
|
<Setter Property="Visibility" TargetName="checkBoxEmboss" Value="Collapsed" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryNormalBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsMouseOver" Value="True">
|
|
<Setter Property="Cursor" Value="Hand" />
|
|
<Setter Property="Foreground" TargetName="checkMark" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsEnabled" Value="False">
|
|
<Setter Property="Intensity" TargetName="markSlot" Value="0" />
|
|
<Setter Property="Background" TargetName="markSlot" Value="{DynamicResource ControlBackgroundDisabledBrush}" />
|
|
<Setter Property="Foreground" TargetName="checkMark" Value="{DynamicResource PrimaryDisabledBrush}" />
|
|
|
|
<Setter Property="ShaderEnabled" TargetName="checkBoxEmboss" Value="False" />
|
|
<Setter Property="Background" TargetName="checkBoxEmboss" Value="{DynamicResource ControlBackgroundDisabledBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource TextDisabledBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsPressed" Value="True">
|
|
<Setter Property="RenderTransform" TargetName="checkBoxEmboss">
|
|
<Setter.Value>
|
|
<ScaleTransform ScaleX="0.9" ScaleY="0.9" />
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Trigger>
|
|
</ControlTemplate.Triggers>
|
|
</ControlTemplate>
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Style>
|
|
<Style TargetType="{x:Type CheckBox}" x:Key="SlotCheckBoxStyle">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource FocusVisual}" />
|
|
<Setter Property="Background" Value="{DynamicResource ControlBackgroundNormalBrush}" />
|
|
<Setter Property="Foreground" Value="{DynamicResource TextPrimaryBrush}" />
|
|
<Setter Property="FontSize" Value="14" />
|
|
<Setter Property="VerticalContentAlignment" Value="Center" />
|
|
<Setter Property="Template">
|
|
<Setter.Value>
|
|
<ControlTemplate TargetType="{x:Type CheckBox}">
|
|
<Grid SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" x:Name="templateRoot">
|
|
<Grid.ColumnDefinitions>
|
|
<ColumnDefinition Width="Auto" />
|
|
<ColumnDefinition Width="*" />
|
|
</Grid.ColumnDefinitions>
|
|
<decorations:SlotBorder
|
|
Background="{TemplateBinding Background}"
|
|
BorderThickness="{TemplateBinding BorderThickness}"
|
|
CornerRadius="4"
|
|
Height="24"
|
|
Intensity="0.2"
|
|
RenderTransformOrigin="0.5,0.5"
|
|
Width="24"
|
|
x:Name="checkBoxSlot" />
|
|
<decorations:EmbossBorder
|
|
Background="{TemplateBinding Background}"
|
|
CornerRadius="4"
|
|
Grid.Column="0"
|
|
Height="24"
|
|
Intensity="0.4"
|
|
Padding="2"
|
|
Visibility="Collapsed"
|
|
Width="24"
|
|
x:Name="markEmboss">
|
|
<Rectangle
|
|
Fill="{DynamicResource PrimaryNormalBrush}"
|
|
Margin="2"
|
|
RadiusX="3"
|
|
RadiusY="3"
|
|
x:Name="checkMark" />
|
|
</decorations:EmbossBorder>
|
|
<ContentPresenter
|
|
Focusable="False"
|
|
Grid.Column="1"
|
|
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
|
|
Margin="{TemplateBinding Padding}"
|
|
RecognizesAccessKey="True"
|
|
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"
|
|
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
|
|
x:Name="contentPresenter" />
|
|
</Grid>
|
|
<ControlTemplate.Triggers>
|
|
<Trigger Property="HasContent" Value="True">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource OptionMarkFocusVisual}" />
|
|
<Setter Property="Padding" Value="4,0,0,0" />
|
|
</Trigger>
|
|
<Trigger Property="IsChecked" Value="True">
|
|
<Setter Property="Visibility" TargetName="markEmboss" Value="Visible" />
|
|
<Setter Property="Visibility" TargetName="checkBoxSlot" Value="Collapsed" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryNormalBrush}" />
|
|
</Trigger>
|
|
<!-- 鼠标高亮,隐藏边框,显示深度效果 -->
|
|
<Trigger Property="IsMouseOver" Value="True">
|
|
<Setter Property="Cursor" Value="Hand" />
|
|
<Setter Property="Fill" TargetName="checkMark" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsEnabled" Value="False">
|
|
<Setter Property="ShaderEnabled" TargetName="checkBoxSlot" Value="False" />
|
|
<Setter Property="Background" TargetName="checkBoxSlot" Value="{DynamicResource ControlBackgroundDisabledBrush}" />
|
|
<Setter Property="ShaderEnabled" TargetName="markEmboss" Value="False" />
|
|
<Setter Property="Background" TargetName="markEmboss" Value="{DynamicResource ControlBackgroundDisabledBrush}" />
|
|
<Setter Property="Fill" TargetName="checkMark" Value="{DynamicResource PrimaryDisabledBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource TextDisabledBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsPressed" Value="True">
|
|
<Setter Property="RenderTransform" TargetName="checkBoxSlot">
|
|
<Setter.Value>
|
|
<ScaleTransform ScaleX="0.9" ScaleY="0.9" />
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Trigger>
|
|
|
|
</ControlTemplate.Triggers>
|
|
</ControlTemplate>
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Style>
|
|
<Style TargetType="{x:Type CheckBox}" x:Key="DefaultCheckBoxStyle">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource FocusVisual}" />
|
|
<Setter Property="Background" Value="{DynamicResource ControlBackgroundNormalBrush}" />
|
|
<Setter Property="BorderBrush" Value="{DynamicResource BorderNormalBrush}" />
|
|
<Setter Property="Foreground" Value="{DynamicResource TextPrimaryBrush}" />
|
|
<Setter Property="BorderThickness" Value="1" />
|
|
<Setter Property="FontSize" Value="14" />
|
|
<Setter Property="VerticalContentAlignment" Value="Center" />
|
|
|
|
<Setter Property="Template">
|
|
<Setter.Value>
|
|
<ControlTemplate TargetType="{x:Type CheckBox}">
|
|
<Grid SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" x:Name="templateRoot">
|
|
<Grid.ColumnDefinitions>
|
|
<ColumnDefinition Width="Auto" />
|
|
<ColumnDefinition Width="*" />
|
|
</Grid.ColumnDefinitions>
|
|
<Border
|
|
Background="{TemplateBinding Background}"
|
|
BorderBrush="{TemplateBinding BorderBrush}"
|
|
BorderThickness="{TemplateBinding BorderThickness}"
|
|
CornerRadius="4"
|
|
Height="18"
|
|
Margin="3,2"
|
|
RenderTransformOrigin="0.5,0.5"
|
|
Width="18"
|
|
x:Name="checkBoxBorder">
|
|
<Grid Margin="-1" x:Name="markGrid">
|
|
<Border
|
|
Background="{DynamicResource PrimaryNormalBrush}"
|
|
CornerRadius="4"
|
|
Opacity="0"
|
|
x:Name="markBorder">
|
|
<controls:IconElement
|
|
Foreground="{TemplateBinding Background}"
|
|
Margin="3"
|
|
Symbol="Check" />
|
|
</Border>
|
|
|
|
<Rectangle
|
|
Fill="{DynamicResource PrimaryNormalBrush}"
|
|
Margin="3"
|
|
Opacity="0"
|
|
RadiusX="3"
|
|
RadiusY="3"
|
|
x:Name="indeterminateMark" />
|
|
|
|
</Grid>
|
|
</Border>
|
|
|
|
<ContentPresenter
|
|
Focusable="False"
|
|
Grid.Column="1"
|
|
HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
|
|
Margin="{TemplateBinding Padding}"
|
|
RecognizesAccessKey="True"
|
|
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"
|
|
VerticalAlignment="{TemplateBinding VerticalContentAlignment}"
|
|
x:Name="contentPresenter" />
|
|
</Grid>
|
|
<ControlTemplate.Triggers>
|
|
<Trigger Property="HasContent" Value="True">
|
|
<Setter Property="FocusVisualStyle" Value="{DynamicResource OptionMarkFocusVisual}" />
|
|
<Setter Property="Padding" Value="4,0,0,0" />
|
|
</Trigger>
|
|
<Trigger Property="IsChecked" Value="True">
|
|
<Setter Property="Opacity" TargetName="markBorder" Value="1" />
|
|
<Setter Property="Opacity" TargetName="indeterminateMark" Value="0" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryNormalBrush}" />
|
|
</Trigger>
|
|
<Trigger Property="IsChecked" Value="{x:Null}">
|
|
<Setter Property="Opacity" TargetName="indeterminateMark" Value="1" />
|
|
</Trigger>
|
|
<Trigger Property="IsEnabled" Value="False">
|
|
<Setter Property="BorderBrush" TargetName="checkBoxBorder" Value="{DynamicResource BorderDisabledBrush}" />
|
|
<Setter Property="Background" TargetName="markBorder" Value="{DynamicResource PrimaryDisabledBrush}" />
|
|
<Setter Property="Fill" TargetName="indeterminateMark" Value="{DynamicResource PrimaryDisabledBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource TextDisabledBrush}" />
|
|
</Trigger>
|
|
<!-- 鼠标高亮,隐藏边框,显示深度效果 -->
|
|
<Trigger Property="IsMouseOver" Value="True">
|
|
<Setter Property="BorderBrush" TargetName="checkBoxBorder" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
<Setter Property="Fill" TargetName="indeterminateMark" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
<Setter Property="Background" TargetName="markBorder" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
<Setter Property="TextElement.Foreground" TargetName="contentPresenter" Value="{DynamicResource PrimaryFocusedBrush}" />
|
|
</Trigger>
|
|
|
|
<Trigger Property="IsPressed" Value="True">
|
|
<Setter Property="RenderTransform" TargetName="checkBoxBorder">
|
|
<Setter.Value>
|
|
<ScaleTransform ScaleX="0.9" ScaleY="0.9" />
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Trigger>
|
|
|
|
</ControlTemplate.Triggers>
|
|
</ControlTemplate>
|
|
</Setter.Value>
|
|
</Setter>
|
|
</Style>
|
|
<!-- 默认样式 -->
|
|
<Style BasedOn="{StaticResource DefaultCheckBoxStyle}" TargetType="{x:Type CheckBox}" />
|
|
<!-- 工具栏样式 -->
|
|
<Style
|
|
BasedOn="{StaticResource DefaultCheckBoxStyle}"
|
|
TargetType="{x:Type CheckBox}"
|
|
x:Key="{x:Static ToolBar.CheckBoxStyleKey}">
|
|
<Setter Property="Margin" Value="0,0,8,0" />
|
|
<Setter Property="VerticalAlignment" Value="Center" />
|
|
</Style>
|
|
</ResourceDictionary> |