 Chromium Code Reviews
 Chromium Code Reviews Issue 2665203005:
  Gtk3: Fix gn_all compile  (Closed)
    
  
    Issue 2665203005:
  Gtk3: Fix gn_all compile  (Closed) 
  | OLD | NEW | 
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 <gtk/gtk.h> | 5 #include <gtk/gtk.h> | 
| 6 #include <math.h> | 6 #include <math.h> | 
| 7 | 7 | 
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" | 
| 9 #include "base/logging.h" | 9 #include "base/logging.h" | 
| 10 #include "base/macros.h" | 10 #include "base/macros.h" | 
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 47 GtkWidget* button_; | 47 GtkWidget* button_; | 
| 48 | 48 | 
| 49 // Used to distinguish resize events from other types of "configure-event" | 49 // Used to distinguish resize events from other types of "configure-event" | 
| 50 // notifications. | 50 // notifications. | 
| 51 int current_width_; | 51 int current_width_; | 
| 52 int current_height_; | 52 int current_height_; | 
| 53 | 53 | 
| 54 DISALLOW_COPY_AND_ASSIGN(DisconnectWindowGtk); | 54 DISALLOW_COPY_AND_ASSIGN(DisconnectWindowGtk); | 
| 55 }; | 55 }; | 
| 56 | 56 | 
| 57 #if GTK_MAJOR_VERSION == 2 | |
| 57 // Helper function for creating a rectangular path with rounded corners, as | 58 // Helper function for creating a rectangular path with rounded corners, as | 
| 58 // Cairo doesn't have this facility. |radius| is the arc-radius of each | 59 // Cairo doesn't have this facility. |radius| is the arc-radius of each | 
| 59 // corner. The bounding rectangle extends from (0, 0) to (width, height). | 60 // corner. The bounding rectangle extends from (0, 0) to (width, height). | 
| 60 void AddRoundRectPath(cairo_t* cairo_context, int width, int height, | 61 void AddRoundRectPath(cairo_t* cairo_context, int width, int height, | 
| 61 int radius) { | 62 int radius) { | 
| 62 cairo_new_sub_path(cairo_context); | 63 cairo_new_sub_path(cairo_context); | 
| 63 cairo_arc(cairo_context, width - radius, radius, radius, -M_PI_2, 0); | 64 cairo_arc(cairo_context, width - radius, radius, radius, -M_PI_2, 0); | 
| 64 cairo_arc(cairo_context, width - radius, height - radius, radius, 0, M_PI_2); | 65 cairo_arc(cairo_context, width - radius, height - radius, radius, 0, M_PI_2); | 
| 65 cairo_arc(cairo_context, radius, height - radius, radius, M_PI_2, 2 * M_PI_2); | 66 cairo_arc(cairo_context, radius, height - radius, radius, M_PI_2, 2 * M_PI_2); | 
| 66 cairo_arc(cairo_context, radius, radius, radius, 2 * M_PI_2, 3 * M_PI_2); | 67 cairo_arc(cairo_context, radius, radius, radius, 2 * M_PI_2, 3 * M_PI_2); | 
| 67 cairo_close_path(cairo_context); | 68 cairo_close_path(cairo_context); | 
| 68 } | 69 } | 
| 70 #endif | |
| 69 | 71 | 
| 70 DisconnectWindowGtk::DisconnectWindowGtk() | 72 DisconnectWindowGtk::DisconnectWindowGtk() | 
| 71 : disconnect_window_(nullptr), | 73 : disconnect_window_(nullptr), | 
| 72 current_width_(0), | 74 current_width_(0), | 
| 73 current_height_(0) { | 75 current_height_(0) { | 
| 74 } | 76 } | 
| 75 | 77 | 
| 76 DisconnectWindowGtk::~DisconnectWindowGtk() { | 78 DisconnectWindowGtk::~DisconnectWindowGtk() { | 
| 77 DCHECK(CalledOnValidThread()); | 79 DCHECK(CalledOnValidThread()); | 
| 78 | 80 | 
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 131 G_CALLBACK(OnButtonPressThunk), this); | 133 G_CALLBACK(OnButtonPressThunk), this); | 
| 132 | 134 | 
| 133 // All magic numbers taken from screen shots provided by UX. | 135 // All magic numbers taken from screen shots provided by UX. | 
| 134 // The alignment sets narrow margins at the top and bottom, compared with | 136 // The alignment sets narrow margins at the top and bottom, compared with | 
| 135 // left and right. The left margin is made larger to accommodate the | 137 // left and right. The left margin is made larger to accommodate the | 
| 136 // window movement gripper. | 138 // window movement gripper. | 
| 137 GtkWidget* align = gtk_alignment_new(0, 0, 1, 1); | 139 GtkWidget* align = gtk_alignment_new(0, 0, 1, 1); | 
| 138 gtk_alignment_set_padding(GTK_ALIGNMENT(align), 8, 8, 24, 12); | 140 gtk_alignment_set_padding(GTK_ALIGNMENT(align), 8, 8, 24, 12); | 
| 139 gtk_container_add(GTK_CONTAINER(window), align); | 141 gtk_container_add(GTK_CONTAINER(window), align); | 
| 140 | 142 | 
| 143 #if GTK_MAJOR_VERSION == 2 | |
| 141 GtkWidget* button_row = gtk_hbox_new(FALSE, 12); | 144 GtkWidget* button_row = gtk_hbox_new(FALSE, 12); | 
| 145 #else | |
| 146 GtkWidget* button_row = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 12); | |
| 147 gtk_box_set_homogeneous(GTK_BOX(button_row), FALSE); | |
| 148 #endif | |
| 142 gtk_container_add(GTK_CONTAINER(align), button_row); | 149 gtk_container_add(GTK_CONTAINER(align), button_row); | 
| 143 | 150 | 
| 144 button_ = gtk_button_new_with_label( | 151 button_ = gtk_button_new_with_label( | 
| 145 l10n_util::GetStringUTF8(IDS_STOP_SHARING_BUTTON).c_str()); | 152 l10n_util::GetStringUTF8(IDS_STOP_SHARING_BUTTON).c_str()); | 
| 146 gtk_box_pack_end(GTK_BOX(button_row), button_, FALSE, FALSE, 0); | 153 gtk_box_pack_end(GTK_BOX(button_row), button_, FALSE, FALSE, 0); | 
| 147 | 154 | 
| 148 g_signal_connect(button_, "clicked", G_CALLBACK(OnClickedThunk), this); | 155 g_signal_connect(button_, "clicked", G_CALLBACK(OnClickedThunk), this); | 
| 149 | 156 | 
| 150 message_ = gtk_label_new(nullptr); | 157 message_ = gtk_label_new(nullptr); | 
| 151 gtk_box_pack_end(GTK_BOX(button_row), message_, FALSE, FALSE, 0); | 158 gtk_box_pack_end(GTK_BOX(button_row), message_, FALSE, FALSE, 0); | 
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 190 GdkEventConfigure* event) { | 197 GdkEventConfigure* event) { | 
| 191 DCHECK(CalledOnValidThread()); | 198 DCHECK(CalledOnValidThread()); | 
| 192 | 199 | 
| 193 // Only generate bitmaps if the size has actually changed. | 200 // Only generate bitmaps if the size has actually changed. | 
| 194 if (event->width == current_width_ && event->height == current_height_) | 201 if (event->width == current_width_ && event->height == current_height_) | 
| 195 return FALSE; | 202 return FALSE; | 
| 196 | 203 | 
| 197 current_width_ = event->width; | 204 current_width_ = event->width; | 
| 198 current_height_ = event->height; | 205 current_height_ = event->height; | 
| 199 | 206 | 
| 207 #if GTK_MAJOR_VERSION == 2 | |
| 
Tom (Use chromium acct)
2017/02/01 00:02:42
We can just let gtk draw the window background, ri
 
Sergey Ulanov
2017/02/02 00:42:49
I don't think we want to omit this code. This code
 | |
| 200 // Create the depth 1 pixmap for the window shape. | 208 // Create the depth 1 pixmap for the window shape. | 
| 201 GdkPixmap* shape_mask = | 209 GdkPixmap* shape_mask = | 
| 202 gdk_pixmap_new(nullptr, current_width_, current_height_, 1); | 210 gdk_pixmap_new(nullptr, current_width_, current_height_, 1); | 
| 203 cairo_t* cairo_context = gdk_cairo_create(shape_mask); | 211 cairo_t* cairo_context = gdk_cairo_create(shape_mask); | 
| 204 | 212 | 
| 205 // Set the arc radius for the corners. | 213 // Set the arc radius for the corners. | 
| 206 const int kCornerRadius = 6; | 214 const int kCornerRadius = 6; | 
| 207 | 215 | 
| 208 // Initialize the whole bitmap to be transparent. | 216 // Initialize the whole bitmap to be transparent. | 
| 209 cairo_set_source_rgba(cairo_context, 0, 0, 0, 0); | 217 cairo_set_source_rgba(cairo_context, 0, 0, 0, 0); | 
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 263 x += 3; | 271 x += 3; | 
| 264 cairo_move_to(cairo_context, x, gripper_top); | 272 cairo_move_to(cairo_context, x, gripper_top); | 
| 265 cairo_line_to(cairo_context, x, gripper_bottom); | 273 cairo_line_to(cairo_context, x, gripper_bottom); | 
| 266 cairo_stroke(cairo_context); | 274 cairo_stroke(cairo_context); | 
| 267 | 275 | 
| 268 cairo_destroy(cairo_context); | 276 cairo_destroy(cairo_context); | 
| 269 | 277 | 
| 270 gdk_window_set_back_pixmap(widget->window, background, FALSE); | 278 gdk_window_set_back_pixmap(widget->window, background, FALSE); | 
| 271 g_object_unref(background); | 279 g_object_unref(background); | 
| 272 gdk_window_invalidate_rect(widget->window, nullptr, TRUE); | 280 gdk_window_invalidate_rect(widget->window, nullptr, TRUE); | 
| 281 #endif | |
| 273 | 282 | 
| 274 return FALSE; | 283 return FALSE; | 
| 275 } | 284 } | 
| 276 | 285 | 
| 277 gboolean DisconnectWindowGtk::OnButtonPress(GtkWidget* widget, | 286 gboolean DisconnectWindowGtk::OnButtonPress(GtkWidget* widget, | 
| 278 GdkEventButton* event) { | 287 GdkEventButton* event) { | 
| 279 DCHECK(CalledOnValidThread()); | 288 DCHECK(CalledOnValidThread()); | 
| 280 | 289 | 
| 281 gtk_window_begin_move_drag(GTK_WINDOW(disconnect_window_), | 290 gtk_window_begin_move_drag(GTK_WINDOW(disconnect_window_), | 
| 282 event->button, | 291 event->button, | 
| 283 event->x_root, | 292 event->x_root, | 
| 284 event->y_root, | 293 event->y_root, | 
| 285 event->time); | 294 event->time); | 
| 286 return FALSE; | 295 return FALSE; | 
| 287 } | 296 } | 
| 288 | 297 | 
| 289 } // namespace | 298 } // namespace | 
| 290 | 299 | 
| 291 // static | 300 // static | 
| 292 std::unique_ptr<HostWindow> HostWindow::CreateDisconnectWindow() { | 301 std::unique_ptr<HostWindow> HostWindow::CreateDisconnectWindow() { | 
| 293 return base::MakeUnique<DisconnectWindowGtk>(); | 302 return base::MakeUnique<DisconnectWindowGtk>(); | 
| 294 } | 303 } | 
| 295 | 304 | 
| 296 } // namespace remoting | 305 } // namespace remoting | 
| OLD | NEW |