WPF 自定义DateTimePicker(带时分秒选择)

大家好,好久不写博客了,这几天比较闲在,想了想把最近学习WPF和项目中用到的一些控件啊和知识分享给大家。

在项目中我们经常用到时间选择器,winfrom中就有datetimepicker这个控件,但是wpf中只能选择到天,不能选择时分秒,在网上找了半天也没有发现一个合适的,于是准备自己写一个,但是呢自己写又觉得可能不是很美观就想着从GitHub上找一个模板来自己改一下,我在GitHub上边是这样搜索的:

然后选择关于C#的那一栏,然后就开始了漫长的寻找之旅.........

最终,我找到了一个还算比较合适的,那么马上进行修改吧。(我用的那个是哪个我也忘了,有知道的小伙伴记得留言告诉我,我在博客中加上人家的GitHub地址) 

  • 首先在vs你的项目中创建一个关于自定义控件的类库,并添加如下引用(一定要引用全,不然会报错的):
  • 第二步,把从GitHub上下载下来的项目提取你需要的那一部分(哈哈,感觉有点无耻),这个DateTimePicker文件夹下的就是咱们所需要的了:

    下面的图就是整个的组成:

    DateTimePicker.xaml 其实就是一个文本框,然后点击文本框使用pop弹出TDateTimeView.xaml

  • 第三步,对DateTimePicker.xaml进行修改,因为在项目中引用咱们肯定是只用DateTimePicker.xaml的,所以要对DateTimePicker.xaml的一些属性进行修改来符合咱们的使用条件,有可能也需要加到一些新功能。因为我们项目时MVVM架构的,所以获得时间的值-DateTimeStr 是不能传递给咱们的后台的,所以需要把DateTimeStr改为依赖属性(这个网上都是有的)

    /// <summary>
    /// 日期时间
    /// </summary>
    public string DateTimeStr
    {
       get { return (string)GetValue(DateTimeProperty); }
       set { SetValue(DateTimeProperty, value); }
    }
    // Using a DependencyProperty as the backing store for DateTimeText.  This enables animation, styling, binding, etc...
    public static readonly DependencyProperty DateTimeProperty =
                DependencyProperty.Register("DateTimeStr", typeof(string), typeof(DateTimePicker));

    有时候呢,咱们可能也需要时间改变后能通知后台进行一些操作,这就需要用到命令,原来的DateTimePicker.xaml用的是TextBlock这个文本框,咱们需要改成TextBox 因为这个文本框有TextChanged这个事件,咱们可以通过这个事件来触发时间更改的命令,下边是添加的命令和TextChanged事件触发后的方法:

    public ICommand TimeChangeCommand
            {
                get { return (ICommand)GetValue(TimeChangeCommandProperty); }
                set { SetValue(TimeChangeCommandProperty, value); }
            }
    
            // Using a DependencyProperty as the backing store for SearchCommand.  This enables animation, styling, binding, etc...
            public static readonly DependencyProperty TimeChangeCommandProperty =
                DependencyProperty.Register("TimeChangeCommand", typeof(ICommand), typeof(DateTimePicker), new PropertyMetadata(null));
    
    /// <summary>
            /// The delete event
            /// </summary>
            public static readonly RoutedEvent TimeTextChangedEvent =
                 EventManager.RegisterRoutedEvent("TimeTextChanged", RoutingStrategy.Bubble, typeof(RoutedEventHandler), typeof(DateTimePicker));
    
            /// <summary>
            /// 时间改变的操作.
            /// </summary>
            public event RoutedEventHandler TimeTextChanged
            {
                add
                {
                    AddHandler(TimeTextChangedEvent, value);
                }
    
                remove
                {
                    RemoveHandler(TimeTextChangedEvent, value);
                }
            }
    
    public void TimeTextChanged_Click(object sender, TextChangedEventArgs e)
            {
                ButtonAutomationPeer bam = new ButtonAutomationPeer(TimeChangeBtn);
                IInvokeProvider iip = bam.GetPattern(PatternInterface.Invoke) as IInvokeProvider;
                iip.Invoke();
            }

因为DateTimePicker.xaml只有一个文本框不是很美观也不能突出他是一个DateTimePicker的选择器,所以咱们在文本框的末尾加一个时间选择器的小图标,这个图标的路径使用的是你引用这个自定义控件的项目下的路径,这个要注意。

至此,咱们这个时间选择器就修改完了,让我们在项目中使用来体验一下,具体的使用方式我在demo里都写好了,项目的源代码我放在了文章的末尾,是用VS2013编译的,需要自取哦,如果解决了你的问题的话记得给我点个赞,富裕的大佬记得给个赞赏(此时脸皮贼厚)。

下载地址:WPF_DateTimePicker.zip - 蓝奏云


推荐一个开源的wpf控件库 handycontrol,上边的时间控件和其他控件更好,有需要的可以去看看

DateTimePicker 日期时间选择器 | HandyOrg

  • 34
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 26
    评论
### 回答1: WPF是一种强大的UI框架,它提供了许多控件,其中包括时间选择器控件。但是,由于在特定的应用程序中,需要自定义时间选择器以满足一些个性化需求。在这种情况下,可以使用WPF自定义控件来创建自己的时间选择器控件。 首先,在WPF中创建时间选择器控件,需要使用Calendar控件和TimePicker控件。Calendar控件用于显示日期,而TimePicker控件用于选择时间。时间选择器控件的主体是StackPanel控件。在StackPanel控件中添加了两个控件Calendar和TimePicker,以实现时间选择器的基本功能。 然后,需要在时间选择器控件中定义一些附加属性,例如:选定日期、选定时间等等,以实现一些高级功能。 最后,为时间选择器控件添加样式,并实现一些触发器和动画效果,以使其外观和功能与应用程序的主题相匹配。 实现WPF自定义时间选择器可能需要一些时间和经验,但对于需要一个不寻常的时间选择器的应用程序来说,是值得的。 这样的时间选择器是用户友好的,具有很好的设计和功能,并且以C#编写,可以很容易地与WPF应用程序集成。 ### 回答2: WPF自定义时间选择器是一种功能强大、灵活性高的工具,它可以根据需求自行设计不同的选择器,可以实现小时、分钟、秒数的选择等多种功能。 首先,我们需要使用WPFDatePicker控件和TimePicker控件来实现时间选择器。接下来,我们可以自定义控件的样式和模板,使其更符合我们的设计需求。 在自定义控件的样式时,我们需要设置控件的各个属性,比如控件的边框、背景、字体等。同时,我们可以通过设置样式来调整控件的布局和显示效果。 在时间选择器的实现中,需要涉及到一些比较复杂的计算,比如计算时间的差值、时间的格式转换等。我们可以使用C#中的DateTime类和TimeSpan类来实现这些功能。 最后对于自定义时间选择器的控件事件,需要自定义一些控件事件,使其更加符合我们的设计需求。比如增加或减少系统时钟里的时间。 总而言之,实现WPF自定义时间选择器需要对WPF控件、样式、模板、计算和控件事件等各个方面有深入的了解。只有掌握了这些知识,才能够设计出优秀的时间选择器,满足用户的需求。
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值