| 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 #ifndef CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ | 5 #ifndef CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ |
| 6 #define CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ | 6 #define CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 | 9 |
| 10 #include <memory> | 10 #include <memory> |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 42 const base::android::JavaParamRef<jobject>& obj); | 42 const base::android::JavaParamRef<jobject>& obj); |
| 43 void UpdateVSyncInterval(JNIEnv* env, | 43 void UpdateVSyncInterval(JNIEnv* env, |
| 44 const base::android::JavaParamRef<jobject>& obj, | 44 const base::android::JavaParamRef<jobject>& obj, |
| 45 jlong timebase_nanos, | 45 jlong timebase_nanos, |
| 46 jdouble interval_seconds); | 46 jdouble interval_seconds); |
| 47 void OnPause(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); | 47 void OnPause(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); |
| 48 void OnResume(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); | 48 void OnResume(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); |
| 49 void Destroy(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); | 49 void Destroy(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); |
| 50 void ShowTab(int id); | 50 void ShowTab(int id); |
| 51 void OpenNewTab(bool incognito); | 51 void OpenNewTab(bool incognito); |
| 52 device::mojom::VRSubmitFrameClientPtr TakeSubmitFrameClient(); |
| 52 | 53 |
| 53 device::GvrDeviceProvider* device_provider() { return device_provider_; } | 54 device::GvrDeviceProvider* device_provider() { return device_provider_; } |
| 54 void OnVRVsyncProviderRequest(device::mojom::VRVSyncProviderRequest request); | |
| 55 base::WeakPtr<VrShellDelegate> GetWeakPtr(); | 55 base::WeakPtr<VrShellDelegate> GetWeakPtr(); |
| 56 | 56 |
| 57 private: | 57 private: |
| 58 // device::GvrDelegateProvider implementation | 58 // device::GvrDelegateProvider implementation |
| 59 void SetDeviceProvider(device::GvrDeviceProvider* device_provider) override; | 59 void SetDeviceProvider(device::GvrDeviceProvider* device_provider) override; |
| 60 void ClearDeviceProvider() override; | 60 void ClearDeviceProvider() override; |
| 61 void RequestWebVRPresent(const base::Callback<void(bool)>& callback) override; | 61 void RequestWebVRPresent(device::mojom::VRSubmitFrameClientPtr submit_client, |
| 62 const base::Callback<void(bool)>& callback) override; |
| 62 void ExitWebVRPresent() override; | 63 void ExitWebVRPresent() override; |
| 63 device::GvrDelegate* GetDelegate() override; | 64 device::GvrDelegate* GetDelegate() override; |
| 64 void SetListeningForActivate(bool listening) override; | 65 void SetListeningForActivate(bool listening) override; |
| 65 | 66 |
| 66 void CreateNonPresentingDelegate(); | 67 void CreateNonPresentingDelegate(); |
| 67 | 68 |
| 68 std::unique_ptr<NonPresentingGvrDelegate> non_presenting_delegate_; | 69 std::unique_ptr<NonPresentingGvrDelegate> non_presenting_delegate_; |
| 69 base::android::ScopedJavaGlobalRef<jobject> j_vr_shell_delegate_; | 70 base::android::ScopedJavaGlobalRef<jobject> j_vr_shell_delegate_; |
| 70 device::GvrDeviceProvider* device_provider_ = nullptr; | 71 device::GvrDeviceProvider* device_provider_ = nullptr; |
| 71 device::GvrDelegate* delegate_ = nullptr; | 72 device::GvrDelegate* delegate_ = nullptr; |
| 72 base::Callback<void(bool)> present_callback_; | 73 base::Callback<void(bool)> present_callback_; |
| 73 int64_t timebase_nanos_ = 0; | 74 int64_t timebase_nanos_ = 0; |
| 74 double interval_seconds_ = 0; | 75 double interval_seconds_ = 0; |
| 75 | 76 device::mojom::VRSubmitFrameClientPtr submit_client_; |
| 76 // TODO(mthiesse): Remove the need for this to be stored here. | |
| 77 // crbug.com/674594 | |
| 78 gvr_context* context_ = nullptr; | |
| 79 | 77 |
| 80 base::WeakPtrFactory<VrShellDelegate> weak_ptr_factory_; | 78 base::WeakPtrFactory<VrShellDelegate> weak_ptr_factory_; |
| 81 | 79 |
| 82 DISALLOW_COPY_AND_ASSIGN(VrShellDelegate); | 80 DISALLOW_COPY_AND_ASSIGN(VrShellDelegate); |
| 83 }; | 81 }; |
| 84 | 82 |
| 85 bool RegisterVrShellDelegate(JNIEnv* env); | 83 bool RegisterVrShellDelegate(JNIEnv* env); |
| 86 | 84 |
| 87 } // namespace vr_shell | 85 } // namespace vr_shell |
| 88 | 86 |
| 89 #endif // CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ | 87 #endif // CHROME_BROWSER_ANDROID_VR_SHELL_VR_SHELL_DELEGATE_H_ |
| OLD | NEW |