| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "content/browser/android/content_view_render_view.h" | 5 #include "content/browser/android/content_view_render_view.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/jni_string.h" | 8 #include "base/android/jni_string.h" |
| 9 #include "base/android/scoped_java_ref.h" | 9 #include "base/android/scoped_java_ref.h" |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 46 } // anonymous namespace | 46 } // anonymous namespace |
| 47 | 47 |
| 48 // static | 48 // static |
| 49 bool ContentViewRenderView::RegisterContentViewRenderView(JNIEnv* env) { | 49 bool ContentViewRenderView::RegisterContentViewRenderView(JNIEnv* env) { |
| 50 return RegisterNativesImpl(env); | 50 return RegisterNativesImpl(env); |
| 51 } | 51 } |
| 52 | 52 |
| 53 ContentViewRenderView::ContentViewRenderView(JNIEnv* env, | 53 ContentViewRenderView::ContentViewRenderView(JNIEnv* env, |
| 54 jobject obj, | 54 jobject obj, |
| 55 gfx::NativeWindow root_window) | 55 gfx::NativeWindow root_window) |
| 56 : buffers_swapped_during_composite_(false), | 56 : layer_tree_build_helper_(new LayerTreeBuildHelperImpl()), |
| 57 layer_tree_build_helper_(new LayerTreeBuildHelperImpl()), | |
| 58 root_window_(root_window), | 57 root_window_(root_window), |
| 59 current_surface_format_(0) { | 58 current_surface_format_(0) { |
| 60 java_obj_.Reset(env, obj); | 59 java_obj_.Reset(env, obj); |
| 61 } | 60 } |
| 62 | 61 |
| 63 ContentViewRenderView::~ContentViewRenderView() { | 62 ContentViewRenderView::~ContentViewRenderView() { |
| 64 } | 63 } |
| 65 | 64 |
| 66 void ContentViewRenderView::SetLayerTreeBuildHelper(JNIEnv* env, | 65 void ContentViewRenderView::SetLayerTreeBuildHelper(JNIEnv* env, |
| 67 jobject obj, | 66 jobject obj, |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 | 110 |
| 112 void ContentViewRenderView::SurfaceChanged(JNIEnv* env, jobject obj, | 111 void ContentViewRenderView::SurfaceChanged(JNIEnv* env, jobject obj, |
| 113 jint format, jint width, jint height, jobject surface) { | 112 jint format, jint width, jint height, jobject surface) { |
| 114 if (current_surface_format_ != format) { | 113 if (current_surface_format_ != format) { |
| 115 current_surface_format_ = format; | 114 current_surface_format_ = format; |
| 116 compositor_->SetSurface(surface); | 115 compositor_->SetSurface(surface); |
| 117 } | 116 } |
| 118 compositor_->SetWindowBounds(gfx::Size(width, height)); | 117 compositor_->SetWindowBounds(gfx::Size(width, height)); |
| 119 } | 118 } |
| 120 | 119 |
| 121 jboolean ContentViewRenderView::Composite(JNIEnv* env, jobject obj) { | |
| 122 if (!compositor_) | |
| 123 return false; | |
| 124 | |
| 125 buffers_swapped_during_composite_ = false; | |
| 126 compositor_->Composite(); | |
| 127 return buffers_swapped_during_composite_; | |
| 128 } | |
| 129 | |
| 130 jboolean ContentViewRenderView::CompositeToBitmap(JNIEnv* env, jobject obj, | 120 jboolean ContentViewRenderView::CompositeToBitmap(JNIEnv* env, jobject obj, |
| 131 jobject java_bitmap) { | 121 jobject java_bitmap) { |
| 132 gfx::JavaBitmap bitmap(java_bitmap); | 122 gfx::JavaBitmap bitmap(java_bitmap); |
| 133 if (!compositor_ || bitmap.format() != ANDROID_BITMAP_FORMAT_RGBA_8888) | 123 if (!compositor_ || bitmap.format() != ANDROID_BITMAP_FORMAT_RGBA_8888) |
| 134 return false; | 124 return false; |
| 135 return compositor_->CompositeAndReadback(bitmap.pixels(), | 125 return compositor_->CompositeAndReadback(bitmap.pixels(), |
| 136 gfx::Rect(bitmap.size())); | 126 gfx::Rect(bitmap.size())); |
| 137 } | 127 } |
| 138 | 128 |
| 139 void ContentViewRenderView::SetOverlayVideoMode( | 129 void ContentViewRenderView::SetOverlayVideoMode( |
| 140 JNIEnv* env, jobject obj, bool enabled) { | 130 JNIEnv* env, jobject obj, bool enabled) { |
| 141 compositor_->SetHasTransparentBackground(enabled); | 131 compositor_->SetHasTransparentBackground(enabled); |
| 142 Java_ContentViewRenderView_requestRender(env, obj); | |
| 143 } | 132 } |
| 144 | 133 |
| 145 void ContentViewRenderView::ScheduleComposite() { | 134 void ContentViewRenderView::Layout() { |
| 146 JNIEnv* env = base::android::AttachCurrentThread(); | 135 JNIEnv* env = base::android::AttachCurrentThread(); |
| 147 Java_ContentViewRenderView_requestRender(env, java_obj_.obj()); | 136 Java_ContentViewRenderView_onCompositorLayout(env, java_obj_.obj()); |
| 148 } | 137 } |
| 149 | 138 |
| 150 void ContentViewRenderView::OnSwapBuffersPosted() { | 139 void ContentViewRenderView::OnSwapBuffersCompleted(int pending_swap_buffers) { |
| 151 buffers_swapped_during_composite_ = true; | |
| 152 } | |
| 153 | |
| 154 void ContentViewRenderView::OnSwapBuffersCompleted() { | |
| 155 JNIEnv* env = base::android::AttachCurrentThread(); | 140 JNIEnv* env = base::android::AttachCurrentThread(); |
| 156 Java_ContentViewRenderView_onSwapBuffersCompleted(env, java_obj_.obj()); | 141 Java_ContentViewRenderView_onSwapBuffersCompleted(env, java_obj_.obj()); |
| 157 } | 142 } |
| 158 | 143 |
| 159 void ContentViewRenderView::InitCompositor() { | 144 void ContentViewRenderView::InitCompositor() { |
| 160 if (!compositor_) | 145 if (!compositor_) |
| 161 compositor_.reset(Compositor::Create(this, root_window_)); | 146 compositor_.reset(Compositor::Create(this, root_window_)); |
| 162 } | 147 } |
| 163 } // namespace content | 148 } // namespace content |
| OLD | NEW |