diff options
author | erg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-23 23:53:21 +0000 |
---|---|---|
committer | erg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-23 23:53:21 +0000 |
commit | 9fe6464530f957ed38be9edc7a6d0cc47ab5b2df (patch) | |
tree | 45e1cfe10eafd6edcee02473d9e950c7a3ada0cc /chrome | |
parent | 7cc4ad1d9f0cdae224af53eb29272d1bfca64df3 (diff) | |
download | chromium_src-9fe6464530f957ed38be9edc7a6d0cc47ab5b2df.zip chromium_src-9fe6464530f957ed38be9edc7a6d0cc47ab5b2df.tar.gz chromium_src-9fe6464530f957ed38be9edc7a6d0cc47ab5b2df.tar.bz2 |
Clear out the vbox before adding a new widget.
This prevents the weird issue where gtk tries to pack both views into the box.
It isn't optimal, though. This solution leaves the area blank since it clears
the old renderer as soon as the new one is created instead of waiting until
the new renderer has something to display.
Review URL: http://codereview.chromium.org/27057
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@10223 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r-- | chrome/browser/renderer_host/render_widget_host_view_gtk.cc | 31 | ||||
-rw-r--r-- | chrome/browser/tab_contents/web_contents_view_gtk.cc | 10 |
2 files changed, 28 insertions, 13 deletions
diff --git a/chrome/browser/renderer_host/render_widget_host_view_gtk.cc b/chrome/browser/renderer_host/render_widget_host_view_gtk.cc index 6c38c00..c955abc 100644 --- a/chrome/browser/renderer_host/render_widget_host_view_gtk.cc +++ b/chrome/browser/renderer_host/render_widget_host_view_gtk.cc @@ -291,20 +291,25 @@ void RenderWidgetHostViewGtk::Paint(const gfx::Rect& damage_rect) { damage_rect.width(), damage_rect.height() }; + + // Only render the widget if it is attached to a window; there's a short + // period where this object isn't attached to a window but hasn't been + // Destroy()ed yet and it receives paint messages... GdkWindow* window = view_->window; - DCHECK(window) << "Trying to impossibly paint object " << view_; - - gdk_window_begin_paint_rect(window, &grect); - - skia::PlatformDeviceLinux &platdev = - backing_store->canvas()->getTopPlatformDevice(); - skia::BitmapPlatformDeviceLinux* const bitdev = - static_cast<skia::BitmapPlatformDeviceLinux* >(&platdev); - cairo_t* cairo_drawable = gdk_cairo_create(window); - cairo_set_source_surface(cairo_drawable, bitdev->surface(), 0, 0); - cairo_paint(cairo_drawable); - cairo_destroy(cairo_drawable); - gdk_window_end_paint(window); + if (window) { + gdk_window_begin_paint_rect(window, &grect); + + skia::PlatformDeviceLinux &platdev = + backing_store->canvas()->getTopPlatformDevice(); + skia::BitmapPlatformDeviceLinux* const bitdev = + static_cast<skia::BitmapPlatformDeviceLinux* >(&platdev); + cairo_t* cairo_drawable = gdk_cairo_create(window); + cairo_set_source_surface(cairo_drawable, bitdev->surface(), 0, 0); + cairo_paint(cairo_drawable); + cairo_destroy(cairo_drawable); + gdk_window_end_paint(window); + } + } else { NOTIMPLEMENTED(); } diff --git a/chrome/browser/tab_contents/web_contents_view_gtk.cc b/chrome/browser/tab_contents/web_contents_view_gtk.cc index 3dd3ec3..c63d2bf 100644 --- a/chrome/browser/tab_contents/web_contents_view_gtk.cc +++ b/chrome/browser/tab_contents/web_contents_view_gtk.cc @@ -12,6 +12,15 @@ #include "chrome/browser/renderer_host/render_widget_host_view_gtk.h" #include "chrome/browser/tab_contents/web_contents.h" +namespace { + +// Callback used in WebContentsViewGtk::CreateViewForWidget(). +void RemoveWidget(GtkWidget* widget, void* container) { + gtk_container_remove(GTK_CONTAINER(container), widget); +} + +} // namespace + // static WebContentsView* WebContentsView::Create(WebContents* web_contents) { return new WebContentsViewGtk(web_contents); @@ -40,6 +49,7 @@ RenderWidgetHostView* WebContentsViewGtk::CreateViewForWidget( RenderWidgetHostViewGtk* view = new RenderWidgetHostViewGtk(render_widget_host); gtk_widget_show(view->native_view()); + gtk_container_foreach(GTK_CONTAINER(vbox_), RemoveWidget, vbox_); gtk_box_pack_start(GTK_BOX(vbox_), view->native_view(), TRUE, TRUE, 0); return view; } |