OLD | NEW |
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 "chrome/browser/android/vr_shell/vr_shell_delegate.h" | 5 #include "chrome/browser/android/vr_shell/vr_shell_delegate.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
10 #include "chrome/browser/android/vr_shell/non_presenting_gvr_delegate.h" | 10 #include "chrome/browser/android/vr_shell/non_presenting_gvr_delegate.h" |
11 #include "device/vr/android/gvr/gvr_device.h" | 11 #include "device/vr/android/gvr/gvr_device.h" |
12 #include "device/vr/android/gvr/gvr_device_provider.h" | 12 #include "device/vr/android/gvr/gvr_device_provider.h" |
13 #include "device/vr/android/gvr/gvr_gamepad_data_fetcher.h" | 13 #include "device/vr/android/gvr/gvr_gamepad_data_fetcher.h" |
14 #include "jni/VrShellDelegate_jni.h" | 14 #include "jni/VrShellDelegate_jni.h" |
15 | 15 |
16 using base::android::JavaParamRef; | 16 using base::android::JavaParamRef; |
17 using base::android::AttachCurrentThread; | 17 using base::android::AttachCurrentThread; |
18 | 18 |
19 namespace vr_shell { | 19 namespace vr_shell { |
20 | 20 |
21 VrShellDelegate::VrShellDelegate(JNIEnv* env, jobject obj) | 21 VrShellDelegate::VrShellDelegate(JNIEnv* env, jobject obj) |
22 : weak_ptr_factory_(this) { | 22 : weak_ptr_factory_(this) { |
23 j_vr_shell_delegate_.Reset(env, obj); | 23 j_vr_shell_delegate_.Reset(env, obj); |
24 GvrDelegateProvider::SetInstance(this); | |
25 } | 24 } |
26 | 25 |
27 VrShellDelegate::~VrShellDelegate() { | 26 VrShellDelegate::~VrShellDelegate() { |
28 GvrDelegateProvider::SetInstance(nullptr); | |
29 if (device_provider_) { | 27 if (device_provider_) { |
30 device_provider_->Device()->OnDelegateChanged(); | 28 device_provider_->Device()->OnDelegateChanged(); |
31 } | 29 } |
32 } | 30 } |
33 | 31 |
| 32 device::GvrDelegateProvider* VrShellDelegate::CreateVrShellDelegate() { |
| 33 JNIEnv* env = AttachCurrentThread(); |
| 34 base::android::ScopedJavaLocalRef<jobject> jdelegate = |
| 35 Java_VrShellDelegate_getInstance(env); |
| 36 if (!jdelegate.is_null()) |
| 37 return GetNativeVrShellDelegate(env, jdelegate.obj()); |
| 38 return nullptr; |
| 39 } |
| 40 |
34 VrShellDelegate* VrShellDelegate::GetNativeVrShellDelegate(JNIEnv* env, | 41 VrShellDelegate* VrShellDelegate::GetNativeVrShellDelegate(JNIEnv* env, |
35 jobject jdelegate) { | 42 jobject jdelegate) { |
36 return reinterpret_cast<VrShellDelegate*>( | 43 return reinterpret_cast<VrShellDelegate*>( |
37 Java_VrShellDelegate_getNativePointer(env, jdelegate)); | 44 Java_VrShellDelegate_getNativePointer(env, jdelegate)); |
38 } | 45 } |
39 | 46 |
40 void VrShellDelegate::SetDelegate(device::GvrDelegate* delegate, | 47 void VrShellDelegate::SetDelegate(device::GvrDelegate* delegate, |
41 gvr_context* context) { | 48 gvr_context* context) { |
42 context_ = context; | 49 context_ = context; |
43 delegate_ = delegate; | 50 delegate_ = delegate; |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
108 non_presenting_delegate_->Pause(); | 115 non_presenting_delegate_->Pause(); |
109 } | 116 } |
110 } | 117 } |
111 | 118 |
112 void VrShellDelegate::OnResume(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 119 void VrShellDelegate::OnResume(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
113 if (non_presenting_delegate_) { | 120 if (non_presenting_delegate_) { |
114 non_presenting_delegate_->Resume(); | 121 non_presenting_delegate_->Resume(); |
115 } | 122 } |
116 } | 123 } |
117 | 124 |
| 125 void VrShellDelegate::Destroy(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
| 126 delete this; |
| 127 } |
| 128 |
118 void VrShellDelegate::ShowTab(int id) { | 129 void VrShellDelegate::ShowTab(int id) { |
119 JNIEnv* env = AttachCurrentThread(); | 130 JNIEnv* env = AttachCurrentThread(); |
120 Java_VrShellDelegate_showTab(env, j_vr_shell_delegate_.obj(), id); | 131 Java_VrShellDelegate_showTab(env, j_vr_shell_delegate_.obj(), id); |
121 } | 132 } |
122 | 133 |
123 void VrShellDelegate::SetDeviceProvider( | 134 void VrShellDelegate::SetDeviceProvider( |
124 device::GvrDeviceProvider* device_provider) { | 135 device::GvrDeviceProvider* device_provider) { |
125 CHECK(!device_provider_); | 136 CHECK(!device_provider_); |
126 device_provider_ = device_provider; | 137 device_provider_ = device_provider; |
127 if (!delegate_) | 138 if (!delegate_) |
128 CreateNonPresentingDelegate(); | 139 CreateNonPresentingDelegate(); |
129 device_provider_->Device()->OnDelegateChanged(); | 140 device_provider_->Device()->OnDelegateChanged(); |
130 } | 141 } |
131 | 142 |
132 void VrShellDelegate::ClearDeviceProvider() { | 143 void VrShellDelegate::ClearDeviceProvider() { |
133 non_presenting_delegate_ = nullptr; | 144 non_presenting_delegate_ = nullptr; |
134 JNIEnv* env = AttachCurrentThread(); | 145 JNIEnv* env = AttachCurrentThread(); |
135 Java_VrShellDelegate_shutdownNonPresentingNativeContext( | 146 Java_VrShellDelegate_shutdownNonPresentingNativeContext( |
136 env, j_vr_shell_delegate_.obj()); | 147 env, j_vr_shell_delegate_.obj()); |
137 device_provider_->Device()->OnDelegateChanged(); | |
138 device_provider_ = nullptr; | 148 device_provider_ = nullptr; |
139 } | 149 } |
140 | 150 |
141 void VrShellDelegate::RequestWebVRPresent( | 151 void VrShellDelegate::RequestWebVRPresent( |
142 const base::Callback<void(bool)>& callback) { | 152 const base::Callback<void(bool)>& callback) { |
143 if (!present_callback_.is_null()) { | 153 if (!present_callback_.is_null()) { |
144 // Can only handle one request at a time. This is also extremely unlikely to | 154 // Can only handle one request at a time. This is also extremely unlikely to |
145 // happen in practice. | 155 // happen in practice. |
146 callback.Run(false); | 156 callback.Run(false); |
147 return; | 157 return; |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
201 // ---------------------------------------------------------------------------- | 211 // ---------------------------------------------------------------------------- |
202 | 212 |
203 bool RegisterVrShellDelegate(JNIEnv* env) { | 213 bool RegisterVrShellDelegate(JNIEnv* env) { |
204 return RegisterNativesImpl(env); | 214 return RegisterNativesImpl(env); |
205 } | 215 } |
206 | 216 |
207 jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 217 jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
208 return reinterpret_cast<intptr_t>(new VrShellDelegate(env, obj)); | 218 return reinterpret_cast<intptr_t>(new VrShellDelegate(env, obj)); |
209 } | 219 } |
210 | 220 |
| 221 static void OnLibraryAvailable(JNIEnv* env, const JavaParamRef<jclass>& clazz) { |
| 222 device::GvrDelegateProvider::SetInstance( |
| 223 base::Bind(&VrShellDelegate::CreateVrShellDelegate)); |
| 224 } |
| 225 |
211 } // namespace vr_shell | 226 } // namespace vr_shell |
OLD | NEW |