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

Side by Side Diff: chrome/renderer/render_widget_fullscreen.cc

Issue 3352019: Add fullscreen support to Pepper. (Closed) Base URL: git://git.chromium.org/chromium.git
Patch Set: git cl tree Created 10 years, 3 months 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
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/renderer/render_widget_fullscreen.h" 5 #include "chrome/renderer/render_widget_fullscreen.h"
6 6
7 #include "chrome/common/render_messages.h" 7 #include "chrome/common/render_messages.h"
8 #include "chrome/renderer/render_thread.h" 8 #include "chrome/renderer/render_thread.h"
9 #include "third_party/WebKit/WebKit/chromium/public/WebWidget.h" 9 #include "third_party/WebKit/WebKit/chromium/public/WebWidget.h"
10 10
11 using WebKit::WebWidget; 11 using WebKit::WebWidget;
12 12
13 // static 13 // static
14 RenderWidgetFullscreen* RenderWidgetFullscreen::Create( 14 RenderWidgetFullscreen* RenderWidgetFullscreen::Create(
15 int32 opener_id, RenderThreadBase* render_thread, 15 int32 opener_id, RenderThreadBase* render_thread,
16 WebKit::WebPopupType popup_type) { 16 WebKit::WebPopupType popup_type) {
17 DCHECK_NE(MSG_ROUTING_NONE, opener_id); 17 DCHECK_NE(MSG_ROUTING_NONE, opener_id);
18 scoped_refptr<RenderWidgetFullscreen> widget = new RenderWidgetFullscreen( 18 scoped_refptr<RenderWidgetFullscreen> widget = new RenderWidgetFullscreen(
19 render_thread, popup_type); 19 render_thread, popup_type);
20 widget->Init(opener_id); 20 widget->Init(opener_id);
21 return widget.release(); 21 return widget.release();
22 } 22 }
23 23
24 // static 24 WebWidget* RenderWidgetFullscreen::CreateWebWidget() {
25 WebWidget* RenderWidgetFullscreen::CreateWebWidget(
26 RenderWidgetFullscreen* render_widget) {
27 // TODO(boliu): Handle full screen render widgets here. 25 // TODO(boliu): Handle full screen render widgets here.
28 return RenderWidget::CreateWebWidget(render_widget); 26 return RenderWidget::CreateWebWidget(this);
29 } 27 }
30 28
31 void RenderWidgetFullscreen::Init(int32 opener_id) { 29 void RenderWidgetFullscreen::Init(int32 opener_id) {
32 DCHECK(!webwidget_); 30 DCHECK(!webwidget_);
33 31
34 RenderWidget::DoInit( 32 RenderWidget::DoInit(
35 opener_id, 33 opener_id,
36 RenderWidgetFullscreen::CreateWebWidget(this), 34 CreateWebWidget(),
37 new ViewHostMsg_CreateFullscreenWidget( 35 new ViewHostMsg_CreateFullscreenWidget(
38 opener_id, popup_type_, &routing_id_)); 36 opener_id, popup_type_, &routing_id_));
39 } 37 }
40 38
41 void RenderWidgetFullscreen::show(WebKit::WebNavigationPolicy) { 39 void RenderWidgetFullscreen::show(WebKit::WebNavigationPolicy) {
42 DCHECK(!did_show_) << "received extraneous Show call"; 40 DCHECK(!did_show_) << "received extraneous Show call";
43 DCHECK_NE(MSG_ROUTING_NONE, routing_id_); 41 DCHECK_NE(MSG_ROUTING_NONE, routing_id_);
44 DCHECK_NE(MSG_ROUTING_NONE, opener_id_); 42 DCHECK_NE(MSG_ROUTING_NONE, opener_id_);
45 43
46 if (!did_show_) { 44 if (!did_show_) {
47 did_show_ = true; 45 did_show_ = true;
48 Send(new ViewHostMsg_ShowFullscreenWidget(opener_id_, routing_id_)); 46 Send(new ViewHostMsg_ShowFullscreenWidget(opener_id_, routing_id_));
49 SetPendingWindowRect(initial_pos_); 47 SetPendingWindowRect(initial_pos_);
50 } 48 }
51 } 49 }
52 50
53 RenderWidgetFullscreen::RenderWidgetFullscreen(RenderThreadBase* render_thread, 51 RenderWidgetFullscreen::RenderWidgetFullscreen(RenderThreadBase* render_thread,
54 WebKit::WebPopupType popup_type) 52 WebKit::WebPopupType popup_type)
55 : RenderWidget(render_thread, popup_type) { 53 : RenderWidget(render_thread, popup_type) {
56 } 54 }
OLDNEW
« no previous file with comments | « chrome/renderer/render_widget_fullscreen.h ('k') | chrome/renderer/render_widget_fullscreen_pepper.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698