| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/composited_touch_handle_drawable.h" | 5 #include "content/browser/android/composited_touch_handle_drawable.h" |
| 6 | 6 |
| 7 #include "base/debug/trace_event.h" | 7 #include "base/debug/trace_event.h" |
| 8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "cc/layers/ui_resource_layer.h" | 10 #include "cc/layers/ui_resource_layer.h" |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 right_bitmap_ = CreateSkBitmapFromJavaBitmap( | 43 right_bitmap_ = CreateSkBitmapFromJavaBitmap( |
| 44 Java_HandleViewResources_getRightHandleBitmap(env, context)); | 44 Java_HandleViewResources_getRightHandleBitmap(env, context)); |
| 45 center_bitmap_ = CreateSkBitmapFromJavaBitmap( | 45 center_bitmap_ = CreateSkBitmapFromJavaBitmap( |
| 46 Java_HandleViewResources_getCenterHandleBitmap(env, context)); | 46 Java_HandleViewResources_getCenterHandleBitmap(env, context)); |
| 47 | 47 |
| 48 left_bitmap_.setImmutable(); | 48 left_bitmap_.setImmutable(); |
| 49 right_bitmap_.setImmutable(); | 49 right_bitmap_.setImmutable(); |
| 50 center_bitmap_.setImmutable(); | 50 center_bitmap_.setImmutable(); |
| 51 } | 51 } |
| 52 | 52 |
| 53 const SkBitmap& GetBitmap(TouchHandleOrientation orientation) { | 53 const SkBitmap& GetBitmap(ui::TouchHandleOrientation orientation) { |
| 54 DCHECK(loaded_); | 54 DCHECK(loaded_); |
| 55 switch (orientation) { | 55 switch (orientation) { |
| 56 case TOUCH_HANDLE_LEFT: | 56 case ui::TOUCH_HANDLE_LEFT: |
| 57 return left_bitmap_; | 57 return left_bitmap_; |
| 58 case TOUCH_HANDLE_RIGHT: | 58 case ui::TOUCH_HANDLE_RIGHT: |
| 59 return right_bitmap_; | 59 return right_bitmap_; |
| 60 case TOUCH_HANDLE_CENTER: | 60 case ui::TOUCH_HANDLE_CENTER: |
| 61 return center_bitmap_; | 61 return center_bitmap_; |
| 62 case TOUCH_HANDLE_ORIENTATION_UNDEFINED: | 62 case ui::TOUCH_HANDLE_ORIENTATION_UNDEFINED: |
| 63 NOTREACHED() << "Invalid touch handle orientation."; | 63 NOTREACHED() << "Invalid touch handle orientation."; |
| 64 }; | 64 }; |
| 65 return center_bitmap_; | 65 return center_bitmap_; |
| 66 } | 66 } |
| 67 | 67 |
| 68 private: | 68 private: |
| 69 SkBitmap left_bitmap_; | 69 SkBitmap left_bitmap_; |
| 70 SkBitmap right_bitmap_; | 70 SkBitmap right_bitmap_; |
| 71 SkBitmap center_bitmap_; | 71 SkBitmap center_bitmap_; |
| 72 bool loaded_; | 72 bool loaded_; |
| 73 | 73 |
| 74 DISALLOW_COPY_AND_ASSIGN(HandleResources); | 74 DISALLOW_COPY_AND_ASSIGN(HandleResources); |
| 75 }; | 75 }; |
| 76 | 76 |
| 77 base::LazyInstance<HandleResources>::Leaky g_selection_resources; | 77 base::LazyInstance<HandleResources>::Leaky g_selection_resources; |
| 78 | 78 |
| 79 } // namespace | 79 } // namespace |
| 80 | 80 |
| 81 CompositedTouchHandleDrawable::CompositedTouchHandleDrawable( | 81 CompositedTouchHandleDrawable::CompositedTouchHandleDrawable( |
| 82 cc::Layer* root_layer, | 82 cc::Layer* root_layer, |
| 83 float dpi_scale, | 83 float dpi_scale, |
| 84 jobject context) | 84 jobject context) |
| 85 : dpi_scale_(dpi_scale), | 85 : dpi_scale_(dpi_scale), |
| 86 orientation_(TOUCH_HANDLE_ORIENTATION_UNDEFINED), | 86 orientation_(ui::TOUCH_HANDLE_ORIENTATION_UNDEFINED), |
| 87 layer_(cc::UIResourceLayer::Create()) { | 87 layer_(cc::UIResourceLayer::Create()) { |
| 88 g_selection_resources.Get().LoadIfNecessary(context); | 88 g_selection_resources.Get().LoadIfNecessary(context); |
| 89 DCHECK(root_layer); | 89 DCHECK(root_layer); |
| 90 root_layer->AddChild(layer_.get()); | 90 root_layer->AddChild(layer_.get()); |
| 91 } | 91 } |
| 92 | 92 |
| 93 CompositedTouchHandleDrawable::~CompositedTouchHandleDrawable() { | 93 CompositedTouchHandleDrawable::~CompositedTouchHandleDrawable() { |
| 94 Detach(); | 94 Detach(); |
| 95 } | 95 } |
| 96 | 96 |
| 97 void CompositedTouchHandleDrawable::SetEnabled(bool enabled) { | 97 void CompositedTouchHandleDrawable::SetEnabled(bool enabled) { |
| 98 layer_->SetIsDrawable(enabled); | 98 layer_->SetIsDrawable(enabled); |
| 99 } | 99 } |
| 100 | 100 |
| 101 void CompositedTouchHandleDrawable::SetOrientation( | 101 void CompositedTouchHandleDrawable::SetOrientation( |
| 102 TouchHandleOrientation orientation) { | 102 ui::TouchHandleOrientation orientation) { |
| 103 DCHECK(layer_->parent()); | 103 DCHECK(layer_->parent()); |
| 104 orientation_ = orientation; | 104 orientation_ = orientation; |
| 105 | 105 |
| 106 const SkBitmap& bitmap = g_selection_resources.Get().GetBitmap(orientation); | 106 const SkBitmap& bitmap = g_selection_resources.Get().GetBitmap(orientation); |
| 107 layer_->SetBitmap(bitmap); | 107 layer_->SetBitmap(bitmap); |
| 108 layer_->SetBounds(gfx::Size(bitmap.width(), bitmap.height())); | 108 layer_->SetBounds(gfx::Size(bitmap.width(), bitmap.height())); |
| 109 | 109 |
| 110 switch (orientation_) { | 110 switch (orientation_) { |
| 111 case TOUCH_HANDLE_LEFT: | 111 case ui::TOUCH_HANDLE_LEFT: |
| 112 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.75f, 0); | 112 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.75f, 0); |
| 113 break; | 113 break; |
| 114 case TOUCH_HANDLE_RIGHT: | 114 case ui::TOUCH_HANDLE_RIGHT: |
| 115 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.25f, 0); | 115 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.25f, 0); |
| 116 break; | 116 break; |
| 117 case TOUCH_HANDLE_CENTER: | 117 case ui::TOUCH_HANDLE_CENTER: |
| 118 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.5f, 0); | 118 focal_offset_from_origin_ = gfx::Vector2dF(bitmap.width() * 0.5f, 0); |
| 119 break; | 119 break; |
| 120 case TOUCH_HANDLE_ORIENTATION_UNDEFINED: | 120 case ui::TOUCH_HANDLE_ORIENTATION_UNDEFINED: |
| 121 NOTREACHED() << "Invalid touch handle orientation."; | 121 NOTREACHED() << "Invalid touch handle orientation."; |
| 122 break; | 122 break; |
| 123 }; | 123 }; |
| 124 | 124 |
| 125 layer_->SetPosition(focal_position_ - focal_offset_from_origin_); | 125 layer_->SetPosition(focal_position_ - focal_offset_from_origin_); |
| 126 } | 126 } |
| 127 | 127 |
| 128 void CompositedTouchHandleDrawable::SetAlpha(float alpha) { | 128 void CompositedTouchHandleDrawable::SetAlpha(float alpha) { |
| 129 DCHECK(layer_->parent()); | 129 DCHECK(layer_->parent()); |
| 130 alpha = std::max(0.f, std::min(1.f, alpha)); | 130 alpha = std::max(0.f, std::min(1.f, alpha)); |
| (...skipping 23 matching lines...) Expand all Loading... |
| 154 layer_->bounds().width(), | 154 layer_->bounds().width(), |
| 155 layer_->bounds().height()); | 155 layer_->bounds().height()); |
| 156 } | 156 } |
| 157 | 157 |
| 158 // static | 158 // static |
| 159 bool CompositedTouchHandleDrawable::RegisterHandleViewResources(JNIEnv* env) { | 159 bool CompositedTouchHandleDrawable::RegisterHandleViewResources(JNIEnv* env) { |
| 160 return RegisterNativesImpl(env); | 160 return RegisterNativesImpl(env); |
| 161 } | 161 } |
| 162 | 162 |
| 163 } // namespace content | 163 } // namespace content |
| OLD | NEW |