前一段时间,自己搞了个TimePicker控件。 为了方便在工控机上使用,在选择时间时仿照手机上时间的选择做了个可以触摸滚动的效果。
当前选择的时间实现了一个依赖属性SelectedTime。这个属性的类型是我自己定义的一个Time类型。这个类是仿照DateTime实现的,虽然没有全部实现DateTime 的功能把。目前满足我的需求。
然后如果想要使用这个控件,可以将一个Time类型的变量绑定到这个SelectedTime属性。
选中时间后为了方便与程序中其他逻辑做通信。实现了Command和CommandParameter。这个Command在时间修改后将触发。可以将一些选中事件后需要做的操作放到一个你自己定义的Command中,并将这个Command绑定到这个Command上。
下面这是我做的控件,主体样式是仿照WPF自带的DateTimePicker做的。
下面是一些关键代码
/// <summary>
/// 获取或设置Command的值
/// </summary>
public ICommand Command
{
get { return (ICommand)GetValue(CommandProperty); }
set { SetValue(CommandProperty, value); }
}
/// <summary>
/// 获取或设置CommandParameter的值
/// </summary>
public object CommandParameter
{
get { return (object)GetValue(CommandParameterProperty); }
set { SetValue(CommandParameterProperty, value); }
}
public static readonly DependencyProperty CommandProperty =
DependencyProperty.Register("Command", typeof(ICommand), typeof(TimePicker), new PropertyMetadata(null, OnCommandChanged));
public static readonly DependencyProperty CommandParameterProperty =
DependencyProperty.Register("CommandParameter",typeof(object),typeof(TimePicker),new PropertyMetadata(null, OnCommandParameterCallback));
private static void OnCommandChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
}
private static void OnCommandParameterCallback(DependencyObject d,DependencyPropertyChangedEventArgs e)
{
}
Phone_TimePicker dtView = new Phone_TimePicker(textBlock1.Text);// TDateTimeView 构造函数传入时间
dtView.TimeChange += (dateTimeStr) => //TDateTimeView 时间确定事件
{
SelectedTime = Time.StringToTime(dateTimeStr);
textBlock1.Text = SelectedTime.ToString("yyyy-MM-dd");
popChioce.IsOpen = false;//TDateTimeView 所在pop 关闭
Command.Execute(CommandParameter);
};
Command.Execute(CommandParameter);
这条代码是很关键的,将他放到需要触发Command执行的位置即可。如果CommandParameter
没有的话可以将这个函数传入一个null。
这个TimePicker控件稍后将上传