WPF C#DatePicker单击打开日历

问题描述 投票:3回答:3

我正在向表单添加WPF DatePicker控件,它可以正常工作。但是我不希望用户能够在“选择日期”文本框中输入类型。我希望它是只读的,当他们单击文本框时,它只是打开日历。

我不确定属性中是否有此选项?我什么也找不到...

c# wpf wpf-controls
3个回答
4
投票
<DatePicker HorizontalAlignment="Left" VerticalAlignment="Top">
    <DatePicker.Resources>
        <Style TargetType="DatePickerTextBox">
            <Setter Property="IsReadOnly" Value="True"/>
            <Setter Property="Text" Value=" "/>
            <Setter Property="Focusable" Value="False"/>
            <Setter Property="IsEnabled" Value="False" />
            <Setter Property="IsHitTestVisible" Value="False"/>
        </Style>
    </DatePicker.Resources>
</DatePicker>

[将来,您可以使用WPF可视化工具查看顶级控件正在使用哪个子控件(在本例中为DatePickerTextBox),然后像我在此处所做的那样,在资源部分中对该类型应用样式和/或模板。


2
投票

Mark Feldman的回答部分正确,他没有回答如何单击文本框来打开日历弹出窗口!

您应该钩住DatePicker的模板并扩大按钮的大小,以使其与文本框重叠:然后,您完成了,当您单击文本框时,是获得事件的按钮,请参见下面的部分。修改后的DatePicker模板:

<DatePickerTextBox Grid.Row="0"  Grid.Column="0" x:Name="PART_TextBox" Focusable="{TemplateBinding Focusable}" HorizontalContentAlignment="Stretch" VerticalContentAlignment="Stretch"/>
<Button Grid.Row="0"  Grid.Column="0" x:Name="PART_Button"  Foreground="{TemplateBinding Foreground}" Focusable="False" >
    <Button.Template>
        <ControlTemplate>
            <Grid>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="*"/>
                    <ColumnDefinition Width="Auto"/>
                </Grid.ColumnDefinitions>
                <Border Background="Transparent"/>
                <Button Grid.Column="1" HorizontalAlignment="Left" Foreground="{TemplateBinding Foreground}" Template="{StaticResource DropDownButtonTemplate}"  VerticalAlignment="Top" Width="20" Margin="3,0,3,0" />
            </Grid>
        </ControlTemplate>
    </Button.Template>
</Button>

不要忘记添加马克·费尔德曼答案中描述的DatePickerTextBox样式


1
投票

您可以通过这种方式打开日历:

<DatePicker Name="datePicker" Focusable="False">
     <DatePicker.Resources>
          <Style TargetType="DatePickerTextBox">
                <EventSetter Event="MouseLeftButtonUp" Handler="OnMouseLeftButtonUp" />
          </Style>
     </DatePicker.Resources>
</DatePicker>
private void OnMouseLeftButtonUp(object sender, RoutedEventArgs e)
{
    datePicker.IsDropDownOpen = true;
}
© www.soinside.com 2019 - 2024. All rights reserved.