OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "gfx/gtk_preserve_window.h" | 5 #include "gfx/gtk_preserve_window.h" |
6 | 6 |
7 #include <gdk/gdkwindow.h> | 7 #include <gdk/gdkwindow.h> |
8 #include <gtk/gtk.h> | 8 #include <gtk/gtk.h> |
9 #include <gtk/gtkwidget.h> | 9 #include <gtk/gtkwidget.h> |
10 #include <gtk/gtkfixed.h> | 10 #include <gtk/gtkfixed.h> |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
54 // These widgets always have their own window. | 54 // These widgets always have their own window. |
55 gtk_fixed_set_has_window(GTK_FIXED(widget), TRUE); | 55 gtk_fixed_set_has_window(GTK_FIXED(widget), TRUE); |
56 } | 56 } |
57 | 57 |
58 GtkWidget* gtk_preserve_window_new() { | 58 GtkWidget* gtk_preserve_window_new() { |
59 return GTK_WIDGET(g_object_new(GTK_TYPE_PRESERVE_WINDOW, NULL)); | 59 return GTK_WIDGET(g_object_new(GTK_TYPE_PRESERVE_WINDOW, NULL)); |
60 } | 60 } |
61 | 61 |
62 static void gtk_preserve_window_destroy(GtkObject* object) { | 62 static void gtk_preserve_window_destroy(GtkObject* object) { |
63 GtkWidget* widget = reinterpret_cast<GtkWidget*>(object); | 63 GtkWidget* widget = reinterpret_cast<GtkWidget*>(object); |
| 64 GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
64 | 65 |
65 if (widget->window) { | 66 if (widget->window) { |
66 gdk_window_set_user_data(widget->window, NULL); | 67 gdk_window_set_user_data(widget->window, NULL); |
67 gdk_window_destroy(widget->window); | 68 // If the window is preserved, someone else must destroy it. |
| 69 if (!priv->preserve_window) |
| 70 gdk_window_destroy(widget->window); |
68 widget->window = NULL; | 71 widget->window = NULL; |
69 } | 72 } |
70 | 73 |
71 GTK_OBJECT_CLASS(gtk_preserve_window_parent_class)->destroy(object); | 74 GTK_OBJECT_CLASS(gtk_preserve_window_parent_class)->destroy(object); |
72 } | 75 } |
73 | 76 |
74 static void gtk_preserve_window_realize(GtkWidget* widget) { | 77 static void gtk_preserve_window_realize(GtkWidget* widget) { |
75 g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); | 78 g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); |
76 | 79 |
77 if (widget->window) { | 80 if (widget->window) { |
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
160 | 163 |
161 attributes.window_type = GDK_WINDOW_CHILD; | 164 attributes.window_type = GDK_WINDOW_CHILD; |
162 attributes.wclass = GDK_INPUT_OUTPUT; | 165 attributes.wclass = GDK_INPUT_OUTPUT; |
163 | 166 |
164 attributes.visual = gtk_widget_get_visual(widget); | 167 attributes.visual = gtk_widget_get_visual(widget); |
165 attributes.colormap = gtk_widget_get_colormap(widget); | 168 attributes.colormap = gtk_widget_get_colormap(widget); |
166 | 169 |
167 attributes_mask = GDK_WA_VISUAL | GDK_WA_COLORMAP; | 170 attributes_mask = GDK_WA_VISUAL | GDK_WA_COLORMAP; |
168 widget->window = gdk_window_new( | 171 widget->window = gdk_window_new( |
169 gdk_get_default_root_window(), &attributes, attributes_mask); | 172 gdk_get_default_root_window(), &attributes, attributes_mask); |
| 173 } else if (!value && widget->window && !GTK_WIDGET_REALIZED(widget)) { |
| 174 gdk_window_destroy(widget->window); |
| 175 widget->window = NULL; |
170 } | 176 } |
171 } | 177 } |
172 | 178 |
173 void gtk_preserve_window_size_allocate(GtkWidget* widget, | 179 void gtk_preserve_window_size_allocate(GtkWidget* widget, |
174 GtkAllocation* allocation) { | 180 GtkAllocation* allocation) { |
175 g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); | 181 g_return_if_fail(GTK_IS_PRESERVE_WINDOW(widget)); |
176 GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); | 182 GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
177 | 183 |
178 if (priv->delegate_resize) { | 184 if (priv->delegate_resize) { |
179 // Just update the state. Someone else will gdk_window_resize the | 185 // Just update the state. Someone else will gdk_window_resize the |
180 // associated GdkWindow. | 186 // associated GdkWindow. |
181 widget->allocation = *allocation; | 187 widget->allocation = *allocation; |
182 } else { | 188 } else { |
183 GTK_WIDGET_CLASS(gtk_preserve_window_parent_class)->size_allocate( | 189 GTK_WIDGET_CLASS(gtk_preserve_window_parent_class)->size_allocate( |
184 widget, allocation); | 190 widget, allocation); |
185 } | 191 } |
186 } | 192 } |
187 | 193 |
188 void gtk_preserve_window_delegate_resize(GtkPreserveWindow* widget, | 194 void gtk_preserve_window_delegate_resize(GtkPreserveWindow* widget, |
189 gboolean delegate) { | 195 gboolean delegate) { |
190 GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); | 196 GtkPreserveWindowPrivate* priv = GTK_PRESERVE_WINDOW_GET_PRIVATE(widget); |
191 priv->delegate_resize = delegate; | 197 priv->delegate_resize = delegate; |
192 } | 198 } |
193 | 199 |
194 G_END_DECLS | 200 G_END_DECLS |
OLD | NEW |