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_VIEWS_WIDGET_NATIVE_WIDGET_PRIVATE_H_
6 #define UI_VIEWS_WIDGET_NATIVE_WIDGET_PRIVATE_H_
8 #include "base/strings/string16.h"
9 #include "ui/base/ui_base_types.h"
10 #include "ui/gfx/native_widget_types.h"
11 #include "ui/views/widget/native_widget.h"
29 class InputMethodDelegate
;
31 ////////////////////////////////////////////////////////////////////////////////
32 // NativeWidgetPrivate interface
34 // A NativeWidget subclass internal to views that provides Widget a conduit for
35 // communication with a backend-specific native widget implementation.
37 // Many of the methods here are pass-thrus for Widget, and as such there is no
38 // documentation for them here. In that case, see methods of the same name in
41 // IMPORTANT: This type is intended for use only by the views system and for
42 // NativeWidget implementations. This file should not be included
43 // in code that does not fall into one of these use cases.
45 class VIEWS_EXPORT NativeWidgetPrivate
: public NativeWidget
{
47 virtual ~NativeWidgetPrivate() {}
49 // Creates an appropriate default NativeWidgetPrivate implementation for the
50 // current OS/circumstance.
51 static NativeWidgetPrivate
* CreateNativeWidget(
52 internal::NativeWidgetDelegate
* delegate
);
54 static NativeWidgetPrivate
* GetNativeWidgetForNativeView(
55 gfx::NativeView native_view
);
56 static NativeWidgetPrivate
* GetNativeWidgetForNativeWindow(
57 gfx::NativeWindow native_window
);
59 // Retrieves the top NativeWidgetPrivate in the hierarchy containing the given
60 // NativeView, or NULL if there is no NativeWidgetPrivate that contains it.
61 static NativeWidgetPrivate
* GetTopLevelNativeWidget(
62 gfx::NativeView native_view
);
64 static void GetAllChildWidgets(gfx::NativeView native_view
,
65 Widget::Widgets
* children
);
66 static void GetAllOwnedWidgets(gfx::NativeView native_view
,
67 Widget::Widgets
* owned
);
68 static void ReparentNativeView(gfx::NativeView native_view
,
69 gfx::NativeView new_parent
);
71 // Returns true if any mouse button is currently down.
72 static bool IsMouseButtonDown();
74 static gfx::FontList
GetWindowTitleFontList();
76 // Initializes the NativeWidget.
77 virtual void InitNativeWidget(const Widget::InitParams
& params
) = 0;
79 // Returns a NonClientFrameView for the widget's NonClientView, or NULL if
80 // the NativeWidget wants no special NonClientFrameView.
81 virtual NonClientFrameView
* CreateNonClientFrameView() = 0;
83 virtual bool ShouldUseNativeFrame() const = 0;
84 virtual bool ShouldWindowContentsBeTransparent() const = 0;
85 virtual void FrameTypeChanged() = 0;
87 // Returns the Widget associated with this NativeWidget. This function is
88 // guaranteed to return non-NULL for the lifetime of the NativeWidget.
89 virtual Widget
* GetWidget() = 0;
90 virtual const Widget
* GetWidget() const = 0;
92 // Returns the NativeView/Window associated with this NativeWidget.
93 virtual gfx::NativeView
GetNativeView() const = 0;
94 virtual gfx::NativeWindow
GetNativeWindow() const = 0;
96 // Returns the topmost Widget in a hierarchy.
97 virtual Widget
* GetTopLevelWidget() = 0;
99 // Returns the Compositor, or NULL if there isn't one associated with this
101 virtual const ui::Compositor
* GetCompositor() const = 0;
102 virtual ui::Compositor
* GetCompositor() = 0;
104 // Returns the NativeWidget's layer, if any.
105 virtual ui::Layer
* GetLayer() = 0;
107 // Reorders the widget's child NativeViews which are associated to the view
108 // tree (eg via a NativeViewHost) to match the z-order of the views in the
109 // view tree. The z-order of views with layers relative to views with
110 // associated NativeViews is used to reorder the NativeView layers. This
111 // method assumes that the widget's child layers which are owned by a view are
112 // already in the correct z-order relative to each other and does no
113 // reordering if there are no views with an associated NativeView.
114 virtual void ReorderNativeViews() = 0;
116 // Notifies the NativeWidget that a view was removed from the Widget's view
118 virtual void ViewRemoved(View
* view
) = 0;
120 // Sets/Gets a native window property on the underlying native window object.
121 // Returns NULL if the property does not exist. Setting the property value to
122 // NULL removes the property.
123 virtual void SetNativeWindowProperty(const char* name
, void* value
) = 0;
124 virtual void* GetNativeWindowProperty(const char* name
) const = 0;
126 // Returns the native widget's tooltip manager. Called from the View hierarchy
127 // to update tooltips.
128 virtual TooltipManager
* GetTooltipManager() const = 0;
130 // Sets or releases event capturing for this native widget.
131 virtual void SetCapture() = 0;
132 virtual void ReleaseCapture() = 0;
134 // Returns true if this native widget is capturing events.
135 virtual bool HasCapture() const = 0;
137 // Returns the InputMethod for this native widget.
138 // Note that all widgets in a widget hierarchy share the same input method.
139 // TODO(suzhe): rename to GetInputMethod() when NativeWidget implementation
140 // class doesn't inherit Widget anymore.
141 virtual InputMethod
* CreateInputMethod() = 0;
143 // Returns the InputMethodDelegate for this native widget.
144 virtual InputMethodDelegate
* GetInputMethodDelegate() = 0;
146 // Returns the ui::InputMethod for this native widget.
147 // TODO(yukishiino): Rename this method to GetInputMethod once we remove
148 // views::InputMethod.
149 virtual ui::InputMethod
* GetHostInputMethod() = 0;
151 // Centers the window and sizes it to the specified size.
152 virtual void CenterWindow(const gfx::Size
& size
) = 0;
154 // Retrieves the window's current restored bounds and "show" state, for
156 virtual void GetWindowPlacement(
158 ui::WindowShowState
* show_state
) const = 0;
160 // Sets the NativeWindow title. Returns true if the title changed.
161 virtual bool SetWindowTitle(const base::string16
& title
) = 0;
163 // Sets the Window icons. |window_icon| is a 16x16 icon suitable for use in
164 // a title bar. |app_icon| is a larger size for use in the host environment
166 virtual void SetWindowIcons(const gfx::ImageSkia
& window_icon
,
167 const gfx::ImageSkia
& app_icon
) = 0;
169 // Initializes the modal type of the window to |modal_type|. Called from
170 // NativeWidgetDelegate::OnNativeWidgetCreated() before the widget is
171 // initially parented.
172 virtual void InitModalType(ui::ModalType modal_type
) = 0;
174 // See method documentation in Widget.
175 virtual gfx::Rect
GetWindowBoundsInScreen() const = 0;
176 virtual gfx::Rect
GetClientAreaBoundsInScreen() const = 0;
177 virtual gfx::Rect
GetRestoredBounds() const = 0;
178 virtual void SetBounds(const gfx::Rect
& bounds
) = 0;
179 virtual void SetSize(const gfx::Size
& size
) = 0;
180 virtual void StackAbove(gfx::NativeView native_view
) = 0;
181 virtual void StackAtTop() = 0;
182 virtual void StackBelow(gfx::NativeView native_view
) = 0;
183 virtual void SetShape(gfx::NativeRegion shape
) = 0;
184 virtual void Close() = 0;
185 virtual void CloseNow() = 0;
186 virtual void Show() = 0;
187 virtual void Hide() = 0;
188 // Invoked if the initial show should maximize the window. |restored_bounds|
189 // is the bounds of the window when not maximized.
190 virtual void ShowMaximizedWithBounds(const gfx::Rect
& restored_bounds
) = 0;
191 virtual void ShowWithWindowState(ui::WindowShowState show_state
) = 0;
192 virtual bool IsVisible() const = 0;
193 virtual void Activate() = 0;
194 virtual void Deactivate() = 0;
195 virtual bool IsActive() const = 0;
196 virtual void SetAlwaysOnTop(bool always_on_top
) = 0;
197 virtual bool IsAlwaysOnTop() const = 0;
198 virtual void SetVisibleOnAllWorkspaces(bool always_visible
) = 0;
199 virtual void Maximize() = 0;
200 virtual void Minimize() = 0;
201 virtual bool IsMaximized() const = 0;
202 virtual bool IsMinimized() const = 0;
203 virtual void Restore() = 0;
204 virtual void SetFullscreen(bool fullscreen
) = 0;
205 virtual bool IsFullscreen() const = 0;
206 virtual void SetOpacity(unsigned char opacity
) = 0;
207 virtual void SetUseDragFrame(bool use_drag_frame
) = 0;
208 virtual void FlashFrame(bool flash
) = 0;
209 virtual void RunShellDrag(View
* view
,
210 const ui::OSExchangeData
& data
,
211 const gfx::Point
& location
,
213 ui::DragDropTypes::DragEventSource source
) = 0;
214 virtual void SchedulePaintInRect(const gfx::Rect
& rect
) = 0;
215 virtual void SetCursor(gfx::NativeCursor cursor
) = 0;
216 virtual bool IsMouseEventsEnabled() const = 0;
217 virtual void ClearNativeFocus() = 0;
218 virtual gfx::Rect
GetWorkAreaBoundsInScreen() const = 0;
219 virtual Widget::MoveLoopResult
RunMoveLoop(
220 const gfx::Vector2d
& drag_offset
,
221 Widget::MoveLoopSource source
,
222 Widget::MoveLoopEscapeBehavior escape_behavior
) = 0;
223 virtual void EndMoveLoop() = 0;
224 virtual void SetVisibilityChangedAnimationsEnabled(bool value
) = 0;
225 virtual ui::NativeTheme
* GetNativeTheme() const = 0;
226 virtual void OnRootViewLayout() = 0;
227 virtual bool IsTranslucentWindowOpacitySupported() const = 0;
228 virtual void OnSizeConstraintsChanged() = 0;
230 // Repost an unhandled event to the native widget for default OS processing.
231 virtual void RepostNativeEvent(gfx::NativeEvent native_event
) = 0;
233 // Overridden from NativeWidget:
234 virtual internal::NativeWidgetPrivate
* AsNativeWidgetPrivate() override
;
237 } // namespace internal
240 #endif // UI_VIEWS_WIDGET_NATIVE_WIDGET_PRIVATE_H_