diff options
author | sky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-07 03:30:22 +0000 |
---|---|---|
committer | sky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-07 03:30:22 +0000 |
commit | 2cb5b91effa942fa165eb847c295ddc883ab70df (patch) | |
tree | 724dc900ea6f2dbfe0299506ad940bff146717df /views/widget/widget_gtk.cc | |
parent | 6d8d0e083f750fda6da6edcf8949c9d4c59a16aa (diff) | |
download | chromium_src-2cb5b91effa942fa165eb847c295ddc883ab70df.zip chromium_src-2cb5b91effa942fa165eb847c295ddc883ab70df.tar.gz chromium_src-2cb5b91effa942fa165eb847c295ddc883ab70df.tar.bz2 |
Converts info bubbles on views/gtk from popups to normal windows to
avoid the focus problems.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/246099
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28228 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'views/widget/widget_gtk.cc')
-rw-r--r-- | views/widget/widget_gtk.cc | 39 |
1 files changed, 35 insertions, 4 deletions
diff --git a/views/widget/widget_gtk.cc b/views/widget/widget_gtk.cc index 734ea02..299eea5 100644 --- a/views/widget/widget_gtk.cc +++ b/views/widget/widget_gtk.cc @@ -108,7 +108,9 @@ WidgetGtk::WidgetGtk(Type type) ignore_drag_leave_(false), opacity_(255), drag_data_(NULL), - in_paint_now_(false) { + in_paint_now_(false), + is_active_(false), + transient_to_parent_(false) { static bool installed_message_loop_observer = false; if (!installed_message_loop_observer) { installed_message_loop_observer = true; @@ -122,6 +124,8 @@ WidgetGtk::WidgetGtk(Type type) } WidgetGtk::~WidgetGtk() { + if (type_ != TYPE_CHILD) + ActiveWindowWatcherX::RemoveObserver(this); MessageLoopForUI::current()->RemoveObserver(this); } @@ -190,11 +194,37 @@ void WidgetGtk::DoDrag(const OSExchangeData& data, int operation) { drag_data_ = NULL; } +void WidgetGtk::ActiveWindowChanged(GdkWindow* active_window) { + if (!GetNativeView()) + return; + + bool was_active = IsActive(); + is_active_ = (active_window == GTK_WIDGET(GetNativeView())->window); + if (!is_active_ && active_window && type_ != TYPE_CHILD) { + // We're not active, but the force the window to be rendered as active if + // a child window is transient to us. + GtkWidget* widget = NULL; + gdk_window_get_user_data(active_window, + reinterpret_cast<gpointer*>(&widget)); + is_active_ = + (widget && GTK_IS_WINDOW(widget) && + gtk_window_get_transient_for(GTK_WINDOW(widget)) == GTK_WINDOW( + widget_)); + } + if (was_active != IsActive()) + IsActiveChanged(); +} + +void WidgetGtk::IsActiveChanged() { +} + //////////////////////////////////////////////////////////////////////////////// // WidgetGtk, Widget implementation: void WidgetGtk::Init(GtkWidget* parent, const gfx::Rect& bounds) { + if (type_ != TYPE_CHILD) + ActiveWindowWatcherX::AddObserver(this); // Force creation of the RootView if it hasn't been created yet. GetRootView(); @@ -433,9 +463,8 @@ bool WidgetGtk::IsVisible() const { } bool WidgetGtk::IsActive() const { - // If this only applies to windows, it shouldn't be in widget. - DCHECK(GTK_IS_WINDOW(widget_)); - return gtk_window_is_active(GTK_WINDOW(widget_)); + DCHECK(type_ != TYPE_CHILD); + return is_active_; } void WidgetGtk::GenerateMousePressedForView(View* view, @@ -558,6 +587,8 @@ void WidgetGtk::CreateGtkWidget(GtkWidget* parent, const gfx::Rect& bounds) { widget_ = gtk_window_new( (type_ == TYPE_WINDOW || type_ == TYPE_DECORATED_WINDOW) ? GTK_WINDOW_TOPLEVEL : GTK_WINDOW_POPUP); + if (transient_to_parent_) + gtk_window_set_transient_for(GTK_WINDOW(widget_), GTK_WINDOW(parent)); GTK_WIDGET_UNSET_FLAGS(widget_, GTK_DOUBLE_BUFFERED); if (!bounds.size().IsEmpty()) { |