Creating style for circle checkbox:
<Style TargetType="CheckBox" x:Key="CircleCheckbox">
<Setter Property="Cursor" Value="Hand"></Setter>
<Setter Property="Content" Value=""></Setter>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type CheckBox}">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="24"></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="24"></ColumnDefinition>
<ColumnDefinition ></ColumnDefinition>
</Grid.ColumnDefinitions>
<Border Background="White" BorderBrush="#C6C6C6" BorderThickness="1" CornerRadius="0" Width="20" Height="20" VerticalAlignment="Center" >
<Grid>
<Ellipse x:Name="outerEllipse" Grid.Column="0" Fill="Blue" Margin="2">
</Ellipse>
</Grid>
</Border>
<ContentPresenter Grid.Column="1" x:Name="content" Margin="5,0,0,0" HorizontalAlignment="Left" VerticalAlignment="Center"/>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsChecked" Value="True">
<Setter TargetName="outerEllipse" Property="Fill" Value="Red">
</Setter>
</Trigger>
<Trigger Property="IsChecked" Value="False">
<Setter TargetName="outerEllipse" Property="Fill" Value="Blue">
</Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Adding style to checkboxes:
<CheckBox Grid.Row="1" Content="Checkbox1" Style="{StaticResource CircleCheckbox}" Margin="1,2,14,-2">
</CheckBox>
<CheckBox Grid.Row="1" Content="Checkbox2" Style="{StaticResource CircleCheckbox}" Margin="0,54,0,-54">
</CheckBox>
<CheckBox Grid.Row="1" Content="Checkbox3" Style="{StaticResource CircleCheckbox}" Margin="1,100,-1,-100">
</CheckBox>
OUTPUT:
Default CheckBox
data:image/s3,"s3://crabby-images/ed513/ed513b0f89c5a751d686d33b53e96529eba24105" alt=""
On Click of CheckBox
data:image/s3,"s3://crabby-images/b9f4e/b9f4e99c2add3a9293a5cb24b5381261ec3da53e" alt=""
Blue color is for unchecked checkbox and red color is for checked checkbox. You can also remove circle in case of unchecked checkbox by simply changing the color as:
<Trigger Property="IsChecked" Value="False">
<Setter TargetName="outerEllipse" Property="Fill" Value="White">
</Setter>
</Trigger>
and then the output is:
data:image/s3,"s3://crabby-images/2bef0/2bef0194bc85f346be66cd09b8f007418da93516" alt=""
Hope, this code will help you. Thanks
0 Comment(s)