WPF Calendar 日历控件 样式自定义

简介: 原文:WPF Calendar 日历控件 样式自定义 粗略的在代码上做了些注释 blend 生成出来的模版 有的时候 会生成 跟 vs ui界面不兼容的代码 会导致可视化设计界面 报错崩溃掉 但是确不影响 程序的编译运行 这个样式表 在vs 里会提示动画不兼容 Foreground属性 报错 ...

原文:WPF Calendar 日历控件 样式自定义

粗略的在代码上做了些注释

blend 生成出来的模版 有的时候 会生成 跟 vs ui界面不兼容的代码 会导致可视化设计界面 报错崩溃掉 但是确不影响 程序的编译运行

这个样式表 在vs 里会提示动画不兼容 Foreground属性 报错

先上图看下样式

 

下面是代码 

 <Window x:Class="CalendarStyleWpfApplication.MainWindow"
         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
         Title="MainWindow"
         Width="640"
         Height="480">
 
 
 
     <Window.Resources>
         <Style x:Key="CalendarStyle1"
                TargetType="{x:Type Calendar}">
             <!--日历控件的背景色,也可以改成绑定的-->
             <Setter Property="Background"
                     Value="#f6f6f6" />
             <Setter Property="Template">
                 <Setter.Value>
                     <ControlTemplate TargetType="{x:Type Calendar}">
 
                         <StackPanel x:Name="PART_Root"
                                     HorizontalAlignment="Center"
                                     VerticalAlignment="Center">
                             <!--这个是日历控件的主体元件,也是内部元件PART_CalendarItem名称不要更改,可以改它的其它样式属性-->
                             <CalendarItem x:Name="PART_CalendarItem"
                                           BorderBrush="{TemplateBinding BorderBrush}"
                                           BorderThickness="{TemplateBinding BorderThickness}"
                                           Background="{TemplateBinding Background}"
                                           Style="{TemplateBinding CalendarItemStyle}"
                                           Height="{TemplateBinding Height}"
                                           Width="{TemplateBinding Width}"
                                           HorizontalAlignment="Stretch"
                                           VerticalAlignment="Stretch" />
                         </StackPanel>
 
                     </ControlTemplate>
                 </Setter.Value>
             </Setter>
         </Style>
         
         <!--日历主体样式表-->
         <Style x:Key="CalendarItemStyle1"
                TargetType="{x:Type CalendarItem}">
             <Setter Property="Template">
                 <Setter.Value>
                     <ControlTemplate TargetType="{x:Type CalendarItem}">
                         <ControlTemplate.Resources>
                             <DataTemplate x:Key="{x:Static CalendarItem.DayTitleTemplateResourceKey}">
                                <!--日历星期几的绑定样式,我格式化成周一,周二等-->
                                 <TextBlock Foreground="#666666"
                                            FontSize="16"
                                            FontFamily="微软雅黑"
                                            HorizontalAlignment="Center"
                                            Margin="0 15"
                                            Text="{Binding StringFormat=周{0} }"
                                            VerticalAlignment="Center" />
                             </DataTemplate>
                         </ControlTemplate.Resources>
                         <Grid x:Name="PART_Root">
                             <Grid.Resources>
                                 <!--设置日历控件 IsEnable=false 时的不可用遮罩层颜色,并且会播放过渡动画-->
                                 <SolidColorBrush x:Key="DisabledColor"
                                                  Color="#A5FFFFFF" />
                             </Grid.Resources>
                             
                             
                             <VisualStateManager.VisualStateGroups>
                                 <VisualStateGroup x:Name="CommonStates">
                                     <VisualState x:Name="Normal" />
                                     <VisualState x:Name="Disabled">
                                         <!--设置日历控件 IsEnable=false 时遮罩层透明度0-1变色动画-->
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To="1"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="PART_DisabledVisual" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                             </VisualStateManager.VisualStateGroups>
                             
                             <Border BorderBrush="#cfcfcf"
                                     BorderThickness="0"
                                     Background="{TemplateBinding Background}"
                                     CornerRadius="2">
                                 <Border>
                                     <Grid>
                                         <Grid.Resources>
                                             <!--日历头左箭头按钮样式模版-->
                                             <ControlTemplate x:Key="PreviousButtonTemplate"
                                                              TargetType="{x:Type Button}">
                                                 <!--鼠标悬停在左箭头按钮上时改变鼠标指针样式-->
                                                 <Grid Cursor="Hand">
                                                     <VisualStateManager.VisualStateGroups>
                                                         <VisualStateGroup x:Name="CommonStates">
                                                             <VisualState x:Name="Normal" />
                                                             <VisualState x:Name="MouseOver">
                                                                 <!--鼠标悬停在左箭头按钮上时左箭头颜色变化动画-->
                                                                 <Storyboard>
                                                                     <ColorAnimation Duration="0"
                                                                                     To="#FF73A9D8"
                                                                                     Storyboard.TargetProperty="(Shape.Fill).(SolidColorBrush.Color)"
                                                                                     Storyboard.TargetName="path" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                             <VisualState x:Name="Disabled">
                                                                 <Storyboard>
                                                                     <DoubleAnimation Duration="0"
                                                                                      To=".5"
                                                                                      Storyboard.TargetProperty="(Shape.Fill).(Brush.Opacity)"
                                                                                      Storyboard.TargetName="path" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                         </VisualStateGroup>
                                                     </VisualStateManager.VisualStateGroups>
                                                     <!--左箭头整个区域矩形块-->
                                                     <Rectangle Fill="#363636"
                                                                Opacity="1"
                                                                Stretch="Fill" />
                                                     <Grid>
                                                         <!--左箭头-->
                                                         <Path x:Name="path"
                                                               Data="M288.75,232.25 L288.75,240.625 L283,236.625 z"
                                                               Fill="#e0e0e0"
                                                               HorizontalAlignment="Left"
                                                               Height="15"
                                                               Width="15"
                                                               Margin="20,0,0,0"
                                                               Stretch="Fill"
                                                               VerticalAlignment="Center" />
                                                     </Grid>
                                                 </Grid>
                                             </ControlTemplate>
                                             <!--日历头右箭头按钮样式模版,这块跟左箭头样式模版没什么区别-->
                                             <ControlTemplate x:Key="NextButtonTemplate"
                                                              TargetType="{x:Type Button}">
                                                 <Grid Cursor="Hand">
                                                     <VisualStateManager.VisualStateGroups>
                                                         <VisualStateGroup x:Name="CommonStates">
                                                             <VisualState x:Name="Normal" />
                                                             <VisualState x:Name="MouseOver">
                                                                 <Storyboard>
                                                                     <ColorAnimation Duration="0"
                                                                                     To="#FF73A9D8"
                                                                                     Storyboard.TargetProperty="(Shape.Fill).(SolidColorBrush.Color)"
                                                                                     Storyboard.TargetName="path" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                             <VisualState x:Name="Disabled">
                                                                 <Storyboard>
                                                                     <DoubleAnimation Duration="0"
                                                                                      To=".5"
                                                                                      Storyboard.TargetProperty="(Shape.Fill).(Brush.Opacity)"
                                                                                      Storyboard.TargetName="path" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                         </VisualStateGroup>
                                                     </VisualStateManager.VisualStateGroups>
                                                     <Rectangle Fill="#363636"
                                                                Opacity="1"
                                                                Stretch="Fill" />
                                                     <Grid>
                                                         <Path x:Name="path"
                                                               Data="M282.875,231.875 L282.875,240.375 L288.625,236 z"
                                                               Fill="#e0e0e0"
                                                               HorizontalAlignment="Right"
                                                               Height="15"
                                                               Width="15"
                                                               Margin="0,0,20,0"
                                                               Stretch="Fill"
                                                               VerticalAlignment="Center" />
                                                     </Grid>
                                                 </Grid>
                                             </ControlTemplate>
                                             <!--日历头中间年按钮样式模版-->
                                             <ControlTemplate x:Key="HeaderButtonTemplate"
                                                              TargetType="{x:Type Button}">
                                                 <Grid Cursor="Hand">
                                                     <VisualStateManager.VisualStateGroups>
                                                         <VisualStateGroup x:Name="CommonStates">
                                                             <VisualState x:Name="Normal" />
                                                             <VisualState x:Name="MouseOver">
                                                                 <Storyboard>
                                                                     <ColorAnimation Duration="0"
                                                                                     To="#FF73A9D8"
                                                                                     Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)"
                                                                                     Storyboard.TargetName="buttonContent" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                             <VisualState x:Name="Disabled">
                                                                 <Storyboard>
                                                                     <DoubleAnimation Duration="0"
                                                                                      To=".5"
                                                                                      Storyboard.TargetProperty="Opacity"
                                                                                      Storyboard.TargetName="buttonContent" />
                                                                 </Storyboard>
                                                             </VisualState>
                                                         </VisualStateGroup>
                                                     </VisualStateManager.VisualStateGroups>
                                                     <ContentPresenter x:Name="buttonContent"
                                                                       ContentTemplate="{TemplateBinding ContentTemplate}"
                                                                       Content="{TemplateBinding Content}"
                                                                       TextElement.Foreground="#e0e0e0"
                                                                       HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
                                                                       Margin="1,4,1,9"
                                                                       VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
                                                 </Grid>
                                             </ControlTemplate>
                                         </Grid.Resources>
                                       
                                         <Grid.RowDefinitions>
                                             <!--日历头,左箭头,年,右箭头-->
                                             <RowDefinition Height="Auto" />
                                             <!--日历内容,星期几和具体的日期几号几号-->
                                             <RowDefinition Height="*" />
                                         </Grid.RowDefinitions>
                                         <Grid.ColumnDefinitions>
                                             <!--左箭头-->
                                             <ColumnDefinition Width="Auto" />
                                             <!---->
                                             <ColumnDefinition Width="*" />
                                             <!--右箭头-->
                                             <ColumnDefinition Width="Auto" />
                                         </Grid.ColumnDefinitions>
                                         <!--头,左箭头,年,右箭头,整体的背景色-->
                                         <Border Grid.Row="0"
                                                 Grid.ColumnSpan="3"
                                                 Background="#363636"></Border>
                                         <!--左箭头-->
                                         <Button x:Name="PART_PreviousButton"
                                                 Grid.Column="0"
                                                 Focusable="False"
                                                 HorizontalAlignment="Left"
                                                 Grid.Row="0"
                                                 Template="{StaticResource PreviousButtonTemplate}" />
                                         <!---->
                                         <Button x:Name="PART_HeaderButton"
                                                 Grid.Column="1"
                                                 FontFamily="微软雅黑"
                                                 Focusable="False"
                                                 FontSize="26"
                                                 HorizontalAlignment="Center"
                                                 Grid.Row="0"
                                                 Template="{StaticResource HeaderButtonTemplate}"
                                                 VerticalAlignment="Center" />
                                         <!--右箭头-->
                                         <Button x:Name="PART_NextButton"
                                                 Grid.Column="2"
                                                 Focusable="False"
                                                 HorizontalAlignment="Right"
                                                 Grid.Row="0"
                                                 Template="{StaticResource NextButtonTemplate}" />
                                        <!--日期几号几号内容显示-->
                                         <Border Grid.Row="1"
                                                 Grid.ColumnSpan="3"
                                                 Margin="0"
                                                 BorderBrush="#cfcfcf"
                                                 BorderThickness="3,0,3,3">
                                             <Grid x:Name="PART_MonthView"
                                                   HorizontalAlignment="Center"
                                                   Visibility="Visible">
                                                 <Grid.ColumnDefinitions>
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                     <ColumnDefinition Width="*" />
                                                 </Grid.ColumnDefinitions>
                                                 <Grid.RowDefinitions>
                                                     <RowDefinition Height="auto" />
                                                     <RowDefinition Height="*" />
                                                     <RowDefinition Height="*" />
                                                     <RowDefinition Height="*" />
                                                     <RowDefinition Height="*" />
                                                     <RowDefinition Height="*" />
                                                     <RowDefinition Height="*" />
                                                 </Grid.RowDefinitions>
                                             </Grid>
                                         </Border>
 
                                         <!--月和年内容显示-->
                                         <Grid x:Name="PART_YearView"
                                               Grid.ColumnSpan="3"
                                               HorizontalAlignment="Center"
                                               Margin="6,-3,7,6"
                                               Grid.Row="1"
                                               Visibility="Hidden"
                                               VerticalAlignment="Center">
                                             <Grid.ColumnDefinitions>
                                                 <ColumnDefinition Width="*" />
                                                 <ColumnDefinition Width="*" />
                                                 <ColumnDefinition Width="*" />
                                                 <ColumnDefinition Width="*" />
                                             </Grid.ColumnDefinitions>
                                             <Grid.RowDefinitions>
                                                 <RowDefinition Height="*" />
                                                 <RowDefinition Height="*" />
                                                 <RowDefinition Height="*" />
                                             </Grid.RowDefinitions>
                                         </Grid>
                                     </Grid>
                                 </Border>
                             </Border>
                             <!--日历不可用的遮罩层-->
                             <Rectangle x:Name="PART_DisabledVisual"
                                        Fill="{StaticResource DisabledColor}"
                                        Opacity="0"
                                        RadiusY="2"
                                        RadiusX="2"
                                        Stretch="Fill"
                                        Stroke="{StaticResource DisabledColor}"
                                        StrokeThickness="1"
                                        Visibility="Collapsed" />
                         </Grid>
                         <!--触发器属性-->
                         <ControlTemplate.Triggers>
                             <Trigger Property="IsEnabled"
                                      Value="False">
                                 <Setter Property="Visibility"
                                         TargetName="PART_DisabledVisual"
                                         Value="Visible" />
                             </Trigger>
                             <DataTrigger Binding="{Binding DisplayMode, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Calendar}}}"
                                          Value="Year">
                                 <Setter Property="Visibility"
                                         TargetName="PART_MonthView"
                                         Value="Hidden" />
                                 <Setter Property="Visibility"
                                         TargetName="PART_YearView"
                                         Value="Visible" />
                             </DataTrigger>
                             <DataTrigger Binding="{Binding DisplayMode, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Calendar}}}"
                                          Value="Decade">
                                 <Setter Property="Visibility"
                                         TargetName="PART_MonthView"
                                         Value="Hidden" />
                                 <Setter Property="Visibility"
                                         TargetName="PART_YearView"
                                         Value="Visible" />
                             </DataTrigger>
                         </ControlTemplate.Triggers>
                     </ControlTemplate>
                 </Setter.Value>
             </Setter>
         </Style>
         <!--单个几号几号按钮的样式模版-->
         <Style x:Key="CalendarDayButtonStyle1"
                TargetType="{x:Type CalendarDayButton}">
             <Setter Property="Margin"
                     Value="1" />
             <Setter Property="MinWidth"
                     Value="5" />
             <Setter Property="MinHeight"
                     Value="5" />
             <Setter Property="FontSize"
                     Value="22" />
             <Setter Property="FontFamily"
                     Value="微软雅黑" />
             <Setter Property="HorizontalContentAlignment"
                     Value="Center" />
             <Setter Property="VerticalContentAlignment"
                     Value="Center" />
             <Setter Property="Template">
                 <Setter.Value>
                     <ControlTemplate TargetType="{x:Type CalendarDayButton}">
                         <Grid>
                             <VisualStateManager.VisualStateGroups>
                                 <VisualStateGroup x:Name="CommonStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0:0:0.1" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Normal" />
                                     <!--悬停的颜色动画-->
                                     <VisualState x:Name="MouseOver">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To="0.5"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="HighlightBackground" />
                                         </Storyboard>
                                     </VisualState>
                                     <!--按下后动画-->
                                     <VisualState x:Name="Pressed">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To="0.5"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="HighlightBackground" />
                                         </Storyboard>
                                     </VisualState>
                                     <!--不可用动画-->
                                     <VisualState x:Name="Disabled">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To="0"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="HighlightBackground" />
                                             <DoubleAnimation Duration="0"
                                                              To=".35"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="NormalText" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="SelectionStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Unselected" />
                                     <!--选中某日期的样式-->
                                     <VisualState x:Name="Selected">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To=".75"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="SelectedBackground" />
                                             <ColorAnimation Duration="0"
                                                             To="white"
                                                             Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)"
                                                             Storyboard.TargetName="NormalText" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="CalendarButtonFocusStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="CalendarButtonFocused">
                                         <Storyboard>
                                             <ObjectAnimationUsingKeyFrames Duration="0"
                                                                            Storyboard.TargetProperty="Visibility"
                                                                            Storyboard.TargetName="DayButtonFocusVisual">
                                                 <DiscreteObjectKeyFrame KeyTime="0">
                                                     <DiscreteObjectKeyFrame.Value>
                                                         <Visibility>Visible</Visibility>
                                                     </DiscreteObjectKeyFrame.Value>
                                                 </DiscreteObjectKeyFrame>
                                             </ObjectAnimationUsingKeyFrames>
                                         </Storyboard>
                                     </VisualState>
                                     <VisualState x:Name="CalendarButtonUnfocused">
                                         <Storyboard>
                                             <ObjectAnimationUsingKeyFrames Duration="0"
                                                                            Storyboard.TargetProperty="Visibility"
                                                                            Storyboard.TargetName="DayButtonFocusVisual">
                                                 <DiscreteObjectKeyFrame KeyTime="0">
                                                     <DiscreteObjectKeyFrame.Value>
                                                         <Visibility>Collapsed</Visibility>
                                                     </DiscreteObjectKeyFrame.Value>
                                                 </DiscreteObjectKeyFrame>
                                             </ObjectAnimationUsingKeyFrames>
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="ActiveStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Active" />
                                     <VisualState x:Name="Inactive">
                                         <Storyboard>
                                             <ColorAnimation Duration="0"
                                                             To="#b4b3b3"
                                                             Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)"
                                                             Storyboard.TargetName="NormalText" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="DayStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="RegularDay" />
                                     <!--今天的样式-->
                                     <VisualState x:Name="Today">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To="1"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="TodayBackground" />
                                             <ColorAnimation Duration="0"
                                                             To="#666666"
                                                             Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)"
                                                             Storyboard.TargetName="NormalText" />
 
                                             <ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="Visibility"
                                                                            Storyboard.TargetName="imgToday">
                                                 <DiscreteObjectKeyFrame KeyTime="0">
                                                     <DiscreteObjectKeyFrame.Value>
                                                         <Visibility>Visible</Visibility>
                                                     </DiscreteObjectKeyFrame.Value>
                                                 </DiscreteObjectKeyFrame>
                                             </ObjectAnimationUsingKeyFrames>
 
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <!--过期日期的-->
                                 <VisualStateGroup x:Name="BlackoutDayStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="NormalDay" />
                                     <VisualState x:Name="BlackoutDay">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To=".2"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="Blackout" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                             </VisualStateManager.VisualStateGroups>
                             <Border BorderBrush="#bbbbbb"
                                     BorderThickness="1">
                                 <Border BorderBrush="white"
                                         BorderThickness="2,2,0,0"
                                         Margin="1,1,0,0"></Border>
                             </Border>
 
                             <Rectangle x:Name="TodayBackground"
                                        Fill="#c6c6c6"
                                        Opacity="0"
                                        RadiusY="1"
                                        RadiusX="1" />
                             <Rectangle x:Name="SelectedBackground"
                                        Fill="#6eafbf"
                                        Opacity="0"
                                        RadiusY="1"
                                        RadiusX="1" />
                             <Border BorderBrush="{TemplateBinding BorderBrush}"
                                     BorderThickness="{TemplateBinding BorderThickness}"
                                     Background="{TemplateBinding Background}" />
                             <Rectangle x:Name="HighlightBackground"
                                        Fill="#FFBADDE9"
                                        Opacity="0"
                                        RadiusY="1"
                                        RadiusX="1" />
                             <ContentPresenter x:Name="NormalText"
                                               TextElement.Foreground="#666666"
                                               HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
                                               VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
                             <Path x:Name="Blackout"
                                   Data="M8.1772461,11.029181 L10.433105,11.029181 L11.700684,12.801641 L12.973633,11.029181 L15.191895,11.029181 L12.844727,13.999395 L15.21875,17.060919 L12.962891,17.060919 L11.673828,15.256231 L10.352539,17.060919 L8.1396484,17.060919 L10.519043,14.042364 z"
                                   Fill="#FF000000"
                                   HorizontalAlignment="Stretch"
                                   Margin="3"
                                   Opacity="0"
                                   RenderTransformOrigin="0.5,0.5"
                                   Stretch="Fill"
                                   VerticalAlignment="Stretch" />
                             <Rectangle x:Name="DayButtonFocusVisual"
                                        IsHitTestVisible="false"
                                        RadiusY="1"
                                        RadiusX="1"
                                        Stroke="#FF45D6FA"
                                        Visibility="Collapsed" />
 
                             <Image x:Name="imgToday"
                                    Width="44"
                                    Height="34"
                                    Source="/Images/Today.png"
                                    VerticalAlignment="Top"
                                    HorizontalAlignment="Left"
                                    Visibility="Hidden" />
 
                         </Grid>
                     </ControlTemplate>
                 </Setter.Value>
             </Setter>
         </Style>
         <Style x:Key="CalendarButtonStyle1"
                TargetType="{x:Type CalendarButton}">
             <Setter Property="Background"
                     Value="#FFBADDE9" />
             <Setter Property="MinWidth"
                     Value="80" />
             <Setter Property="MinHeight"
                     Value="80" />
             <Setter Property="Margin"
                     Value="20" />
             <Setter Property="FontSize"
                     Value="25" />
             <Setter Property="HorizontalContentAlignment"
                     Value="Center" />
             <Setter Property="VerticalContentAlignment"
                     Value="Center" />
             <Setter Property="Template">
                 <Setter.Value>
                     <ControlTemplate TargetType="{x:Type CalendarButton}">
                         <Grid>
                             <VisualStateManager.VisualStateGroups>
                                 <VisualStateGroup x:Name="CommonStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0:0:0.1" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Normal" />
                                     <VisualState x:Name="MouseOver">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To=".5"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="Background" />
                                         </Storyboard>
                                     </VisualState>
                                     <VisualState x:Name="Pressed">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To=".5"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="Background" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="SelectionStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Unselected" />
                                     <VisualState x:Name="Selected">
                                         <Storyboard>
                                             <DoubleAnimation Duration="0"
                                                              To=".75"
                                                              Storyboard.TargetProperty="Opacity"
                                                              Storyboard.TargetName="SelectedBackground" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="ActiveStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="Active" />
                                     <VisualState x:Name="Inactive">
                                         <Storyboard>
                                             <ColorAnimation Duration="0"
                                                             To="#FF777777"
                                                             Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)"
                                                             Storyboard.TargetName="NormalText" />
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                                 <VisualStateGroup x:Name="CalendarButtonFocusStates">
                                     <VisualStateGroup.Transitions>
                                         <VisualTransition GeneratedDuration="0" />
                                     </VisualStateGroup.Transitions>
                                     <VisualState x:Name="CalendarButtonFocused">
                                         <Storyboard>
                                             <ObjectAnimationUsingKeyFrames Duration="0"
                                                                            Storyboard.TargetProperty="Visibility"
                                                                            Storyboard.TargetName="CalendarButtonFocusVisual">
                                                 <DiscreteObjectKeyFrame KeyTime="0">
                                                     <DiscreteObjectKeyFrame.Value>
                                                         <Visibility>Visible</Visibility>
                                                     </DiscreteObjectKeyFrame.Value>
                                                 </DiscreteObjectKeyFrame>
                                             </ObjectAnimationUsingKeyFrames>
                                         </Storyboard>
                                     </VisualState>
                                     <VisualState x:Name="CalendarButtonUnfocused">
                                         <Storyboard>
                                             <ObjectAnimationUsingKeyFrames Duration="0"
                                                                            Storyboard.TargetProperty="Visibility"
                                                                            Storyboard.TargetName="CalendarButtonFocusVisual">
                                                 <DiscreteObjectKeyFrame KeyTime="0">
                                                     <DiscreteObjectKeyFrame.Value>
                                                         <Visibility>Collapsed</Visibility>
                                                     </DiscreteObjectKeyFrame.Value>
                                                 </DiscreteObjectKeyFrame>
                                             </ObjectAnimationUsingKeyFrames>
                                         </Storyboard>
                                     </VisualState>
                                 </VisualStateGroup>
                             </VisualStateManager.VisualStateGroups>
                             <Rectangle x:Name="SelectedBackground"
                                        Fill="{TemplateBinding Background}"
                                        Opacity="0"
                                        RadiusY="1"
                                        RadiusX="1" />
                             <Rectangle x:Name="Background"
                                        Fill="{TemplateBinding Background}"
                                        Opacity="0"
                                        RadiusY="1"
                                        RadiusX="1" />
                             <ContentPresenter x:Name="NormalText"
                                               TextElement.Foreground="#FF333333"
                                               HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
                                               Margin="1,0,1,1"
                                               VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
                             <Rectangle x:Name="CalendarButtonFocusVisual"
                                        IsHitTestVisible="false"
                                        RadiusY="1"
                                        RadiusX="1"
                                        Stroke="#FF45D6FA"
                                        Visibility="Collapsed" />
                         </Grid>
                         <ControlTemplate.Triggers>
                             <Trigger Property="IsFocused"
                                      Value="True">
                                 <Setter Property="Visibility"
                                         TargetName="CalendarButtonFocusVisual"
                                         Value="Visible" />
                             </Trigger>
                         </ControlTemplate.Triggers>
                     </ControlTemplate>
                 </Setter.Value>
             </Setter>
         </Style>
     </Window.Resources>
 
     <Grid x:Name="LayoutRoot">
         <Calendar Style="{DynamicResource CalendarStyle1}"
                   CalendarItemStyle="{DynamicResource CalendarItemStyle1}"
                   CalendarDayButtonStyle="{DynamicResource CalendarDayButtonStyle1}"
                   CalendarButtonStyle="{DynamicResource CalendarButtonStyle1}"
            
                   Width="500"
                   Height="500">
 
         </Calendar>
     </Grid>
 
 
 
 </Window>
 

 

源文件

 

目录
相关文章
|
5月前
|
C# 开发者 Windows
一款基于Fluent设计风格、现代化的WPF UI控件库
一款基于Fluent设计风格、现代化的WPF UI控件库
124 1
|
5月前
|
开发者 C# 存储
WPF开发者必读:资源字典应用秘籍,轻松实现样式与模板共享,让你的WPF应用更上一层楼!
【8月更文挑战第31天】在WPF开发中,资源字典是一种强大的工具,用于共享样式、模板、图像等资源,提高了应用的可维护性和可扩展性。本文介绍了资源字典的基础知识、创建方法及最佳实践,并通过示例展示了如何在项目中有效利用资源字典,实现资源的重用和动态绑定。
124 0
|
5月前
|
C# 前端开发 UED
WPF数据验证实战:内置控件与自定义规则,带你玩转前端数据验证,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用开发中,数据验证是确保输入正确性的关键环节。前端验证能及时发现错误,提升用户体验和程序可靠性。本文对比了几种常用的WPF数据验证方法,并通过示例展示了如何使用内置验证控件(如`TextBox`)及自定义验证规则实现有效验证。内置控件结合`Validation`类可快速实现简单验证;自定义规则则提供了更灵活的复杂逻辑支持。希望本文能帮助开发者更好地进行WPF数据验证。
164 0
|
5月前
|
开发者 C# 存储
WPF开发者必读:样式与模板的艺术,轻松定制UI外观,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用开发中,样式与模板是实现美观界面与一致性的关键工具。样式定义了控件如字体、颜色等属性,而模板则允许自定义控件布局与子控件,两者均可存储于`.xaml`文件中。本文介绍了样式与模板的基础知识,通过示例展示了如何创建并应用它们来改变按钮的外观,从而提升用户体验。
112 0
|
5月前
|
C# UED 定位技术
WPF控件大全:初学者必读,掌握控件使用技巧,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用程序开发中,控件是实现用户界面交互的关键元素。WPF提供了丰富的控件库,包括基础控件(如`Button`、`TextBox`)、布局控件(如`StackPanel`、`Grid`)、数据绑定控件(如`ListBox`、`DataGrid`)等。本文将介绍这些控件的基本分类及使用技巧,并通过示例代码展示如何在项目中应用。合理选择控件并利用布局控件和数据绑定功能,可以提升用户体验和程序性能。
98 0
|
5月前
|
C#
WPF 自定义可拖动标题栏
WPF 自定义可拖动标题栏
60 0
|
5月前
|
存储 前端开发 C#
WPF/C#:更改界面的样式
WPF/C#:更改界面的样式
52 0
|
5月前
|
前端开发 C#
wpfui:一个开源免费具有现代化设计趋势的WPF控件库
wpfui:一个开源免费具有现代化设计趋势的WPF控件库
179 0
|
8月前
|
C# 开发者 Windows
基于Material Design风格开源、易用、强大的WPF UI控件库
基于Material Design风格开源、易用、强大的WPF UI控件库
410 0
|
8月前
|
C#
浅谈WPF之装饰器实现控件锚点
使用过visio的都知道,在绘制流程图时,当选择或鼠标移动到控件时,都会在控件的四周出现锚点,以便于修改大小,移动位置,或连接线等,那此功能是如何实现的呢?在WPF开发中,想要在控件四周实现锚点,可以通过装饰器来实现,今天通过一个简单的小例子,简述如何在WPF开发中,应用装饰器,仅供学习分享使用,如有不足之处,还请指正。
156 1