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 "chrome/browser/ui/gtk/zoom_bubble_gtk.h" | 5 #include "chrome/browser/ui/gtk/zoom_bubble_gtk.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/i18n/rtl.h" | 8 #include "base/i18n/rtl.h" |
9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
10 #include "base/utf_string_conversions.h" | 10 #include "base/utf_string_conversions.h" |
(...skipping 15 matching lines...) Expand all Loading... | |
26 // Number of milliseconds the bubble should stay open for if it will auto-close. | 26 // Number of milliseconds the bubble should stay open for if it will auto-close. |
27 const int kBubbleCloseDelay = 400; | 27 const int kBubbleCloseDelay = 400; |
28 | 28 |
29 // Need to manually set anchor width and height to ensure that the bubble shows | 29 // Need to manually set anchor width and height to ensure that the bubble shows |
30 // in the correct spot the first time it is displayed when no icon is present. | 30 // in the correct spot the first time it is displayed when no icon is present. |
31 const int kBubbleAnchorWidth = 20; | 31 const int kBubbleAnchorWidth = 20; |
32 const int kBubbleAnchorHeight = 25; | 32 const int kBubbleAnchorHeight = 25; |
33 } | 33 } |
34 | 34 |
35 // static | 35 // static |
36 void ZoomBubbleGtk::Show(GtkWidget* anchor, | 36 void ZoomBubbleGtk::Show(GtkWidget* anchor, Profile* profile, |
37 Profile* profile, | 37 int zoomPercent, bool autoclose) { |
Ben Goodger (Google)
2012/06/04 15:16:49
leave
Kyle Horimoto
2012/06/05 05:03:59
This was changed in my other CL and must have gott
| |
38 int zoom_percent, | |
39 bool autoclose) { | |
40 if (g_bubble) | 38 if (g_bubble) |
41 ZoomBubbleGtk::Close(); | 39 ZoomBubbleGtk::Close(); |
42 g_bubble = new ZoomBubbleGtk(anchor, profile, zoom_percent, autoclose); | 40 g_bubble = new ZoomBubbleGtk(anchor, profile, zoomPercent, autoclose); |
Ben Goodger (Google)
2012/06/04 15:16:49
leave this parameter name the way it was
Kyle Horimoto
2012/06/05 05:03:59
Same.
| |
43 } | 41 } |
44 | 42 |
45 // static | 43 // static |
46 void ZoomBubbleGtk::Close() { | 44 void ZoomBubbleGtk::Close() { |
47 if (g_bubble) | 45 if (g_bubble) |
48 g_bubble->CloseBubble(); | 46 g_bubble->CloseBubble(); |
49 } | 47 } |
50 | 48 |
51 void ZoomBubbleGtk::BubbleClosing(BubbleGtk* bubble, bool closed_by_escape) { | 49 void ZoomBubbleGtk::BubbleClosing(BubbleGtk* bubble, bool closed_by_escape) { |
52 } | 50 } |
53 | 51 |
54 void ZoomBubbleGtk::Observe(int type, | 52 void ZoomBubbleGtk::Observe(int type, |
55 const content::NotificationSource& source, | 53 const content::NotificationSource& source, |
56 const content::NotificationDetails& details) { | 54 const content::NotificationDetails& details) { |
57 DCHECK(type == chrome::NOTIFICATION_BROWSER_THEME_CHANGED); | 55 DCHECK(type == chrome::NOTIFICATION_BROWSER_THEME_CHANGED); |
58 | 56 |
59 if (theme_service_->UsingNativeTheme()) | 57 if (theme_service_->UsingNativeTheme()) |
60 gtk_widget_modify_fg(label_, GTK_STATE_NORMAL, NULL); | 58 gtk_widget_modify_fg(label_, GTK_STATE_NORMAL, NULL); |
61 else | 59 else |
62 gtk_widget_modify_fg(label_, GTK_STATE_NORMAL, &ui::kGdkBlack); | 60 gtk_widget_modify_fg(label_, GTK_STATE_NORMAL, &ui::kGdkBlack); |
63 } | 61 } |
64 | 62 |
65 ZoomBubbleGtk::ZoomBubbleGtk(GtkWidget* anchor, | 63 ZoomBubbleGtk::ZoomBubbleGtk(GtkWidget* anchor, |
66 Profile* profile, | 64 Profile* profile, |
67 int zoom_percent, | 65 int zoomPercent, |
68 bool autoclose) | 66 bool autoclose) |
69 : theme_service_(GtkThemeService::GetFrom(profile)), | 67 : theme_service_(GtkThemeService::GetFrom(profile)), |
70 factory_(this) { | 68 factory_(this) { |
71 string16 labelText = l10n_util::GetStringFUTF16Int( | 69 string16 labelText = l10n_util::GetStringFUTF16Int( |
72 IDS_ZOOM_PERCENT, zoom_percent); | 70 IDS_ZOOM_PERCENT, zoomPercent); |
73 label_ = gtk_label_new(UTF16ToUTF8(labelText).c_str()); | 71 label_ = gtk_label_new(UTF16ToUTF8(labelText).c_str()); |
74 | 72 |
75 GtkWidget* alignment = gtk_alignment_new(0, 0, 1, 1); | 73 GtkWidget* alignment = gtk_alignment_new(0, 0, 1, 1); |
76 gtk_alignment_set_padding(GTK_ALIGNMENT(alignment), 0, 0, | 74 gtk_alignment_set_padding(GTK_ALIGNMENT(alignment), 0, 0, |
77 kContentBorder, kContentBorder); | 75 kContentBorder, kContentBorder); |
78 gtk_container_add(GTK_CONTAINER(alignment), label_); | 76 gtk_container_add(GTK_CONTAINER(alignment), label_); |
79 | 77 |
80 GtkWidget* content = gtk_event_box_new(); | 78 GtkWidget* content = gtk_event_box_new(); |
81 gtk_event_box_set_visible_window(GTK_EVENT_BOX(content), TRUE); | 79 gtk_event_box_set_visible_window(GTK_EVENT_BOX(content), TRUE); |
82 gtk_container_add(GTK_CONTAINER(content), alignment); | 80 gtk_container_add(GTK_CONTAINER(content), alignment); |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
122 } | 120 } |
123 | 121 |
124 void ZoomBubbleGtk::CloseBubble() { | 122 void ZoomBubbleGtk::CloseBubble() { |
125 bubble_->Close(); | 123 bubble_->Close(); |
126 } | 124 } |
127 | 125 |
128 void ZoomBubbleGtk::OnDestroy(GtkWidget* widget) { | 126 void ZoomBubbleGtk::OnDestroy(GtkWidget* widget) { |
129 // Listen to the destroy signal and delete this instance when it is caught. | 127 // Listen to the destroy signal and delete this instance when it is caught. |
130 delete this; | 128 delete this; |
131 } | 129 } |
OLD | NEW |