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

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

Issue 3055009: Use RenderWidget(Host) for full screen (Closed)
Patch Set: Add IPC::SyncMessage dependency. Fix auto complete. Created 10 years, 4 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
« no previous file with comments | « chrome/renderer/render_widget_fullscreen.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "chrome/renderer/render_widget_fullscreen.h"
6
7 #include "chrome/common/render_messages.h"
8 #include "chrome/renderer/render_thread.h"
9 #include "third_party/WebKit/WebKit/chromium/public/WebWidget.h"
10
11 using WebKit::WebWidget;
12
13 // static
14 RenderWidgetFullscreen* RenderWidgetFullscreen::Create(
15 int32 opener_id, RenderThreadBase* render_thread,
16 WebKit::WebPopupType popup_type) {
17 DCHECK_NE(MSG_ROUTING_NONE, opener_id);
18 scoped_refptr<RenderWidgetFullscreen> widget = new RenderWidgetFullscreen(
19 render_thread, popup_type);
20 widget->Init(opener_id);
21 return widget.release();
22 }
23
24 // static
25 WebWidget* RenderWidgetFullscreen::CreateWebWidget(
26 RenderWidgetFullscreen* render_widget) {
27 // TODO(boliu): Handle full screen render widgets here.
28 return RenderWidget::CreateWebWidget(render_widget);
29 }
30
31 void RenderWidgetFullscreen::Init(int32 opener_id) {
32 DCHECK(!webwidget_);
33
34 RenderWidget::DoInit(
35 opener_id,
36 RenderWidgetFullscreen::CreateWebWidget(this),
37 new ViewHostMsg_CreateFullscreenWidget(
38 opener_id, popup_type_, &routing_id_));
39 }
40
41 void RenderWidgetFullscreen::show(WebKit::WebNavigationPolicy) {
42 DCHECK(!did_show_) << "received extraneous Show call";
43 DCHECK_NE(MSG_ROUTING_NONE, routing_id_);
44 DCHECK_NE(MSG_ROUTING_NONE, opener_id_);
45
46 if (!did_show_) {
47 did_show_ = true;
48 Send(new ViewHostMsg_ShowFullscreenWidget(opener_id_, routing_id_));
49 SetPendingWindowRect(initial_pos_);
50 }
51 }
52
53 RenderWidgetFullscreen::RenderWidgetFullscreen(RenderThreadBase* render_thread,
54 WebKit::WebPopupType popup_type)
55 : RenderWidget(render_thread, popup_type) {
56 }
OLDNEW
« no previous file with comments | « chrome/renderer/render_widget_fullscreen.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698