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

Unified Diff: chrome/browser/viewer/viewer_process_host.cc

Issue 10984007: in-chrome viewer for metro (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: only do viewer mode when shift-F11 is pressed, for now Created 8 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/viewer/viewer_process_host.cc
diff --git a/chrome/browser/viewer/viewer_process_host.cc b/chrome/browser/viewer/viewer_process_host.cc
new file mode 100644
index 0000000000000000000000000000000000000000..d6dcb41353d573714ce815483dfd8bf0ed2efc70
--- /dev/null
+++ b/chrome/browser/viewer/viewer_process_host.cc
@@ -0,0 +1,48 @@
+// Copyright 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/viewer/viewer_process_host.h"
+
+#include "base/logging.h"
+#include "chrome/common/viewer_messages.h"
+#include "content/public/browser/browser_thread.h"
+#include "ipc/ipc_channel_proxy.h"
+#include "ui/surface/accelerated_surface_win.h"
+
+ViewerProcessHost::ViewerProcessHost() {
+ channel_.reset(new IPC::ChannelProxy(
+ // TODO(scottmg): Need to have a secure way to randomize and request
+ // this name from the viewer-side.
+ "viewer",
+ IPC::Channel::MODE_NAMED_SERVER,
+ this,
+ content::BrowserThread::GetMessageLoopProxyForThread(
+ content::BrowserThread::IO)));
+}
+
+ViewerProcessHost::~ViewerProcessHost() {
+}
+
+bool ViewerProcessHost::Send(IPC::Message* msg) {
+ return channel_->Send(msg);
+}
+
+bool ViewerProcessHost::OnMessageReceived(const IPC::Message& message) {
+ DCHECK(CalledOnValidThread());
+ bool handled = true;
+ IPC_BEGIN_MESSAGE_MAP(ViewerProcessHost, message)
+ IPC_MESSAGE_HANDLER(ViewerHostMsg_SetTargetSurface, OnSetTargetSurface)
+ IPC_MESSAGE_UNHANDLED(handled = false)
+ IPC_END_MESSAGE_MAP()
+ return handled;
+}
+
+void ViewerProcessHost::OnSetTargetSurface(uint32 target_surface) {
+ DLOG(INFO) << __FUNCTION__ << ", target_surface = " << target_surface;
+ HWND hwnd = reinterpret_cast<HWND>(target_surface);
+
+ scoped_refptr<AcceleratedPresenter> any_window =
+ AcceleratedPresenter::GetForWindow(NULL);
+ any_window->SetNewTargetWindow(hwnd);
+}

Powered by Google App Engine
This is Rietveld 408576698