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 |