🏆 作者简介,愚公搬代码 🏆《头衔》:华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,阿里云专家博主,腾讯云优秀博主,掘金优秀博主,51CTO博客专家等。 🏆《近期荣誉》:2022年CSDN博客之星TOP2,2022年华为云十佳博主等。 🏆《博客内容》:.NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。 🏆🎉欢迎 👍点赞✍评论⭐收藏

(文章目录)


🚀前言

WPF控件是Windows Presentation Foundation(WPF)中的基本用户界面元素。它们是可视化对象,可以用来创建各种用户界面。WPF控件可以分为两类:原生控件和自定义控件。

原生控件是由Microsoft提供的内置控件,如Button、TextBox、Label、ComboBox等。这些控件都是WPF中常见的标准用户界面元素。

自定义控件则允许开发人员使用XAML和C#等编程语言来创建个性化的用户界面元素。自定义控件可以根据需求提供更多的功能和自定义化选项,以及更好的用户体验。

🚀一、Calendar控件详解

WPF中的Calendar控件是一个显示日期和日期范围的UI控件。它可以让用户选择一个特定的日期,并且可以用于在应用程序中显示日期相关的信息。

以下是一个简单的Calendar控件代码示例:

<Calendar SelectedDate="{Binding MyDate}" DisplayDate="{Binding MyDate}" />

在这个示例中,MyDate是一个DateTime类型的属性,用于存储选定的日期。通过SelectedDate和DisplayDate属性,我们将Calendar控件绑定到这个属性,以便在用户选择新日期时更新它。

🔎1.属性介绍

WPF中Calendar控件具有以下属性:

  1. SelectedDate:获取或设置日历控件所选的日期。
  2. DisplayDate:获取或设置日历控件当前显示的日期。
  3. DisplayDateStart:获取或设置日历控件可显示的最早日期。
  4. DisplayDateEnd:获取或设置日历控件可显示的最晚日期。
  5. FirstDayOfWeek:获取或设置日历控件每周的第一天是星期几。
  6. IsTodayHighlighted:获取或设置日历控件是否突出显示当前日期。
  7. BlackoutDates:获取或设置一组日期,这些日期将在日历中被禁用。
  8. Language:获取或设置日历控件的语言。
  9. CalendarSelectionMode:获取或设置指定日历控件中可以选择的日期范围。
  10. CalendarStyle:获取或设置日历控件的样式。

🔎2.常用场景

WPF中Calendar控件常用于以下场景:

  1. 日历功能:用于选择日期或日期范围。

  2. 任务管理:用于显示任务的截止日期。

  3. 预约/日程安排:用于显示可用时间段或已安排的时间。

  4. 会议/活动管理:用于显示会议或活动的时间和日期。

  5. 日历提醒:通过设置提醒功能,可以在指定日期或时间触发提醒。

🔎3.具体案例

<Grid>
    <!--DisplayMode 默认Month   SelectionMode 默认SingleDate-->
    <Calendar Name="calDate" HorizontalAlignment="Left" Margin="117,124,0,0" VerticalAlignment="Top" Height="166" Width="190" DisplayMode="Month" DisplayDateStart="2020-5-1" DisplayDateEnd="2020-6-10"  IsTodayHighlighted="True"  SelectionMode="MultipleRange" IsTabStop="False" PreviewMouseUp="CalDate_PreviewMouseUp" />
    <TextBox Name="txtStart" HorizontalAlignment="Left" Height="23" Margin="176,65,0,0" TextWrapping="Wrap"  VerticalAlignment="Top" Width="120"/>
    <TextBox Name="txtEnd" HorizontalAlignment="Left" Height="23" Margin="340,65,0,0" TextWrapping="Wrap"  VerticalAlignment="Top" Width="120"/>
    <TextBox Name="txtSel" HorizontalAlignment="Left" Height="23" Margin="24,65,0,0" TextWrapping="Wrap"  VerticalAlignment="Top" Width="120"/>
    <Button Content="Button" HorizontalAlignment="Left" Margin="349,155,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click"/>
</Grid>
private void Calendar_SelectedDatesChanged(object sender, SelectionChangedEventArgs e)
{

    txtStart.Text = calDate.SelectedDates.First().ToShortDateString();
    txtEnd.Text = calDate.SelectedDates.Last().ToShortDateString();
    
}



private void Button_Click(object sender, RoutedEventArgs e)
{
    txtSel.Text = calDate.SelectedDate.Value.ToShortDateString();
}

private void CalDate_PreviewMouseUp(object sender, MouseButtonEventArgs e)
{

    if (Mouse.Captured is CalendarItem)
    {
        Mouse.Capture(null);
    }
}