From 767cdc1f6f6a63ce997fc9476911e2c361f9d402 Mon Sep 17 00:00:00 2001 From: LukePulverenti Date: Wed, 20 Feb 2013 20:33:05 -0500 Subject: Pushing missing changes --- MediaBrowser.UI.Controls/ExtendedScrollViewer.cs | 41 ++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 MediaBrowser.UI.Controls/ExtendedScrollViewer.cs (limited to 'MediaBrowser.UI.Controls/ExtendedScrollViewer.cs') diff --git a/MediaBrowser.UI.Controls/ExtendedScrollViewer.cs b/MediaBrowser.UI.Controls/ExtendedScrollViewer.cs new file mode 100644 index 000000000..c1a6f1c47 --- /dev/null +++ b/MediaBrowser.UI.Controls/ExtendedScrollViewer.cs @@ -0,0 +1,41 @@ +using System.Windows.Controls; +using System.Windows.Input; + +namespace MediaBrowser.UI.Controls +{ + /// + /// This subclass solves the problem of ScrollViewers eating KeyDown for all arrow keys + /// + public class ExtendedScrollViewer : ScrollViewer + { + protected override void OnKeyDown(KeyEventArgs e) + { + if (e.Handled || e.OriginalSource == this) + { + base.OnKeyDown(e); + return; + } + + // Don't eat left/right if horizontal scrolling is disabled + if (e.Key == Key.Left || e.Key == Key.Right) + { + if (HorizontalScrollBarVisibility == ScrollBarVisibility.Disabled) + { + return; + } + } + + // Don't eat up/down if vertical scrolling is disabled + if (e.Key == Key.Up || e.Key == Key.Down) + { + if (VerticalScrollBarVisibility == ScrollBarVisibility.Disabled) + { + return; + } + } + + // Let the base class do it's thing + base.OnKeyDown(e); + } + } +} -- cgit v1.2.3