Chromium Code Reviews| Index: chrome/browser/android/vr_shell/vr_controller_manager.cc |
| diff --git a/chrome/browser/android/vr_shell/vr_controller_manager.cc b/chrome/browser/android/vr_shell/vr_controller_manager.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..ffd137b4c35353d05631b2ec9f9f0409233d385c |
| --- /dev/null |
| +++ b/chrome/browser/android/vr_shell/vr_controller_manager.cc |
| @@ -0,0 +1,122 @@ |
| +// Copyright 2016 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 "base/logging.h" |
| +#include "chrome/browser/android/vr_shell/vr_controller_manager.h" |
| +#include "content/public/browser/browser_thread.h" |
| + |
| +namespace vr_shell { |
| + |
| +VrControllerManager::VrControllerManager(gvr_context_* gvr_context) {} |
|
bshe
2016/09/21 15:18:41
is gvr_context neccessary? it doesn't look like it
asimjour
2016/09/22 14:48:36
Done.
|
| + |
| +VrControllerManager::~VrControllerManager() {} |
| + |
| +void VrControllerManager::OnResume() { |
| + VLOG(1) << "Controller-Resume"; |
|
mthiesse
2016/09/21 17:27:47
Is there a debug only logging path? Might make sen
asimjour
2016/09/22 14:48:36
removed unnecessary logs
|
| + if (vr_controller_) |
| + vr_controller_->OnResume(); |
| +} |
| + |
| +void VrControllerManager::SetContentViewCore( |
| + content::ContentViewCore* content_content_view_core_ptr, |
|
mthiesse
2016/09/21 17:27:47
People don't seem to like the content_content_ nam
asimjour
2016/09/22 14:48:36
Done.
|
| + content::ContentViewCore* ui_content_view_core_ptr) { |
| + vr_content_ptr = content::VrContentViewCore::FromContentViewCore( |
| + content_content_view_core_ptr); |
| + vr_ui_ptr = |
| + content::VrContentViewCore::FromContentViewCore(ui_content_view_core_ptr); |
| +} |
| + |
| +void VrControllerManager::OnPause() { |
| + VLOG(1) << "Controller-Pause"; |
| + if (vr_controller_) |
| + vr_controller_->OnPause(); |
| +} |
| + |
| +void VrControllerManager::Initialize(gvr_context_* gvr_context) { |
| + vr_controller_.reset(new VrController(gvr_context)); |
| + vr_controller_->Initialize(gvr_context); |
| +} |
| + |
| +VrGesture VrControllerManager::Update() { |
| + if (!vr_controller_) |
| + return VrGesture(); |
| + vr_controller_->UpdateState(); |
| + VrGesture gesture = vr_controller_->DetectGesture(); |
| + return gesture; |
| +} |
| + |
| +void VrControllerManager::ProcessUpdatedGesture(VrGesture gesture) { |
|
mthiesse
2016/09/21 17:27:47
Why not pass the CVC pointer in here, and not stor
asimjour
2016/09/22 14:48:36
If we pass the vr_cvc pointer vr_shell need to kno
|
| + content::BrowserThread::PostTask(content::BrowserThread::UI, FROM_HERE, |
|
mthiesse
2016/09/21 17:27:47
You should probably either check that you're not a
asimjour
2016/09/22 14:48:36
Done.
|
| + base::Bind(&VrControllerManager::SendGesture, |
| + this, gesture, vr_content_ptr)); |
| +} |
| + |
| +void VrControllerManager::ProcessUpdatedUIGesture(VrGesture gesture) { |
| + content::BrowserThread::PostTask( |
| + content::BrowserThread::UI, FROM_HERE, |
| + base::Bind(&VrControllerManager::SendGesture, this, gesture, vr_ui_ptr)); |
| +} |
| + |
| +void VrControllerManager::SendGesture( |
| + VrGesture gesture, |
| + content::VrContentViewCore* content_view_core_ptr) { |
| + int64_t event_time = gesture.start_time; |
| + long event_time_milliseconds = (long)(event_time / 1000000); |
| + |
| + if (gesture.type == kGestureTypeScroll) { |
| + content_view_core_ptr->SendScrollEvent( |
| + event_time_milliseconds, 0.0f, 0.0f, gesture.details.scroll.dx, |
| + gesture.details.scroll.dy, gesture.details.scroll.state); |
| + } else if (gesture.type == kGestureTypeButtonsChange) { |
| + content_view_core_ptr->SendClickEvent(event_time_milliseconds, |
| + gesture.details.buttons.x, |
| + gesture.details.buttons.y); |
| + } else if (gesture.type == kGestureTypeAngularMove) { |
| + content_view_core_ptr->SendMouseMoveEvent( |
| + event_time_milliseconds, gesture.details.move.x, gesture.details.move.y, |
| + gesture.details.move.type); |
| + } |
| + return; |
| +} |
| + |
| +bool VrControllerManager::IsTouching() { |
| + return vr_controller_->IsTouching(); |
| +} |
| + |
| +float VrControllerManager::TouchPosX() { |
| + return vr_controller_->TouchPosX(); |
| +} |
| + |
| +float VrControllerManager::TouchPosY() { |
| + return vr_controller_->TouchPosY(); |
| +} |
| + |
| +const gvr_quatf VrControllerManager::Orientation() { |
|
mthiesse
2016/09/21 17:27:47
nit: gvr::Quatf
asimjour
2016/09/22 14:48:36
Done.
|
| + gvr_quatf orientation = { |
| + vr_controller_->Orientation().qx, vr_controller_->Orientation().qy, |
|
mthiesse
2016/09/21 17:27:47
This feels wrong. vr_controller_->Orientation() co
asimjour
2016/09/22 14:48:36
fixed
|
| + vr_controller_->Orientation().qz, vr_controller_->Orientation().qw}; |
| + return orientation; |
| +} |
| + |
| +bool VrControllerManager::IsTouchDown() { |
| + return vr_controller_->IsTouchDown(); |
| +} |
| + |
| +bool VrControllerManager::IsTouchUp() { |
| + return vr_controller_->IsTouchUp(); |
| +} |
| + |
| +bool VrControllerManager::ButtonDown(const int32_t button) { |
| + return vr_controller_->ButtonDown(button); |
| +} |
| + |
| +bool VrControllerManager::ButtonUp(const int32_t button) { |
| + return vr_controller_->ButtonUp(button); |
| +} |
| + |
| +bool VrControllerManager::IsConnected() { |
| + return vr_controller_->IsConnected(); |
| +} |
| + |
| +} // namespace vr_shell |