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 ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ | 5 #ifndef ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ |
6 #define ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ | 6 #define ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ |
7 | 7 |
8 #include <jni.h> | 8 #include <jni.h> |
9 | 9 |
10 #include "android_webview/browser/compositor_frame_consumer.h" | |
11 #include "android_webview/browser/compositor_frame_producer.h" | |
boliu
2016/04/21 17:05:40
don't need producer
Tobias Sargeant
2016/04/21 17:48:27
Done.
| |
10 #include "android_webview/browser/render_thread_manager.h" | 12 #include "android_webview/browser/render_thread_manager.h" |
11 #include "android_webview/browser/render_thread_manager_client.h" | 13 #include "android_webview/browser/render_thread_manager_client.h" |
12 #include "base/android/jni_weak_ref.h" | 14 #include "base/android/jni_weak_ref.h" |
13 | 15 |
14 namespace android_webview { | 16 namespace android_webview { |
15 | 17 |
16 class BrowserViewRenderer; | |
17 | |
18 class AwGLFunctor : public RenderThreadManagerClient { | 18 class AwGLFunctor : public RenderThreadManagerClient { |
19 public: | 19 public: |
20 void OnParentDrawConstraintsUpdated() override; | |
21 bool RequestInvokeGL(bool wait_for_completion) override; | 20 bool RequestInvokeGL(bool wait_for_completion) override; |
22 void DetachFunctorFromView() override; | 21 void DetachFunctorFromView() override; |
23 | 22 |
24 AwGLFunctor(const JavaObjectWeakGlobalRef& java_ref); | 23 AwGLFunctor(const JavaObjectWeakGlobalRef& java_ref); |
25 ~AwGLFunctor() override; | 24 ~AwGLFunctor() override; |
26 | 25 |
27 void SetBrowserViewRenderer(BrowserViewRenderer* browser_view_renderer); | |
28 | |
29 void Destroy(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); | 26 void Destroy(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj); |
30 void DeleteHardwareRenderer(JNIEnv* env, | 27 void DeleteHardwareRenderer(JNIEnv* env, |
31 const base::android::JavaParamRef<jobject>& obj); | 28 const base::android::JavaParamRef<jobject>& obj); |
32 jlong GetAwDrawGLViewContext(JNIEnv* env, | 29 jlong GetAwDrawGLViewContext(JNIEnv* env, |
33 const base::android::JavaParamRef<jobject>& obj); | 30 const base::android::JavaParamRef<jobject>& obj); |
34 jlong GetAwDrawGLFunction(JNIEnv* env, | 31 jlong GetAwDrawGLFunction(JNIEnv* env, |
35 const base::android::JavaParamRef<jobject>& obj); | 32 const base::android::JavaParamRef<jobject>& obj); |
36 | 33 |
37 RenderThreadManager* GetRenderThreadManager() { | 34 CompositorFrameConsumer* GetCompositorFrameConsumer() { |
38 return &render_thread_manager_; | 35 return static_cast<CompositorFrameConsumer*>(&render_thread_manager_); |
boliu
2016/04/21 17:05:40
huh? why does this need to be a cast?
Tobias Sargeant
2016/04/21 17:48:27
Doesn't. Removed.
| |
39 } | 36 } |
40 | 37 |
41 private: | 38 private: |
42 JavaObjectWeakGlobalRef java_ref_; | 39 JavaObjectWeakGlobalRef java_ref_; |
43 RenderThreadManager render_thread_manager_; | 40 RenderThreadManager render_thread_manager_; |
44 BrowserViewRenderer* browser_view_renderer_; | |
45 }; | 41 }; |
46 | 42 |
47 bool RegisterAwGLFunctor(JNIEnv* env); | 43 bool RegisterAwGLFunctor(JNIEnv* env); |
48 | 44 |
49 } // namespace android_webview | 45 } // namespace android_webview |
50 | 46 |
51 #endif // ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ | 47 #endif // ANDROID_WEBVIEW_NATIVE_AW_GL_FUNCTOR_H_ |
OLD | NEW |