Pin Chrome's shortcut to the Win10 Start menu on install and OS upgrade.
[chromium-blink-merge.git] / ash / sticky_keys / sticky_keys_overlay.h
blob5062636b81853caa5754c703bcadd38e944a4923
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef ASH_STICKY_KEYS_STICKY_KEYS_OVERLAY_H_
6 #define ASH_STICKY_KEYS_STICKY_KEYS_OVERLAY_H_
8 #include "ash/ash_export.h"
9 #include "ash/sticky_keys/sticky_keys_state.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "ui/compositor/layer_animation_observer.h"
12 #include "ui/events/event_constants.h"
13 #include "ui/gfx/geometry/size.h"
15 namespace gfx {
16 class Rect;
19 namespace views {
20 class Widget;
23 namespace ash {
25 class StickyKeysOverlayView;
27 // Controls the overlay UI for sticky keys, an accessibility feature allowing
28 // use of modifier keys without holding them down. This overlay will appear as
29 // a transparent window on the top left of the screen, showing the state of
30 // each sticky key modifier.
31 class ASH_EXPORT StickyKeysOverlay : public ui::LayerAnimationObserver {
32 public:
33 StickyKeysOverlay();
34 ~StickyKeysOverlay() override;
36 // Shows or hides the overlay.
37 void Show(bool visible);
39 void SetModifierVisible(ui::EventFlags modifier, bool visible);
41 bool GetModifierVisible(ui::EventFlags modifier);
43 // Updates the overlay with the current state of a sticky key modifier.
44 void SetModifierKeyState(ui::EventFlags modifier,
45 StickyKeyState state);
47 // Get the current state of the sticky key modifier in the overlay.
48 StickyKeyState GetModifierKeyState(ui::EventFlags modifier);
50 // Returns true if the overlay is currently visible. If the overlay is
51 // animating, the returned value is the target of the animation.
52 bool is_visible() { return is_visible_; }
54 // Returns the underlying views::Widget for testing purposes. The returned
55 // widget is owned by StickyKeysOverlay.
56 views::Widget* GetWidgetForTesting();
58 private:
59 // Returns the current bounds of the overlay, which is based on visibility.
60 gfx::Rect CalculateOverlayBounds();
62 // gfx::LayerAnimationObserver overrides:
63 void OnLayerAnimationEnded(ui::LayerAnimationSequence* sequence) override;
64 void OnLayerAnimationAborted(ui::LayerAnimationSequence* sequence) override;
65 void OnLayerAnimationScheduled(ui::LayerAnimationSequence* sequence) override;
67 bool is_visible_;
68 scoped_ptr<views::Widget> overlay_widget_;
69 scoped_ptr<StickyKeysOverlayView> overlay_view_;
70 gfx::Size widget_size_;
73 } // namespace ash
75 #endif // ASH_STICKY_KEYS_STICKY_KEYS_OVERLAY_H_