カスタム スタイルを変更することで、角を丸くするように WPF チェックボックスのスタイルを設定することは可能ですか? もしそうなら、これはどのように行われますか?
質問する
7602 次
2 に答える
2
はい。それが可能だ。
hereを見ると、既存の checkBox の完全なスタイルを取得でき、Border が Decorator によって描画されていないように見えます。したがって、スタイルのこのセクションを変更して適用するだけです。
<Border x:Name="Border"
Width="13"
Height="13"
<!--Here--> CornerRadius="0"
BorderThickness="1">
<Border.BorderBrush>
于 2012-09-24T13:23:52.183 に答える
1
私が知っている最善の方法
<CheckBox Content="CheckBox" HorizontalAlignment="Left" Height="20" Margin="134,143,0,0" VerticalAlignment="Top" Width="176" Style="{DynamicResource CheckBoxStyle1}"/>
リソース辞書
<ResourceDictionary
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:Microsoft_Windows_Themes="clr-namespace:Microsoft.Windows.Themes;assembly=PresentationFramework.Aero">
<Style x:Key="CheckBoxStyle1" TargetType="{x:Type CheckBox}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type CheckBox}">
<BulletDecorator Background="Transparent" SnapsToDevicePixels="true">
<BulletDecorator.Bullet>
<Border Background="#FFAEB3B9" BorderThickness="2" CornerRadius="10">
<Microsoft_Windows_Themes:BulletChrome IsChecked="{TemplateBinding IsChecked}" RenderMouseOver="{TemplateBinding IsMouseOver}" RenderPressed="{TemplateBinding IsPressed}"/>
</Border>
</BulletDecorator.Bullet>
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
</BulletDecorator>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</ResourceDictionary>
于 2012-09-24T13:21:30.883 に答える