| 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 317eef0cfe085b8ae5f4d8bef68351b2ab4196b6..ad18013c281dc04a9474f72f07eb9143e6858c11 100644
|
| --- a/chrome/browser/android/compositor/layer/contextual_search_layer.cc
|
| +++ b/chrome/browser/android/compositor/layer/contextual_search_layer.cc
|
| @@ -15,7 +15,8 @@
|
|
|
| namespace {
|
|
|
| -const SkColor kContextualSearchBarBorderColor = SkColorSetRGB(0xf1, 0xf1, 0xf1);
|
| +const SkColor kSearchBackgroundColor = SkColorSetRGB(0xee, 0xee, 0xee);
|
| +const SkColor kSearchBarBorderColor = SkColorSetRGB(0xf1, 0xf1, 0xf1);
|
|
|
| } // namespace
|
|
|
| @@ -31,11 +32,16 @@ scoped_refptr<ContextualSearchLayer> ContextualSearchLayer::Create(
|
| void ContextualSearchLayer::SetProperties(
|
| int search_bar_background_resource_id,
|
| int search_bar_text_resource_id,
|
| + int search_bar_shadow_resource_id,
|
| int search_provider_icon_resource_id,
|
| int search_icon_resource_id,
|
| int progress_bar_background_resource_id,
|
| int progress_bar_resource_id,
|
| + int search_promo_resource_id,
|
| content::ContentViewCore* content_view_core,
|
| + bool search_promo_visible,
|
| + float search_promo_height,
|
| + float search_promo_opacity,
|
| float search_panel_y,
|
| float search_panel_width,
|
| float search_bar_margin_top,
|
| @@ -44,6 +50,8 @@ void ContextualSearchLayer::SetProperties(
|
| bool search_bar_border_visible,
|
| float search_bar_border_y,
|
| float search_bar_border_height,
|
| + bool search_bar_shadow_visible,
|
| + float search_bar_shadow_opacity,
|
| float search_provider_icon_opacity,
|
| float search_icon_padding_left,
|
| float search_icon_opacity,
|
| @@ -131,9 +139,51 @@ void ContextualSearchLayer::SetProperties(
|
| search_icon_->SetOpacity(search_icon_opacity);
|
|
|
| // ---------------------------------------------------------------------------
|
| + // Search Promo
|
| + // ---------------------------------------------------------------------------
|
| + if (search_promo_visible) {
|
| + // Grab the Search Opt Out Promo resource.
|
| + ui::ResourceManager::Resource* search_promo_resource =
|
| + resource_manager_->GetResource(ui::ANDROID_RESOURCE_TYPE_DYNAMIC,
|
| + search_promo_resource_id);
|
| +
|
| + if (search_promo_resource) {
|
| + // Search Promo Container
|
| + if (search_promo_container_->parent() != layer_)
|
| + layer_->AddChild(search_promo_container_);
|
| +
|
| + int search_promo_content_height = search_promo_resource->size.height();
|
| + gfx::Size search_promo_size(search_panel_width, search_promo_height);
|
| + search_promo_container_->SetBounds(search_promo_size);
|
| + search_promo_container_->SetPosition(gfx::PointF(0.f, search_bar_height));
|
| + search_promo_container_->SetMasksToBounds(true);
|
| +
|
| + // Search Promo
|
| + if (search_promo_->parent() != search_promo_container_)
|
| + search_promo_container_->AddChild(search_promo_);
|
| +
|
| + search_promo_->SetUIResourceId(search_promo_resource->ui_resource->id());
|
| + search_promo_->SetBounds(search_promo_resource->size);
|
| + // Align promo at the bottom of the container so the confirmation button
|
| + // is is not clipped when resizing the promo.
|
| + search_promo_->SetPosition(
|
| + gfx::PointF(0.f, search_promo_height - search_promo_content_height));
|
| + search_promo_->SetOpacity(search_promo_opacity);
|
| + }
|
| + } else {
|
| + // TODO(pedrosimonetti): confirm with dtrainor@ that we don't need to remove
|
| + // the child too (since it's going to be removed when the parent is gone).
|
| +
|
| + // Search Promo Container
|
| + if (search_promo_container_.get() && search_promo_container_->parent())
|
| + search_promo_container_->RemoveFromParent();
|
| + }
|
| +
|
| + // ---------------------------------------------------------------------------
|
| // Search Content View
|
| // ---------------------------------------------------------------------------
|
| - content_view_container_->SetPosition(gfx::PointF(0.f, search_bar_height));
|
| + content_view_container_->SetPosition(
|
| + gfx::PointF(0.f, search_bar_height + search_promo_height));
|
| if (content_view_core && content_view_core->GetLayer().get()) {
|
| scoped_refptr<cc::Layer> content_view_layer = content_view_core->GetLayer();
|
| if (content_view_layer->parent() != content_view_container_)
|
| @@ -143,6 +193,32 @@ void ContextualSearchLayer::SetProperties(
|
| }
|
|
|
| // ---------------------------------------------------------------------------
|
| + // Search Bar Shadow
|
| + // ---------------------------------------------------------------------------
|
| + if (search_bar_shadow_visible) {
|
| + ui::ResourceManager::Resource* search_bar_shadow_resource =
|
| + resource_manager_->GetResource(ui::ANDROID_RESOURCE_TYPE_STATIC,
|
| + search_bar_shadow_resource_id);
|
| +
|
| + if (search_bar_shadow_resource) {
|
| + if (search_bar_shadow_->parent() != layer_)
|
| + layer_->AddChild(search_bar_shadow_);
|
| + }
|
| +
|
| + int shadow_height = search_bar_shadow_resource->size.height();
|
| + gfx::Size shadow_size(search_panel_width, shadow_height);
|
| +
|
| + search_bar_shadow_->SetUIResourceId(
|
| + search_bar_shadow_resource->ui_resource->id());
|
| + search_bar_shadow_->SetBounds(shadow_size);
|
| + search_bar_shadow_->SetPosition(gfx::PointF(0.f, search_bar_height));
|
| + search_bar_shadow_->SetOpacity(search_bar_shadow_opacity);
|
| + } else {
|
| + if (search_bar_shadow_.get() && search_bar_shadow_->parent())
|
| + search_bar_shadow_->RemoveFromParent();
|
| + }
|
| +
|
| + // ---------------------------------------------------------------------------
|
| // Search Panel.
|
| // ---------------------------------------------------------------------------
|
| layer_->SetPosition(gfx::PointF(0.f, search_panel_y));
|
| @@ -222,12 +298,15 @@ ContextualSearchLayer::ContextualSearchLayer(
|
| layer_(cc::Layer::Create()),
|
| search_bar_background_(cc::NinePatchLayer::Create()),
|
| search_bar_text_(cc::UIResourceLayer::Create()),
|
| + search_bar_shadow_(cc::UIResourceLayer::Create()),
|
| search_provider_icon_(cc::UIResourceLayer::Create()),
|
| search_icon_(cc::UIResourceLayer::Create()),
|
| content_view_container_(cc::Layer::Create()),
|
| search_bar_border_(cc::SolidColorLayer::Create()),
|
| progress_bar_(cc::NinePatchLayer::Create()),
|
| - progress_bar_background_(cc::NinePatchLayer::Create()) {
|
| + progress_bar_background_(cc::NinePatchLayer::Create()),
|
| + search_promo_(cc::UIResourceLayer::Create()),
|
| + search_promo_container_(cc::SolidColorLayer::Create()) {
|
| layer_->SetMasksToBounds(false);
|
| layer_->SetIsDrawable(true);
|
|
|
| @@ -248,9 +327,14 @@ ContextualSearchLayer::ContextualSearchLayer(
|
| search_icon_->SetIsDrawable(true);
|
| layer_->AddChild(search_icon_);
|
|
|
| + // Search Opt Out Promo
|
| + search_promo_container_->SetIsDrawable(true);
|
| + search_promo_container_->SetBackgroundColor(kSearchBackgroundColor);
|
| + search_promo_->SetIsDrawable(true);
|
| +
|
| // Search Bar Border
|
| search_bar_border_->SetIsDrawable(true);
|
| - search_bar_border_->SetBackgroundColor(kContextualSearchBarBorderColor);
|
| + search_bar_border_->SetBackgroundColor(kSearchBarBorderColor);
|
|
|
| // Progress Bar Background
|
| progress_bar_background_->SetIsDrawable(true);
|
| @@ -260,8 +344,11 @@ ContextualSearchLayer::ContextualSearchLayer(
|
| progress_bar_->SetIsDrawable(true);
|
| progress_bar_->SetFillCenter(true);
|
|
|
| - // Search Content View
|
| + // Search Content View Container
|
| layer_->AddChild(content_view_container_);
|
| +
|
| + // Search Bar Shadow
|
| + search_bar_shadow_->SetIsDrawable(true);
|
| }
|
|
|
| ContextualSearchLayer::~ContextualSearchLayer() {
|
|
|