1.Calendar 控件介绍
可视化的日历控件 月历显示来选择日期
2.具体案例
<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);
}
}