blob: 1819405fb4b9b065689a4f1ee4dabdbc5e4f2597 [file] [log] [blame]
[email protected]41d9faf2012-02-28 23:46:021// 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.
4
[email protected]5f39adc2013-05-23 11:50:465#ifndef UI_BASE_BASE_WINDOW_H_
6#define UI_BASE_BASE_WINDOW_H_
[email protected]41d9faf2012-02-28 23:46:027
8#include "base/compiler_specific.h"
[email protected]68eeede2013-05-09 06:10:579#include "ui/base/ui_base_types.h" // WindowShowState
[email protected]764864e2012-06-11 19:16:1610#include "ui/gfx/native_widget_types.h"
[email protected]41d9faf2012-02-28 23:46:0211
12namespace gfx {
13class Rect;
14}
15
[email protected]1443fe82012-04-02 08:48:0316class SkRegion;
17
[email protected]5f39adc2013-05-23 11:50:4618namespace ui {
[email protected]41d9faf2012-02-28 23:46:0219
[email protected]5f39adc2013-05-23 11:50:4620// Provides an interface to perform actions on windows, and query window
21// state.
[email protected]9552c2d2014-01-06 02:05:3222class UI_BASE_EXPORT BaseWindow {
[email protected]41d9faf2012-02-28 23:46:0223 public:
24 // Returns true if the window is currently the active/focused window.
25 virtual bool IsActive() const = 0;
26
27 // Returns true if the window is maximized (aka zoomed).
28 virtual bool IsMaximized() const = 0;
29
30 // Returns true if the window is minimized.
31 virtual bool IsMinimized() const = 0;
32
[email protected]c80ed692012-04-18 19:51:1033 // Returns true if the window is full screen.
34 virtual bool IsFullscreen() const = 0;
35
[email protected]b954da472013-08-27 00:20:1736 // Returns true if the window is fully restored (not Fullscreen, Maximized,
37 // Minimized).
38 static bool IsRestored(const BaseWindow& window);
39
[email protected]764864e2012-06-11 19:16:1640 // Return a platform dependent identifier for this window.
yozf5067252014-11-05 22:10:1141 virtual gfx::NativeWindow GetNativeWindow() const = 0;
[email protected]764864e2012-06-11 19:16:1642
[email protected]41d9faf2012-02-28 23:46:0243 // Returns the nonmaximized bounds of the window (even if the window is
44 // currently maximized or minimized) in terms of the screen coordinates.
45 virtual gfx::Rect GetRestoredBounds() const = 0;
46
[email protected]68eeede2013-05-09 06:10:5747 // Returns the restore state for the window (platform dependent).
48 virtual ui::WindowShowState GetRestoredState() const = 0;
49
[email protected]41d9faf2012-02-28 23:46:0250 // Retrieves the window's current bounds, including its window.
51 // This will only differ from GetRestoredBounds() for maximized
52 // and minimized windows.
53 virtual gfx::Rect GetBounds() const = 0;
54
55 // Shows the window, or activates it if it's already visible.
56 virtual void Show() = 0;
57
[email protected]7d412f72012-10-25 04:59:1558 // Hides the window.
59 virtual void Hide() = 0;
60
[email protected]41d9faf2012-02-28 23:46:0261 // Show the window, but do not activate it. Does nothing if window
62 // is already visible.
63 virtual void ShowInactive() = 0;
64
65 // Closes the window as soon as possible. The close action may be delayed
66 // if an operation is in progress (e.g. a drag operation).
67 virtual void Close() = 0;
68
69 // Activates (brings to front) the window. Restores the window from minimized
70 // state if necessary.
71 virtual void Activate() = 0;
72
73 // Deactivates the window, making the next window in the Z order the active
74 // window.
75 virtual void Deactivate() = 0;
76
77 // Maximizes/minimizes/restores the window.
78 virtual void Maximize() = 0;
79 virtual void Minimize() = 0;
80 virtual void Restore() = 0;
81
82 // Sets the window's size and position to the specified values.
83 virtual void SetBounds(const gfx::Rect& bounds) = 0;
84
85 // Flashes the taskbar item associated with this window.
86 // Set |flash| to true to initiate flashing, false to stop flashing.
87 virtual void FlashFrame(bool flash) = 0;
[email protected]d101b0c2012-03-16 00:30:5788
89 // Returns true if a window is set to be always on top.
90 virtual bool IsAlwaysOnTop() const = 0;
[email protected]46d46052013-10-11 11:27:2291
92 // If set to true, the window will stay on top of other windows which do not
93 // have this flag enabled.
94 virtual void SetAlwaysOnTop(bool always_on_top) = 0;
[email protected]41d9faf2012-02-28 23:46:0295};
96
[email protected]5f39adc2013-05-23 11:50:4697} // namespace ui
98
99#endif // UI_BASE_BASE_WINDOW_H_