ozone: evdev: Sync caps lock LED state to evdev
[chromium-blink-merge.git] / ui / aura / window_delegate.h
blob1927ccd4adb11f51e9175903d6ef839082503331
1 // Copyright (c) 2012 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 UI_AURA_WINDOW_DELEGATE_H_
6 #define UI_AURA_WINDOW_DELEGATE_H_
8 #include "base/compiler_specific.h"
9 #include "base/memory/ref_counted.h"
10 #include "ui/aura/aura_export.h"
11 #include "ui/events/event_constants.h"
12 #include "ui/events/event_handler.h"
13 #include "ui/gfx/native_widget_types.h"
15 namespace gfx {
16 class Canvas;
17 class Path;
18 class Point;
19 class Rect;
20 class Size;
23 namespace ui {
24 class GestureEvent;
25 class KeyEvent;
26 class Layer;
27 class MouseEvent;
28 class TextInputClient;
29 class Texture;
30 class TouchEvent;
33 namespace aura {
35 // Delegate interface for aura::Window.
36 class AURA_EXPORT WindowDelegate : public ui::EventHandler {
37 public:
38 // Returns the window's minimum size, or size 0,0 if there is no limit.
39 virtual gfx::Size GetMinimumSize() const = 0;
41 // Returns the window's maximum size, or size 0,0 if there is no limit.
42 virtual gfx::Size GetMaximumSize() const = 0;
44 // Called when the Window's position and/or size changes.
45 virtual void OnBoundsChanged(const gfx::Rect& old_bounds,
46 const gfx::Rect& new_bounds) = 0;
48 // Returns the focused text input client within this window.
49 // This function does not look at child windows.
50 virtual ui::TextInputClient* GetFocusedTextInputClient() = 0;
52 // Returns the native cursor for the specified point, in window coordinates,
53 // or NULL for the default cursor.
54 virtual gfx::NativeCursor GetCursor(const gfx::Point& point) = 0;
56 // Returns the non-client component (see hit_test.h) containing |point|, in
57 // window coordinates.
58 virtual int GetNonClientComponent(const gfx::Point& point) const = 0;
60 // Returns true if event handling should descend into |child|. |location| is
61 // in terms of the Window.
62 virtual bool ShouldDescendIntoChildForEventHandling(
63 Window* child,
64 const gfx::Point& location) = 0;
66 // Returns true of the window can be focused.
67 virtual bool CanFocus() = 0;
69 // Invoked when mouse capture is lost on the window.
70 virtual void OnCaptureLost() = 0;
72 // Asks the delegate to paint window contents into the supplied canvas.
73 virtual void OnPaint(gfx::Canvas* canvas) = 0;
75 // Called when the window's device scale factor has changed.
76 virtual void OnDeviceScaleFactorChanged(float device_scale_factor) = 0;
78 // Called from Window's destructor before OnWindowDestroyed and before the
79 // children have been destroyed and the window has been removed from its
80 // parent.
81 // This method takes the window because the delegate implementation may no
82 // longer have a route back to the window by the time this method is called.
83 virtual void OnWindowDestroying(Window* window) = 0;
85 // Called when the Window has been destroyed (i.e. from its destructor). This
86 // is called after OnWindowDestroying and after the children have been
87 // deleted and the window has been removed from its parent.
88 // The delegate can use this as an opportunity to delete itself if necessary.
89 // This method takes the window because the delegate implementation may no
90 // longer have a route back to the window by the time this method is called.
91 virtual void OnWindowDestroyed(Window* window) = 0;
93 // Called when the TargetVisibility() of a Window changes. |visible|
94 // corresponds to the target visibility of the window. See
95 // Window::TargetVisibility() for details.
96 virtual void OnWindowTargetVisibilityChanged(bool visible) = 0;
98 // Called from Window::HitTest to check if the window has a custom hit test
99 // mask. It works similar to the views counterparts. That is, if the function
100 // returns true, GetHitTestMask below will be called to get the mask.
101 // Otherwise, Window will hit-test against its bounds.
102 virtual bool HasHitTestMask() const = 0;
104 // Called from Window::HitTest to retrieve hit test mask when HasHitTestMask
105 // above returns true.
106 virtual void GetHitTestMask(gfx::Path* mask) const = 0;
108 protected:
109 ~WindowDelegate() override {}
112 } // namespace aura
114 #endif // UI_AURA_WINDOW_DELEGATE_H_