OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2011 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 |
| 5 #ifndef UI_WAYLAND_WAYLAND_WINDOW_H_ |
| 6 #define UI_WAYLAND_WAYLAND_WINDOW_H_ |
| 7 |
| 8 #include <stdint.h> |
| 9 |
| 10 #include "base/basictypes.h" |
| 11 #include "ui/gfx/point.h" |
| 12 |
| 13 struct wl_surface; |
| 14 |
| 15 namespace ui { |
| 16 |
| 17 class WaylandDisplay; |
| 18 class WaylandWidget; |
| 19 |
| 20 // WaylandWindow wraps a wl_surface and some basic operations for the surface. |
| 21 // WaylandWindow also keeps track of the WaylandWidget that will process all |
| 22 // events related to the window. |
| 23 class WaylandWindow { |
| 24 public: |
| 25 // Creates a toplevel window. |
| 26 WaylandWindow(WaylandWidget* widget, WaylandDisplay* display); |
| 27 // Creates a transient window with an offset of (x,y) from parent. |
| 28 WaylandWindow(WaylandWidget* widget, |
| 29 WaylandDisplay* display, |
| 30 WaylandWindow* parent, |
| 31 int32_t x, |
| 32 int32_t y); |
| 33 |
| 34 ~WaylandWindow(); |
| 35 |
| 36 void SetVisible(bool visible); |
| 37 bool IsVisible() const; |
| 38 |
| 39 // Sets the window to fullscreen if |fullscreen| is true. Otherwise it sets |
| 40 // it as a normal window. |
| 41 void set_fullscreen(bool fullscreen) { fullscreen_ = fullscreen; } |
| 42 bool fullscreen() const { return fullscreen_; } |
| 43 |
| 44 // Returns a pointer to the parent window. NULL is this window doesn't have |
| 45 // a parent. |
| 46 WaylandWindow* parent_window() const { return parent_window_; } |
| 47 |
| 48 WaylandWidget* widget() const { return widget_; } |
| 49 |
| 50 // Returns the pointer to the surface associated with the window. |
| 51 // The WaylandWindow object owns the pointer. |
| 52 wl_surface* surface() const { return surface_; } |
| 53 |
| 54 void Configure(uint32_t time, uint32_t edges, int32_t x, int32_t y, |
| 55 int32_t width, int32_t height); |
| 56 |
| 57 private: |
| 58 // The widget that will process events for this window. This is not owned |
| 59 // by the window. |
| 60 WaylandWidget* widget_; |
| 61 |
| 62 // Pointer to the display this window is using. This doesn't own the pointer |
| 63 // to the display. |
| 64 WaylandDisplay* display_; |
| 65 |
| 66 // When creating a transient window, |parent_window_| is set to point to the |
| 67 // parent of this window. We will then use |parent_window_| to align this |
| 68 // window at the specified offset in |relative_position_|. |
| 69 // |parent_window_| is not owned by this window. |
| 70 WaylandWindow* parent_window_; |
| 71 |
| 72 // Position relative to parent window. This is only used by |
| 73 // a transient window. |
| 74 gfx::Point relative_position_; |
| 75 |
| 76 // The native wayland surface associated with this window. |
| 77 wl_surface* surface_; |
| 78 |
| 79 // Whether the window is in fullscreen mode. |
| 80 bool fullscreen_; |
| 81 |
| 82 DISALLOW_COPY_AND_ASSIGN(WaylandWindow); |
| 83 }; |
| 84 |
| 85 } // namespace ui |
| 86 |
| 87 #endif // UI_WAYLAND_WAYLAND_WINDOW_H_ |
OLD | NEW |