diff options
author | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 13:02:25 -0700 |
---|---|---|
committer | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 16:13:41 -0700 |
commit | 17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch) | |
tree | b5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs | |
download | xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2 xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip |
Initial import
Diffstat (limited to 'Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs')
-rw-r--r-- | Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs b/Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs new file mode 100644 index 00000000..3aa5fdca --- /dev/null +++ b/Xamarin.Forms.Platform.WinRT/TimePickerRenderer.cs @@ -0,0 +1,75 @@ +using System; +using System.ComponentModel; +using Windows.UI.Xaml.Controls; + +#if WINDOWS_UWP + +namespace Xamarin.Forms.Platform.UWP +#else + +namespace Xamarin.Forms.Platform.WinRT +#endif +{ + public class TimePickerRenderer : ViewRenderer<TimePicker, FormsTimePicker>, IWrapperAware + { + public void NotifyWrapped() + { + if (Control != null) + { + Control.ForceInvalidate += PickerOnForceInvalidate; + } + } + + protected override void Dispose(bool disposing) + { + if (disposing && Control != null) + { + Control.ForceInvalidate -= PickerOnForceInvalidate; + Control.TimeChanged -= OnControlTimeChanged; + } + + base.Dispose(disposing); + } + + protected override void OnElementChanged(ElementChangedEventArgs<TimePicker> e) + { + if (e.NewElement != null) + { + if (Control == null) + { + var picker = new FormsTimePicker(); + picker.TimeChanged += OnControlTimeChanged; + SetNativeControl(picker); + } + + UpdateTime(); + } + + base.OnElementChanged(e); + } + + protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e) + { + base.OnElementPropertyChanged(sender, e); + + if (e.PropertyName == TimePicker.TimeProperty.PropertyName) + UpdateTime(); + } + + void OnControlTimeChanged(object sender, TimePickerValueChangedEventArgs e) + { + Element.Time = e.NewTime; + Element?.InvalidateMeasure(InvalidationTrigger.SizeRequestChanged); + } + + void PickerOnForceInvalidate(object sender, EventArgs eventArgs) + { + Element?.InvalidateMeasure(InvalidationTrigger.SizeRequestChanged); + } + + void UpdateTime() + { + Control.Time = Element.Time; + } + } +}
\ No newline at end of file |