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

Side by Side Diff: blimp/client/core/render_widget/blimp_document.cc

Issue 2400923002: Move BlimpInputManager to BlimpDocument from BlimpCompositor. (Closed)
Patch Set: Removed unnecessary DCHECK. Created 4 years, 2 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "blimp/client/core/render_widget/blimp_document.h" 5 #include "blimp/client/core/render_widget/blimp_document.h"
6 6
7 #include "base/threading/thread_task_runner_handle.h"
8 #include "blimp/client/core/compositor/blimp_compositor_dependencies.h"
9 #include "blimp/client/core/input/blimp_input_manager.h"
7 #include "blimp/client/core/render_widget/blimp_document_manager.h" 10 #include "blimp/client/core/render_widget/blimp_document_manager.h"
8 #include "cc/layers/layer.h" 11 #include "cc/layers/layer.h"
9 12
10 namespace blimp { 13 namespace blimp {
11 namespace client { 14 namespace client {
12 15
13 BlimpDocument::BlimpDocument(int document_id, 16 BlimpDocument::BlimpDocument(int document_id,
14 BlimpCompositorDependencies* compositor_deps, 17 BlimpCompositorDependencies* compositor_deps,
15 BlimpDocumentManager* document_manager) 18 BlimpDocumentManager* document_manager)
16 : document_id_(document_id), manager_(document_manager) { 19 : BlimpDocument(document_id,
17 compositor_ = base::MakeUnique<BlimpCompositor>(compositor_deps, this); 20 base::MakeUnique<BlimpCompositor>(compositor_deps, this),
21 compositor_deps,
22 document_manager) {}
23
24 BlimpDocument::BlimpDocument(int document_id,
25 std::unique_ptr<BlimpCompositor> compositor,
26 BlimpCompositorDependencies* compositor_deps,
27 BlimpDocumentManager* document_manager)
28 : document_id_(document_id),
29 compositor_(std::move(compositor)),
30 manager_(document_manager) {
31 input_manager_ =
32 BlimpInputManager::Create(this, base::ThreadTaskRunnerHandle::Get(),
33 compositor_deps->GetCompositorTaskRunner(),
34 compositor_->GetInputHandler());
18 } 35 }
19 36
20 BlimpDocument::~BlimpDocument() = default; 37 BlimpDocument::~BlimpDocument() {
38 compositor_.reset();
39
40 // Destroy the old input manager state.
41 // It is important to destroy the LayerTreeHost before destroying the input
42 // manager as it has a reference to the cc::InputHandlerClient owned by the
43 // BlimpInputManager.
44 input_manager_.reset();
45 }
21 46
22 BlimpCompositor* BlimpDocument::GetCompositor() { 47 BlimpCompositor* BlimpDocument::GetCompositor() {
23 return compositor_.get(); 48 return compositor_.get();
24 } 49 }
25 50
26 void BlimpDocument::SetCompositorForTest( 51 bool BlimpDocument::OnTouchEvent(const ui::MotionEvent& motion_event) {
27 std::unique_ptr<BlimpCompositor> compositor) { 52 if (input_manager_)
28 compositor_ = std::move(compositor); 53 return input_manager_->OnTouchEvent(motion_event);
29 } 54 return false;
30
31 void BlimpDocument::SendWebGestureEvent(
32 const blink::WebGestureEvent& gesture_event) {
33 manager_->SendWebGestureEvent(document_id_, gesture_event);
34 } 55 }
35 56
36 void BlimpDocument::SendCompositorMessage( 57 void BlimpDocument::SendCompositorMessage(
37 const cc::proto::CompositorMessage& message) { 58 const cc::proto::CompositorMessage& message) {
38 manager_->SendCompositorMessage(document_id_, message); 59 manager_->SendCompositorMessage(document_id_, message);
39 } 60 }
40 61
62 void BlimpDocument::SendWebGestureEvent(
63 const blink::WebGestureEvent& gesture_event) {
64 manager_->SendWebGestureEvent(document_id_, gesture_event);
65 }
66
41 } // namespace client 67 } // namespace client
42 } // namespace blimp 68 } // namespace blimp
OLDNEW
« no previous file with comments | « blimp/client/core/render_widget/blimp_document.h ('k') | blimp/client/core/render_widget/blimp_document_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698