| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "android_webview/native/java_browser_view_renderer_helper.h" | 5 #include "android_webview/native/java_browser_view_renderer_helper.h" |
| 6 | 6 |
| 7 #include <android/bitmap.h> | 7 #include <android/bitmap.h> |
| 8 | 8 |
| 9 #include "android_webview/public/browser/draw_sw.h" | 9 #include "android_webview/public/browser/draw_sw.h" |
| 10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 80 const gfx::Vector2d& scroll_correction, | 80 const gfx::Vector2d& scroll_correction, |
| 81 const gfx::Size size); | 81 const gfx::Size size); |
| 82 ~AuxiliaryCanvasHolder() override; | 82 ~AuxiliaryCanvasHolder() override; |
| 83 | 83 |
| 84 SkCanvas* GetCanvas() override; | 84 SkCanvas* GetCanvas() override; |
| 85 | 85 |
| 86 private: | 86 private: |
| 87 ScopedJavaLocalRef<jobject> jcanvas_; | 87 ScopedJavaLocalRef<jobject> jcanvas_; |
| 88 ScopedJavaLocalRef<jobject> jbitmap_; | 88 ScopedJavaLocalRef<jobject> jbitmap_; |
| 89 gfx::Vector2d scroll_; | 89 gfx::Vector2d scroll_; |
| 90 scoped_ptr<SkBitmap> bitmap_; | 90 std::unique_ptr<SkBitmap> bitmap_; |
| 91 skia::RefPtr<SkCanvas> canvas_; | 91 skia::RefPtr<SkCanvas> canvas_; |
| 92 DISALLOW_COPY_AND_ASSIGN(AuxiliaryCanvasHolder); | 92 DISALLOW_COPY_AND_ASSIGN(AuxiliaryCanvasHolder); |
| 93 }; | 93 }; |
| 94 | 94 |
| 95 AuxiliaryCanvasHolder::AuxiliaryCanvasHolder( | 95 AuxiliaryCanvasHolder::AuxiliaryCanvasHolder( |
| 96 JNIEnv* env, | 96 JNIEnv* env, |
| 97 jobject java_canvas, | 97 jobject java_canvas, |
| 98 const gfx::Vector2d& scroll_correction, | 98 const gfx::Vector2d& scroll_correction, |
| 99 const gfx::Size size) | 99 const gfx::Size size) |
| 100 : jcanvas_(env, java_canvas), scroll_(scroll_correction) { | 100 : jcanvas_(env, java_canvas), scroll_(scroll_correction) { |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 142 return canvas_.get(); | 142 return canvas_.get(); |
| 143 } | 143 } |
| 144 | 144 |
| 145 } // namespace | 145 } // namespace |
| 146 | 146 |
| 147 void RasterHelperSetAwDrawSWFunctionTable(AwDrawSWFunctionTable* table) { | 147 void RasterHelperSetAwDrawSWFunctionTable(AwDrawSWFunctionTable* table) { |
| 148 g_sw_draw_functions = table; | 148 g_sw_draw_functions = table; |
| 149 } | 149 } |
| 150 | 150 |
| 151 // static | 151 // static |
| 152 scoped_ptr<SoftwareCanvasHolder> SoftwareCanvasHolder::Create( | 152 std::unique_ptr<SoftwareCanvasHolder> SoftwareCanvasHolder::Create( |
| 153 jobject java_canvas, | 153 jobject java_canvas, |
| 154 const gfx::Vector2d& scroll_correction, | 154 const gfx::Vector2d& scroll_correction, |
| 155 const gfx::Size& auxiliary_bitmap_size, | 155 const gfx::Size& auxiliary_bitmap_size, |
| 156 bool force_auxiliary_bitmap) { | 156 bool force_auxiliary_bitmap) { |
| 157 JNIEnv* env = base::android::AttachCurrentThread(); | 157 JNIEnv* env = base::android::AttachCurrentThread(); |
| 158 scoped_ptr<SoftwareCanvasHolder> holder; | 158 std::unique_ptr<SoftwareCanvasHolder> holder; |
| 159 if (!force_auxiliary_bitmap) { | 159 if (!force_auxiliary_bitmap) { |
| 160 holder.reset(new JavaCanvasHolder(env, java_canvas, scroll_correction)); | 160 holder.reset(new JavaCanvasHolder(env, java_canvas, scroll_correction)); |
| 161 } | 161 } |
| 162 if (!holder.get() || !holder->GetCanvas()) { | 162 if (!holder.get() || !holder->GetCanvas()) { |
| 163 holder.reset(); | 163 holder.reset(); |
| 164 holder.reset(new AuxiliaryCanvasHolder(env, java_canvas, scroll_correction, | 164 holder.reset(new AuxiliaryCanvasHolder(env, java_canvas, scroll_correction, |
| 165 auxiliary_bitmap_size)); | 165 auxiliary_bitmap_size)); |
| 166 } | 166 } |
| 167 if (!holder->GetCanvas()) { | 167 if (!holder->GetCanvas()) { |
| 168 holder.reset(); | 168 holder.reset(); |
| 169 } | 169 } |
| 170 return holder; | 170 return holder; |
| 171 } | 171 } |
| 172 | 172 |
| 173 bool RegisterJavaBrowserViewRendererHelper(JNIEnv* env) { | 173 bool RegisterJavaBrowserViewRendererHelper(JNIEnv* env) { |
| 174 return RegisterNativesImpl(env); | 174 return RegisterNativesImpl(env); |
| 175 } | 175 } |
| 176 | 176 |
| 177 } // namespace android_webview | 177 } // namespace android_webview |
| OLD | NEW |