diff options
| author | LukePulverenti <luke.pulverenti@gmail.com> | 2013-02-20 20:33:05 -0500 |
|---|---|---|
| committer | LukePulverenti <luke.pulverenti@gmail.com> | 2013-02-20 20:33:05 -0500 |
| commit | 767cdc1f6f6a63ce997fc9476911e2c361f9d402 (patch) | |
| tree | 49add55976f895441167c66cfa95e5c7688d18ce /MediaBrowser.UI.Controls/ExtendedButton.cs | |
| parent | 845554722efaed872948a9e0f7202e3ef52f1b6e (diff) | |
Pushing missing changes
Diffstat (limited to 'MediaBrowser.UI.Controls/ExtendedButton.cs')
| -rw-r--r-- | MediaBrowser.UI.Controls/ExtendedButton.cs | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/MediaBrowser.UI.Controls/ExtendedButton.cs b/MediaBrowser.UI.Controls/ExtendedButton.cs new file mode 100644 index 000000000..1b8e9039d --- /dev/null +++ b/MediaBrowser.UI.Controls/ExtendedButton.cs @@ -0,0 +1,49 @@ +using System.Windows; +using System.Windows.Controls; +using System.Windows.Input; + +namespace MediaBrowser.UI.Controls +{ + /// <summary> + /// This subclass simply autofocuses itself when the mouse moves over it + /// </summary> + public class ExtendedButton : Button + { + private Point? _lastMouseMovePoint; + + /// <summary> + /// Handles OnMouseMove to auto-select the item that's being moused over + /// </summary> + protected override void OnMouseMove(MouseEventArgs e) + { + base.OnMouseMove(e); + + var window = this.GetWindow(); + + // If the cursor is currently hidden, don't bother reacting to it + if (Cursor == Cursors.None || window.Cursor == Cursors.None) + { + return; + } + + // Store the last position for comparison purposes + // Even if the mouse is not moving this event will fire as elements are showing and hiding + var pos = e.GetPosition(window); + + if (!_lastMouseMovePoint.HasValue) + { + _lastMouseMovePoint = pos; + return; + } + + if (pos == _lastMouseMovePoint) + { + return; + } + + _lastMouseMovePoint = pos; + + Focus(); + } + } +} |
