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 e4142ee40009bb9fdc704abb07d29e3a9ea103ec..21659266a04231a3145eb7af4a9a3afdcc447707 100644 |
| --- a/chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| +++ b/chrome/browser/android/compositor/layer/contextual_search_layer.cc |
| @@ -38,6 +38,7 @@ void ContextualSearchLayer::SetProperties( |
| int search_provider_icon_resource_id, |
| int search_icon_resource_id, |
| int arrow_up_resource_id, |
| + int close_icon_resource_id, |
| int progress_bar_background_resource_id, |
| int progress_bar_resource_id, |
| int search_promo_resource_id, |
| @@ -61,6 +62,8 @@ void ContextualSearchLayer::SetProperties( |
| bool arrow_icon_visible, |
| float arrow_icon_opacity, |
| float arrow_icon_rotation, |
| + bool close_icon_visible, |
| + float close_icon_opacity, |
| bool progress_bar_visible, |
| float progress_bar_y, |
| float progress_bar_height, |
| @@ -147,8 +150,8 @@ void ContextualSearchLayer::SetProperties( |
| // Centers the Search Icon vertically in the Search Bar. |
| float search_icon_top = |
| - search_bar_margin_top + (search_bar_height - search_bar_margin_top) / 2 - |
| - search_icon_resource->size.height() / 2; |
| + search_bar_margin_top + (search_bar_height - search_bar_margin_top) / 2 |
| + - search_icon_resource->size.height() / 2; |
|
pedro (no code reviews)
2015/07/08 20:15:05
Nit: Differently from Java, the operator should be
Theresa
2015/07/08 21:04:59
Done.
|
| search_icon_->SetUIResourceId(search_icon_resource->ui_resource->id()); |
| search_icon_->SetBounds(search_icon_resource->size); |
| search_icon_->SetPosition( |
| @@ -204,6 +207,42 @@ void ContextualSearchLayer::SetProperties( |
| } |
| // --------------------------------------------------------------------------- |
| + // Close Icon |
| + // --------------------------------------------------------------------------- |
| + if (close_icon_visible) { |
| + // Grab the Close Icon resource. |
| + ui::ResourceManager::Resource* close_icon_resource = |
| + resource_manager_->GetResource(ui::ANDROID_RESOURCE_TYPE_STATIC, |
| + close_icon_resource_id); |
| + if (close_icon_->parent() != layer_) { |
| + layer_->AddChild(close_icon_); |
| + } |
| + |
| + // Positions the icon at the end of the Search Bar. |
| + float close_icon_left; |
| + if (is_rtl) { |
| + close_icon_left = search_bar_margin_side; |
| + } else { |
| + close_icon_left = search_panel_width - |
| + close_icon_resource->size.width() - search_bar_margin_side; |
| + } |
| + |
| + // Centers the Close Icon vertically in the Search Bar. |
| + float close_icon_top = search_bar_margin_top + |
| + (search_bar_height - search_bar_margin_top) / 2 - |
| + close_icon_resource->size.height() / 2; |
| + |
| + close_icon_->SetUIResourceId(close_icon_resource->ui_resource->id()); |
| + close_icon_->SetBounds(close_icon_resource->size); |
| + close_icon_->SetPosition( |
| + gfx::PointF(close_icon_left, close_icon_top)); |
| + close_icon_->SetOpacity(close_icon_opacity); |
| + } else { |
| + if (close_icon_.get() && close_icon_->parent()) |
| + close_icon_->RemoveFromParent(); |
| + } |
| + |
| + // --------------------------------------------------------------------------- |
| // Search Promo |
| // --------------------------------------------------------------------------- |
| if (search_promo_visible) { |
| @@ -372,6 +411,8 @@ ContextualSearchLayer::ContextualSearchLayer( |
| cc::UIResourceLayer::Create(content::Compositor::LayerSettings())), |
| arrow_icon_( |
| cc::UIResourceLayer::Create(content::Compositor::LayerSettings())), |
| + close_icon_( |
| + cc::UIResourceLayer::Create(content::Compositor::LayerSettings())), |
| content_view_container_( |
| cc::Layer::Create(content::Compositor::LayerSettings())), |
| search_bar_border_( |
| @@ -407,6 +448,9 @@ ContextualSearchLayer::ContextualSearchLayer( |
| // Arrow Icon |
| arrow_icon_->SetIsDrawable(true); |
| + // Close Icon |
| + close_icon_->SetIsDrawable(true); |
| + |
| // Search Opt Out Promo |
| search_promo_container_->SetIsDrawable(true); |
| search_promo_container_->SetBackgroundColor(kSearchBackgroundColor); |