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 "content/renderer/render_widget.h" | 5 #include "content/renderer/render_widget.h" |
6 | 6 |
7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
42 #include "content/renderer/gpu/mailbox_output_surface.h" | 42 #include "content/renderer/gpu/mailbox_output_surface.h" |
43 #include "content/renderer/gpu/queue_message_swap_promise.h" | 43 #include "content/renderer/gpu/queue_message_swap_promise.h" |
44 #include "content/renderer/gpu/render_widget_compositor.h" | 44 #include "content/renderer/gpu/render_widget_compositor.h" |
45 #include "content/renderer/ime_event_guard.h" | 45 #include "content/renderer/ime_event_guard.h" |
46 #include "content/renderer/input/input_handler_manager.h" | 46 #include "content/renderer/input/input_handler_manager.h" |
47 #include "content/renderer/pepper/pepper_plugin_instance_impl.h" | 47 #include "content/renderer/pepper/pepper_plugin_instance_impl.h" |
48 #include "content/renderer/render_frame_impl.h" | 48 #include "content/renderer/render_frame_impl.h" |
49 #include "content/renderer/render_frame_proxy.h" | 49 #include "content/renderer/render_frame_proxy.h" |
50 #include "content/renderer/render_process.h" | 50 #include "content/renderer/render_process.h" |
51 #include "content/renderer/render_thread_impl.h" | 51 #include "content/renderer/render_thread_impl.h" |
| 52 #include "content/renderer/render_view_impl.h" |
52 #include "content/renderer/renderer_blink_platform_impl.h" | 53 #include "content/renderer/renderer_blink_platform_impl.h" |
53 #include "content/renderer/resizing_mode_selector.h" | 54 #include "content/renderer/resizing_mode_selector.h" |
54 #include "ipc/ipc_sync_message.h" | 55 #include "ipc/ipc_sync_message.h" |
55 #include "skia/ext/platform_canvas.h" | 56 #include "skia/ext/platform_canvas.h" |
56 #include "third_party/WebKit/public/platform/WebCursorInfo.h" | 57 #include "third_party/WebKit/public/platform/WebCursorInfo.h" |
57 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" | 58 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" |
58 #include "third_party/WebKit/public/platform/WebPoint.h" | 59 #include "third_party/WebKit/public/platform/WebPoint.h" |
59 #include "third_party/WebKit/public/platform/WebRect.h" | 60 #include "third_party/WebKit/public/platform/WebRect.h" |
60 #include "third_party/WebKit/public/platform/WebScreenInfo.h" | 61 #include "third_party/WebKit/public/platform/WebScreenInfo.h" |
61 #include "third_party/WebKit/public/platform/WebSize.h" | 62 #include "third_party/WebKit/public/platform/WebSize.h" |
(...skipping 492 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
554 } | 555 } |
555 | 556 |
556 // static | 557 // static |
557 RenderWidget* RenderWidget::CreateForFrame( | 558 RenderWidget* RenderWidget::CreateForFrame( |
558 int routing_id, | 559 int routing_id, |
559 bool hidden, | 560 bool hidden, |
560 const blink::WebScreenInfo& screen_info, | 561 const blink::WebScreenInfo& screen_info, |
561 CompositorDependencies* compositor_deps, | 562 CompositorDependencies* compositor_deps, |
562 blink::WebLocalFrame* frame) { | 563 blink::WebLocalFrame* frame) { |
563 CHECK_NE(routing_id, MSG_ROUTING_NONE); | 564 CHECK_NE(routing_id, MSG_ROUTING_NONE); |
| 565 // TODO(avi): Before RenderViewImpl has-a RenderWidget, the browser passes the |
| 566 // same routing ID for both the view routing ID and the main frame widget |
| 567 // routing ID. https://crbug.com/545684 |
| 568 RenderViewImpl* view = RenderViewImpl::FromRoutingID(routing_id); |
| 569 if (view) { |
| 570 view->AttachWebFrameWidget(RenderWidget::CreateWebFrameWidget(view, frame)); |
| 571 return view; |
| 572 } |
564 scoped_refptr<RenderWidget> widget( | 573 scoped_refptr<RenderWidget> widget( |
565 new RenderWidget(compositor_deps, blink::WebPopupTypeNone, screen_info, | 574 new RenderWidget(compositor_deps, blink::WebPopupTypeNone, screen_info, |
566 false, hidden, false)); | 575 false, hidden, false)); |
567 widget->routing_id_ = routing_id; | 576 widget->routing_id_ = routing_id; |
568 widget->for_oopif_ = true; | 577 widget->for_oopif_ = true; |
569 // DoInit increments the reference count on |widget|, keeping it alive after | 578 // DoInit increments the reference count on |widget|, keeping it alive after |
570 // this function returns. | 579 // this function returns. |
571 if (widget->DoInit(MSG_ROUTING_NONE, | 580 if (widget->DoInit(MSG_ROUTING_NONE, |
572 RenderWidget::CreateWebFrameWidget(widget.get(), frame), | 581 RenderWidget::CreateWebFrameWidget(widget.get(), frame), |
573 nullptr)) { | 582 nullptr)) { |
574 return widget.get(); | 583 return widget.get(); |
575 } | 584 } |
576 return nullptr; | 585 return nullptr; |
577 } | 586 } |
578 | 587 |
579 // static | 588 // static |
580 blink::WebWidget* RenderWidget::CreateWebFrameWidget( | 589 blink::WebWidget* RenderWidget::CreateWebFrameWidget( |
581 RenderWidget* render_widget, | 590 RenderWidget* render_widget, |
582 blink::WebLocalFrame* frame) { | 591 blink::WebLocalFrame* frame) { |
| 592 if (!frame->parent()) { |
| 593 // TODO(dcheng): The main frame widget currently has a special case. |
| 594 // Eliminate this once WebView is no longer a WebWidget. |
| 595 return blink::WebFrameWidget::create(render_widget, frame->view(), frame); |
| 596 } |
583 return blink::WebFrameWidget::create(render_widget, frame); | 597 return blink::WebFrameWidget::create(render_widget, frame); |
584 } | 598 } |
585 | 599 |
586 // static | 600 // static |
587 blink::WebWidget* RenderWidget::CreateWebWidget(RenderWidget* render_widget) { | 601 blink::WebWidget* RenderWidget::CreateWebWidget(RenderWidget* render_widget) { |
588 switch (render_widget->popup_type_) { | 602 switch (render_widget->popup_type_) { |
589 case blink::WebPopupTypeNone: // Nothing to create. | 603 case blink::WebPopupTypeNone: // Nothing to create. |
590 break; | 604 break; |
591 case blink::WebPopupTypePage: | 605 case blink::WebPopupTypePage: |
592 return WebPagePopup::create(render_widget); | 606 return WebPagePopup::create(render_widget); |
(...skipping 1789 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2382 void RenderWidget::RegisterVideoHoleFrame(RenderFrameImpl* frame) { | 2396 void RenderWidget::RegisterVideoHoleFrame(RenderFrameImpl* frame) { |
2383 video_hole_frames_.AddObserver(frame); | 2397 video_hole_frames_.AddObserver(frame); |
2384 } | 2398 } |
2385 | 2399 |
2386 void RenderWidget::UnregisterVideoHoleFrame(RenderFrameImpl* frame) { | 2400 void RenderWidget::UnregisterVideoHoleFrame(RenderFrameImpl* frame) { |
2387 video_hole_frames_.RemoveObserver(frame); | 2401 video_hole_frames_.RemoveObserver(frame); |
2388 } | 2402 } |
2389 #endif // defined(VIDEO_HOLE) | 2403 #endif // defined(VIDEO_HOLE) |
2390 | 2404 |
2391 } // namespace content | 2405 } // namespace content |
OLD | NEW |