Chromium Code Reviews| Index: chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| diff --git a/chrome/browser/android/compositor/layer/contextual_search_layer.cc b/chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| index 46a243b611b13a4d0ef84a3fb5f9607620016474..85e758ace274ffe9538e6e602208a91bf39008bf 100644 |
| --- a/chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| +++ b/chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| @@ -38,38 +38,6 @@ scoped_refptr<ContextualSearchLayer> ContextualSearchLayer::Create( |
| return make_scoped_refptr(new ContextualSearchLayer(resource_manager)); |
| } |
| -scoped_refptr<cc::Layer> ContextualSearchLayer::GetIconLayer() { |
| - scoped_refptr<cc::Layer> icon = nullptr; |
| - |
| - // Thumbnail. |
| - if (thumbnail_visible_) { |
| - if (thumbnail_layer_->parent() != layer_) |
| - layer_->AddChild(thumbnail_layer_); |
| - |
| - icon = thumbnail_layer_; |
| - } else if (thumbnail_layer_->parent()) { |
| - thumbnail_layer_->RemoveFromParent(); |
| - } |
| - |
| - // Search Provider Icon Sprite (Animated). |
| - if (search_provider_icon_sprite_visible_) { |
| - if (search_provider_icon_sprite_->layer()->parent() != layer_) |
| - layer_->AddChild(search_provider_icon_sprite_->layer().get()); |
| - |
| - search_provider_icon_sprite_->DrawSpriteFrame( |
| - resource_manager_, |
| - panel_icon_resource_id_, |
| - search_provider_icon_sprite_metadata_resource_id_, |
| - search_provider_icon_sprite_completion_percentage_); |
| - icon = search_provider_icon_sprite_->layer(); |
| - } else if (search_provider_icon_sprite_->layer().get() && |
| - search_provider_icon_sprite_->layer()->parent()) { |
| - search_provider_icon_sprite_->layer()->RemoveFromParent(); |
| - } |
| - |
| - return icon; |
| -} |
| - |
| void ContextualSearchLayer::SetProperties( |
| int panel_shadow_resource_id, |
| int search_context_resource_id, |
| @@ -113,6 +81,7 @@ void ContextualSearchLayer::SetProperties( |
| bool search_provider_icon_sprite_visible, |
| float search_provider_icon_sprite_completion_percentage, |
| bool thumbnail_visible, |
| + float thumbnail_visibility_percentage, |
| int thumbnail_size, |
| float arrow_icon_opacity, |
| float arrow_icon_rotation, |
| @@ -122,15 +91,6 @@ void ContextualSearchLayer::SetProperties( |
| float progress_bar_opacity, |
| int progress_bar_completion) { |
| - search_provider_icon_sprite_visible_ = search_provider_icon_sprite_visible; |
| - search_provider_icon_sprite_metadata_resource_id_ = |
| - search_provider_icon_sprite_metadata_resource_id; |
| - search_provider_icon_sprite_completion_percentage_ = |
| - search_provider_icon_sprite_completion_percentage; |
| - |
| - thumbnail_visible_ = thumbnail_visible; |
| - thumbnail_size_ = thumbnail_size; |
| - |
| // Grabs the dynamic Search Context resource. |
| ui::ResourceManager::Resource* search_context_resource = |
| resource_manager_->GetResource(ui::ANDROID_RESOURCE_TYPE_DYNAMIC, |
| @@ -469,6 +429,74 @@ void ContextualSearchLayer::SetProperties( |
| if (progress_bar_.get() && progress_bar_->parent()) |
| progress_bar_->RemoveFromParent(); |
| } |
| + |
| + // --------------------------------------------------------------------------- |
| + // Icon Layer |
| + // --------------------------------------------------------------------------- |
| + thumbnail_size_ = thumbnail_size; |
| + SetupIconLayer(search_provider_icon_sprite_visible, |
| + search_provider_icon_sprite_metadata_resource_id, |
| + search_provider_icon_sprite_completion_percentage, |
| + thumbnail_visible, |
| + thumbnail_visibility_percentage); |
| +} |
| + |
| +scoped_refptr<cc::Layer> ContextualSearchLayer::GetIconLayer() { |
| + return icon_layer_; |
| +} |
| + |
| +void ContextualSearchLayer::SetupIconLayer( |
| + bool search_provider_icon_sprite_visible, |
| + int search_provider_icon_sprite_metadata_resource_id, |
| + float search_provider_icon_sprite_completion_percentage, |
| + bool thumbnail_visible, |
| + float thumbnail_visibility_percentage) { |
| + icon_layer_->SetBounds(gfx::Size(thumbnail_size_, thumbnail_size_)); |
| + icon_layer_->SetMasksToBounds(true); |
| + |
| + // Thumbnail |
| + if (thumbnail_visible) { |
| + if (thumbnail_layer_->parent() != icon_layer_) |
| + icon_layer_->AddChild(thumbnail_layer_); |
| + |
| + thumbnail_layer_->SetOpacity(thumbnail_visibility_percentage); |
| + |
| + float thumbnail_y_offset = |
| + thumbnail_size_ * (1.f - thumbnail_visibility_percentage); |
|
Donn Denman
2016/09/23 04:05:23
Why is the thumbnail_size_ involved here?
Donn Denman
2016/09/23 04:08:21
Elaborating my question ... maybe the available sp
Theresa
2016/09/23 04:39:57
Good question.
The thumbnail and 'G' icon slide t
Theresa
2016/09/23 15:45:46
Done. I also added some comments so hopefully this
|
| + thumbnail_layer_->SetPosition(gfx::PointF(0.f, thumbnail_y_offset)); |
| + } else if (thumbnail_layer_->parent()) { |
| + thumbnail_layer_->RemoveFromParent(); |
| + } |
| + |
| + // Search Provider Icon Sprite |
| + if (search_provider_icon_sprite_visible) { |
| + if (search_provider_icon_sprite_->layer()->parent() != icon_layer_) |
| + icon_layer_->AddChild(search_provider_icon_sprite_->layer().get()); |
| + |
| + search_provider_icon_sprite_->DrawSpriteFrame( |
| + resource_manager_, |
| + panel_icon_resource_id_, |
| + search_provider_icon_sprite_metadata_resource_id, |
| + search_provider_icon_sprite_completion_percentage); |
| + |
| + if (thumbnail_visibility_percentage > 0.f) { |
| + search_provider_icon_sprite_->layer()->SetOpacity( |
| + 1.f - thumbnail_visibility_percentage); |
| + |
| + float icon_y_offset = |
| + -(thumbnail_size_ * thumbnail_visibility_percentage); |
| + search_provider_icon_sprite_->layer()->SetPosition( |
| + gfx::PointF(0.f, icon_y_offset)); |
| + } else { |
|
Donn Denman
2016/09/23 04:05:23
Nit suggestion: I would think that this else claus
Theresa
2016/09/23 15:45:46
Done.
|
| + search_provider_icon_sprite_->layer()->SetOpacity(1.f); |
| + search_provider_icon_sprite_->layer()->SetPosition( |
| + gfx::PointF(0.f, 0.f)); |
| + } |
| + |
| + } else if (search_provider_icon_sprite_->layer().get() && |
| + search_provider_icon_sprite_->layer()->parent()) { |
| + search_provider_icon_sprite_->layer()->RemoveFromParent(); |
| + } |
| } |
| void ContextualSearchLayer::SetThumbnail(const SkBitmap* thumbnail) { |
| @@ -550,6 +578,7 @@ ContextualSearchLayer::ContextualSearchLayer( |
| ui::ResourceManager* resource_manager) |
| : OverlayPanelLayer(resource_manager), |
| search_context_(cc::UIResourceLayer::Create()), |
| + icon_layer_(cc::Layer::Create()), |
| search_provider_icon_sprite_(CrushedSpriteLayer::Create()), |
| thumbnail_layer_(cc::UIResourceLayer::Create()), |
| arrow_icon_(cc::UIResourceLayer::Create()), |
| @@ -595,6 +624,10 @@ ContextualSearchLayer::ContextualSearchLayer( |
| progress_bar_->SetIsDrawable(true); |
| progress_bar_->SetFillCenter(true); |
| + // Icon |
| + icon_layer_->SetIsDrawable(true); |
| + layer_->AddChild(icon_layer_); |
| + |
| // Thumbnail |
| thumbnail_layer_->SetIsDrawable(true); |
| } |