Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(230)

Side by Side Diff: chrome/browser/renderer_host/render_widget_host_view_views.cc

Issue 4319003: Replace TabContentsViewGtk with TabContentsViewViews as part of the ongoing (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Last patchset was missing canvas_direct2d.cc edit, fixed it and sent to try bots. Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 "chrome/browser/renderer_host/render_widget_host_view_views.h" 5 #include "chrome/browser/renderer_host/render_widget_host_view_views.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <string> 8 #include <string>
9 9
10 #include "app/keyboard_code_conversion_gtk.h" 10 #include "app/keyboard_code_conversion_gtk.h"
11 #include "app/l10n_util.h" 11 #include "app/l10n_util.h"
12 #include "app/x11_util.h" 12 #include "app/x11_util.h"
13 #include "base/command_line.h" 13 #include "base/command_line.h"
14 #include "base/logging.h" 14 #include "base/logging.h"
15 #include "base/message_loop.h" 15 #include "base/message_loop.h"
16 #include "base/metrics/histogram.h" 16 #include "base/metrics/histogram.h"
17 #include "base/string_number_conversions.h" 17 #include "base/string_number_conversions.h"
18 #include "base/task.h" 18 #include "base/task.h"
19 #include "base/time.h" 19 #include "base/time.h"
20 #include "chrome/browser/renderer_host/backing_store_x.h" 20 #include "chrome/browser/renderer_host/backing_store_x.h"
21 #include "chrome/browser/renderer_host/gpu_view_host.h" 21 #include "chrome/browser/renderer_host/gpu_view_host.h"
22 #include "chrome/browser/renderer_host/render_widget_host.h" 22 #include "chrome/browser/renderer_host/render_widget_host.h"
23 #include "chrome/browser/renderer_host/video_layer_x.h" 23 #include "chrome/browser/renderer_host/video_layer_x.h"
24 #include "chrome/common/chrome_switches.h" 24 #include "chrome/common/chrome_switches.h"
25 #include "chrome/common/native_web_keyboard_event.h" 25 #include "chrome/common/native_web_keyboard_event.h"
26 #include "chrome/common/render_messages.h" 26 #include "chrome/common/render_messages.h"
27 #include "gfx/canvas.h"
27 #include "third_party/WebKit/WebKit/chromium/public/gtk/WebInputEventFactory.h" 28 #include "third_party/WebKit/WebKit/chromium/public/gtk/WebInputEventFactory.h"
28 #include "third_party/WebKit/WebKit/chromium/public/WebInputEvent.h" 29 #include "third_party/WebKit/WebKit/chromium/public/WebInputEvent.h"
29 #include "views/event.h" 30 #include "views/event.h"
30 #include "views/widget/widget.h" 31 #include "views/widget/widget.h"
31 32
32 static const int kMaxWindowWidth = 4000; 33 static const int kMaxWindowWidth = 4000;
33 static const int kMaxWindowHeight = 4000; 34 static const int kMaxWindowHeight = 4000;
34 static const char* kRenderWidgetHostViewKey = "__RENDER_WIDGET_HOST_VIEW__"; 35 static const char* kRenderWidgetHostViewKey = "__RENDER_WIDGET_HOST_VIEW__";
35 36
36 using WebKit::WebInputEventFactory; 37 using WebKit::WebInputEventFactory;
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
124 GetRenderWidgetHost()->WasHidden(); 125 GetRenderWidgetHost()->WasHidden();
125 } 126 }
126 127
127 void RenderWidgetHostViewViews::SetSize(const gfx::Size& size) { 128 void RenderWidgetHostViewViews::SetSize(const gfx::Size& size) {
128 // This is called when webkit has sent us a Move message. 129 // This is called when webkit has sent us a Move message.
129 int width = std::min(size.width(), kMaxWindowWidth); 130 int width = std::min(size.width(), kMaxWindowWidth);
130 int height = std::min(size.height(), kMaxWindowHeight); 131 int height = std::min(size.height(), kMaxWindowHeight);
131 if (requested_size_.width() != width || 132 if (requested_size_.width() != width ||
132 requested_size_.height() != height) { 133 requested_size_.height() != height) {
133 requested_size_ = gfx::Size(width, height); 134 requested_size_ = gfx::Size(width, height);
134 SetBounds(GetViewBounds()); 135 SetBounds(gfx::Rect(x(), y(), width, height));
135 host_->WasResized(); 136 host_->WasResized();
136 } 137 }
137 } 138 }
138 139
139 void RenderWidgetHostViewViews::MovePluginWindows( 140 void RenderWidgetHostViewViews::MovePluginWindows(
140 const std::vector<webkit_glue::WebPluginGeometry>& moves) { 141 const std::vector<webkit_glue::WebPluginGeometry>& moves) {
141 // TODO(anicolao): NIY 142 // TODO(anicolao): NIY
142 NOTIMPLEMENTED(); 143 NOTIMPLEMENTED();
143 } 144 }
144 145
(...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after
279 } 280 }
280 return gpu_view_host_->CreateBackingStore(size); 281 return gpu_view_host_->CreateBackingStore(size);
281 } 282 }
282 283
283 return new BackingStoreX(host_, size, 284 return new BackingStoreX(host_, size,
284 x11_util::GetVisualFromGtkWidget(native_view()), 285 x11_util::GetVisualFromGtkWidget(native_view()),
285 gtk_widget_get_visual(native_view())->depth); 286 gtk_widget_get_visual(native_view())->depth);
286 } 287 }
287 288
288 gfx::NativeView RenderWidgetHostViewViews::native_view() const { 289 gfx::NativeView RenderWidgetHostViewViews::native_view() const {
289 return GetWidget()->GetNativeView(); 290 if (GetWidget())
291 return GetWidget()->GetNativeView();
292 return NULL;
290 } 293 }
291 294
292 VideoLayer* RenderWidgetHostViewViews::AllocVideoLayer(const gfx::Size& size) { 295 VideoLayer* RenderWidgetHostViewViews::AllocVideoLayer(const gfx::Size& size) {
293 if (enable_gpu_rendering_) { 296 if (enable_gpu_rendering_) {
294 // TODO(scherkus): is it possible for a video layer to be allocated before a 297 // TODO(scherkus): is it possible for a video layer to be allocated before a
295 // backing store? 298 // backing store?
296 DCHECK(gpu_view_host_.get()) 299 DCHECK(gpu_view_host_.get())
297 << "AllocVideoLayer() called before AllocBackingStore()"; 300 << "AllocVideoLayer() called before AllocBackingStore()";
298 return gpu_view_host_->CreateVideoLayer(size); 301 return gpu_view_host_->CreateVideoLayer(size);
299 } 302 }
300 303
301 return new VideoLayerX(host_, size, 304 return new VideoLayerX(host_, size,
302 x11_util::GetVisualFromGtkWidget(native_view()), 305 x11_util::GetVisualFromGtkWidget(native_view()),
303 gtk_widget_get_visual(native_view())->depth); 306 gtk_widget_get_visual(native_view())->depth);
304 } 307 }
305 308
306 void RenderWidgetHostViewViews::SetBackground(const SkBitmap& background) { 309 void RenderWidgetHostViewViews::SetBackground(const SkBitmap& background) {
307 RenderWidgetHostView::SetBackground(background); 310 RenderWidgetHostView::SetBackground(background);
308 host_->Send(new ViewMsg_SetBackground(host_->routing_id(), background)); 311 host_->Send(new ViewMsg_SetBackground(host_->routing_id(), background));
309 } 312 }
310 313
311 void RenderWidgetHostViewViews::Paint(gfx::Canvas* canvas) { 314 void RenderWidgetHostViewViews::Paint(gfx::Canvas* canvas) {
315 if (is_hidden_) {
316 return;
317 }
318
319 // Paint a "hole" in the canvas so that the render of the web page is on
320 // top of whatever else has already been painted in the views hierarchy.
321 // Later views might still get to paint on top.
322 canvas->FillRectInt(SK_ColorBLACK, 0, 0, kMaxWindowWidth, kMaxWindowHeight,
323 SkXfermode::kClear_Mode);
324
312 if (enable_gpu_rendering_) { 325 if (enable_gpu_rendering_) {
313 // When we're proxying painting, we don't actually display the web page 326 // When we're proxying painting, we don't actually display the web page
314 // ourselves. 327 // ourselves.
315 if (gpu_view_host_.get()) 328 if (gpu_view_host_.get())
316 gpu_view_host_->OnWindowPainted(); 329 gpu_view_host_->OnWindowPainted();
317 330
318 // Erase the background. This will prevent a flash of black when resizing 331 // Erase the background. This will prevent a flash of black when resizing
319 // or exposing the window. White is usually better than black. 332 // or exposing the window. White is usually better than black.
320 return; 333 return;
321 } 334 }
322 335
323 // Don't do any painting if the GPU process is rendering directly 336 // Don't do any painting if the GPU process is rendering directly
324 // into the View. 337 // into the View.
325 RenderWidgetHost* render_widget_host = GetRenderWidgetHost(); 338 RenderWidgetHost* render_widget_host = GetRenderWidgetHost();
326 if (render_widget_host->is_gpu_rendering_active()) { 339 if (render_widget_host->is_gpu_rendering_active()) {
327 return; 340 return;
328 } 341 }
329 342
330 GdkWindow* window = native_view()->window; 343 GdkWindow* window = native_view()->window;
331 DCHECK(!about_to_validate_and_paint_); 344 DCHECK(!about_to_validate_and_paint_);
332 345
333 // TODO(anicolao): get the damage somehow 346 // TODO(anicolao): get the damage somehow
334 // invalid_rect_ = damage_rect; 347 // invalid_rect_ = damage_rect;
335 invalid_rect_ = bounds(); 348 invalid_rect_ = bounds();
349 gfx::Point origin;
350 ConvertPointToWidget(this, &origin);
351
336 about_to_validate_and_paint_ = true; 352 about_to_validate_and_paint_ = true;
337 BackingStoreX* backing_store = static_cast<BackingStoreX*>( 353 BackingStoreX* backing_store = static_cast<BackingStoreX*>(
338 host_->GetBackingStore(true)); 354 host_->GetBackingStore(true));
339 // Calling GetBackingStore maybe have changed |invalid_rect_|... 355 // Calling GetBackingStore maybe have changed |invalid_rect_|...
340 about_to_validate_and_paint_ = false; 356 about_to_validate_and_paint_ = false;
341 357
342 gfx::Rect paint_rect = gfx::Rect(0, 0, kMaxWindowWidth, kMaxWindowHeight); 358 gfx::Rect paint_rect = gfx::Rect(0, 0, kMaxWindowWidth, kMaxWindowHeight);
343 paint_rect = paint_rect.Intersect(invalid_rect_); 359 paint_rect = paint_rect.Intersect(invalid_rect_);
344 360
345 if (backing_store) { 361 if (backing_store) {
346 // Only render the widget if it is attached to a window; there's a short 362 // Only render the widget if it is attached to a window; there's a short
347 // period where this object isn't attached to a window but hasn't been 363 // period where this object isn't attached to a window but hasn't been
348 // Destroy()ed yet and it receives paint messages... 364 // Destroy()ed yet and it receives paint messages...
349 if (window) { 365 if (window) {
350 if (!visually_deemphasized_) { 366 if (!visually_deemphasized_) {
351 // In the common case, use XCopyArea. We don't draw more than once, so 367 // In the common case, use XCopyArea. We don't draw more than once, so
352 // we don't need to double buffer. 368 // we don't need to double buffer.
353 backing_store->XShowRect( 369 backing_store->XShowRect(origin,
354 paint_rect, x11_util::GetX11WindowFromGtkWidget(native_view())); 370 paint_rect, x11_util::GetX11WindowFromGtkWidget(native_view()));
355 371
356 // Paint the video layer using XCopyArea. 372 // Paint the video layer using XCopyArea.
357 // TODO(scherkus): implement VideoLayerX::CairoShow() for grey 373 // TODO(scherkus): implement VideoLayerX::CairoShow() for grey
358 // blending. 374 // blending.
359 VideoLayerX* video_layer = static_cast<VideoLayerX*>( 375 VideoLayerX* video_layer = static_cast<VideoLayerX*>(
360 host_->video_layer()); 376 host_->video_layer());
361 if (video_layer) 377 if (video_layer)
362 video_layer->XShow( 378 video_layer->XShow(
363 x11_util::GetX11WindowFromGtkWidget(native_view())); 379 x11_util::GetX11WindowFromGtkWidget(native_view()));
(...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after
523 } 539 }
524 #endif 540 #endif
525 541
526 ShowCurrentCursor(); 542 ShowCurrentCursor();
527 GetRenderWidgetHost()->GotFocus(); 543 GetRenderWidgetHost()->GotFocus();
528 } 544 }
529 545
530 void RenderWidgetHostViewViews::WillLoseFocus() { 546 void RenderWidgetHostViewViews::WillLoseFocus() {
531 // If we are showing a context menu, maintain the illusion that webkit has 547 // If we are showing a context menu, maintain the illusion that webkit has
532 // focus. 548 // focus.
533 if (!is_showing_context_menu_) 549 if (!is_showing_context_menu_ && !is_hidden_)
534 GetRenderWidgetHost()->Blur(); 550 GetRenderWidgetHost()->Blur();
535 } 551 }
536 552
537 553
538 void RenderWidgetHostViewViews::ShowCurrentCursor() { 554 void RenderWidgetHostViewViews::ShowCurrentCursor() {
539 // The widget may not have a window. If that's the case, abort mission. This 555 // The widget may not have a window. If that's the case, abort mission. This
540 // is the same issue as that explained above in Paint(). 556 // is the same issue as that explained above in Paint().
541 if (!native_view()->window) 557 if (!native_view() || !native_view()->window)
542 return; 558 return;
543 559
544 // TODO(anicolao): change to set cursors without GTK 560 // TODO(anicolao): change to set cursors without GTK
545 } 561 }
546 562
547 void RenderWidgetHostViewViews::CreatePluginContainer( 563 void RenderWidgetHostViewViews::CreatePluginContainer(
548 gfx::PluginWindowHandle id) { 564 gfx::PluginWindowHandle id) {
549 // TODO(anicolao): plugin_container_manager_.CreatePluginContainer(id); 565 // TODO(anicolao): plugin_container_manager_.CreatePluginContainer(id);
550 } 566 }
551 567
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
614 } 630 }
615 631
616 // static 632 // static
617 RenderWidgetHostView* 633 RenderWidgetHostView*
618 RenderWidgetHostView::GetRenderWidgetHostViewFromNativeView( 634 RenderWidgetHostView::GetRenderWidgetHostViewFromNativeView(
619 gfx::NativeView widget) { 635 gfx::NativeView widget) {
620 gpointer user_data = g_object_get_data(G_OBJECT(widget), 636 gpointer user_data = g_object_get_data(G_OBJECT(widget),
621 kRenderWidgetHostViewKey); 637 kRenderWidgetHostViewKey);
622 return reinterpret_cast<RenderWidgetHostView*>(user_data); 638 return reinterpret_cast<RenderWidgetHostView*>(user_data);
623 } 639 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698