Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(119)

Side by Side Diff: chrome/browser/ui/views/ash/browser_non_client_frame_view_ash.cc

Issue 10816027: alternate ntp: toolbar background and separator animation (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address dhollowa's comments Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/browser/ui/views/ash/browser_non_client_frame_view_ash.h" 5 #include "chrome/browser/ui/views/ash/browser_non_client_frame_view_ash.h"
6 6
7 #include "ash/wm/frame_painter.h" 7 #include "ash/wm/frame_painter.h"
8 #include "ash/wm/workspace/frame_maximize_button.h" 8 #include "ash/wm/workspace/frame_maximize_button.h"
9 #include "chrome/browser/themes/theme_service.h" 9 #include "chrome/browser/themes/theme_service.h"
10 #include "chrome/browser/ui/browser.h" 10 #include "chrome/browser/ui/browser.h"
(...skipping 260 matching lines...) Expand 10 before | Expand all | Expand 10 after
271 ShouldPaintAsActive() ? 271 ShouldPaintAsActive() ?
272 ash::FramePainter::ACTIVE : ash::FramePainter::INACTIVE, 272 ash::FramePainter::ACTIVE : ash::FramePainter::INACTIVE,
273 GetThemeFrameImageId(), 273 GetThemeFrameImageId(),
274 GetThemeFrameOverlayImage()); 274 GetThemeFrameOverlayImage());
275 if (browser_view()->ShouldShowWindowTitle()) 275 if (browser_view()->ShouldShowWindowTitle())
276 frame_painter_->PaintTitleBar(this, canvas, BrowserFrame::GetTitleFont()); 276 frame_painter_->PaintTitleBar(this, canvas, BrowserFrame::GetTitleFont());
277 if (browser_view()->IsToolbarVisible()) { 277 if (browser_view()->IsToolbarVisible()) {
278 chrome::search::Mode mode = 278 chrome::search::Mode mode =
279 browser_view()->browser()->search_model()->mode(); 279 browser_view()->browser()->search_model()->mode();
280 bool fading_in = false; 280 bool fading_in = false;
281 // For |MODE_SEARCH|, get current state of background animation to figure 281 // Get current opacity of gradient background animation to figure out if
282 // out if we're waiting to fade in or in the process of fading in new 282 // we need to paint both flat and gradient backgrounds or just one:
283 // background for |MODE_SEARCH|. 283 // - if |gradient_opacity| < 1f, paint flat background at full opacity, and
284 // In the former case, just paint the previous background for |MODE_NTP|. 284 // only paint gradient background if |gradient_opacity| is not 0f;
285 // In the latter case, paint the previous background for |MODE_NTP| and then 285 // - if |gradient_opacity| is 1f, paint the background for the current mode
286 // the new background at specified opacity value. 286 // at full opacity.
287 if (mode.is_search()) { 287 double gradient_opacity = browser_view()->browser()->search_delegate()->
288 chrome::search::ToolbarSearchAnimator::BackgroundState background_state = 288 toolbar_search_animator().GetGradientOpacity();
289 chrome::search::ToolbarSearchAnimator::BACKGROUND_STATE_DEFAULT; 289 if (gradient_opacity < 1.0f) {
290 double search_background_opacity = -1.0f; 290 // Paint flat background of |MODE_NTP|.
291 browser_view()->browser()->search_delegate()->toolbar_search_animator(). 291 PaintToolbarBackground(canvas, chrome::search::Mode::MODE_NTP);
292 GetCurrentBackgroundState(&background_state, 292 // We're done if we're not showing gradient background.
293 &search_background_opacity); 293 if (gradient_opacity == 0.0f)
294 if (background_state & 294 return;
295 chrome::search::ToolbarSearchAnimator::BACKGROUND_STATE_NTP) { 295 // Otherwise, we're fading in gradient background at |gradient_opacity|.
296 // Paint background for |MODE_NTP|. 296 fading_in = true;
297 PaintToolbarBackground(canvas, chrome::search::Mode::MODE_NTP); 297 canvas->SaveLayerAlpha(static_cast<uint8>(gradient_opacity * 0xFF));
298 // We're done if we're not showing background for SEARCH mode.
299 if (!(background_state & chrome::search::ToolbarSearchAnimator::
300 BACKGROUND_STATE_SEARCH)) {
301 return;
302 }
303 // Otherwise, we're fading in the new background at
304 // |search_background_opacity|.
305 fading_in = true;
306 canvas->SaveLayerAlpha(static_cast<uint8>(
307 search_background_opacity * 0xFF));
308 }
309 } 298 }
310 // Paint the background for the current mode. 299 // Paint the background for the current mode.
311 PaintToolbarBackground(canvas, mode.mode); 300 PaintToolbarBackground(canvas, mode.mode);
312 // If we're fading in and have saved canvas, restore it now. 301 // If we're fading in and have saved canvas, restore it now.
313 if (fading_in) 302 if (fading_in)
314 canvas->Restore(); 303 canvas->Restore();
315 } else { 304 } else {
316 PaintContentEdge(canvas); 305 PaintContentEdge(canvas);
317 } 306 }
318 } 307 }
(...skipping 227 matching lines...) Expand 10 before | Expand all | Expand 10 after
546 toolbar_left->width(), theme_toolbar->height()); 535 toolbar_left->width(), theme_toolbar->height());
547 gfx::ImageSkia* toolbar_right = 536 gfx::ImageSkia* toolbar_right =
548 tp->GetImageSkiaNamed(IDR_TOOLBAR_SHADE_RIGHT); 537 tp->GetImageSkiaNamed(IDR_TOOLBAR_SHADE_RIGHT);
549 canvas->TileImageInt(*toolbar_right, 538 canvas->TileImageInt(*toolbar_right,
550 0, 0, 539 0, 0,
551 w - toolbar_right->width() - 2 * kClientEdgeThickness, 540 w - toolbar_right->width() - 2 * kClientEdgeThickness,
552 y + kClientEdgeThickness + kContentShadowHeight, 541 y + kClientEdgeThickness + kContentShadowHeight,
553 toolbar_right->width(), theme_toolbar->height()); 542 toolbar_right->width(), theme_toolbar->height());
554 543
555 // Only draw the content/toolbar separator if Instant Extended API is disabled 544 // Only draw the content/toolbar separator if Instant Extended API is disabled
556 // or mode is DEFAULT. 545 // or mode is |DEFAULT|.
557 bool extended_instant_enabled = chrome::search::IsInstantExtendedAPIEnabled( 546 bool extended_instant_enabled = chrome::search::IsInstantExtendedAPIEnabled(
558 browser_view()->browser()->profile()); 547 browser_view()->browser()->profile());
559 if (!extended_instant_enabled || mode == chrome::search::Mode::MODE_DEFAULT) { 548 if (!extended_instant_enabled || mode == chrome::search::Mode::MODE_DEFAULT) {
560 canvas->FillRect( 549 canvas->FillRect(
561 gfx::Rect(x + kClientEdgeThickness, 550 gfx::Rect(x + kClientEdgeThickness,
562 toolbar_bounds.bottom() - kClientEdgeThickness, 551 toolbar_bounds.bottom() - kClientEdgeThickness,
563 w - (2 * kClientEdgeThickness), kClientEdgeThickness), 552 w - (2 * kClientEdgeThickness),
553 kClientEdgeThickness),
564 ThemeService::GetDefaultColor(extended_instant_enabled ? 554 ThemeService::GetDefaultColor(extended_instant_enabled ?
565 ThemeService::COLOR_SEARCH_SEPARATOR_LINE : 555 ThemeService::COLOR_SEARCH_SEPARATOR_LINE :
566 ThemeService::COLOR_TOOLBAR_SEPARATOR)); 556 ThemeService::COLOR_TOOLBAR_SEPARATOR));
567 } 557 }
568 } 558 }
569 559
570 void BrowserNonClientFrameViewAsh::PaintContentEdge(gfx::Canvas* canvas) { 560 void BrowserNonClientFrameViewAsh::PaintContentEdge(gfx::Canvas* canvas) {
571 canvas->FillRect(gfx::Rect(0, close_button_->bounds().bottom(), 561 canvas->FillRect(gfx::Rect(0, close_button_->bounds().bottom(),
572 width(), kClientEdgeThickness), 562 width(), kClientEdgeThickness),
573 ThemeService::GetDefaultColor(ThemeService::COLOR_TOOLBAR_SEPARATOR)); 563 ThemeService::GetDefaultColor(ThemeService::COLOR_TOOLBAR_SEPARATOR));
(...skipping 25 matching lines...) Expand all
599 BrowserNonClientFrameViewAsh::GetThemeFrameOverlayImage() const { 589 BrowserNonClientFrameViewAsh::GetThemeFrameOverlayImage() const {
600 ui::ThemeProvider* tp = GetThemeProvider(); 590 ui::ThemeProvider* tp = GetThemeProvider();
601 if (tp->HasCustomImage(IDR_THEME_FRAME_OVERLAY) && 591 if (tp->HasCustomImage(IDR_THEME_FRAME_OVERLAY) &&
602 browser_view()->IsBrowserTypeNormal() && 592 browser_view()->IsBrowserTypeNormal() &&
603 !browser_view()->IsOffTheRecord()) { 593 !browser_view()->IsOffTheRecord()) {
604 return tp->GetImageSkiaNamed(ShouldPaintAsActive() ? 594 return tp->GetImageSkiaNamed(ShouldPaintAsActive() ?
605 IDR_THEME_FRAME_OVERLAY : IDR_THEME_FRAME_OVERLAY_INACTIVE); 595 IDR_THEME_FRAME_OVERLAY : IDR_THEME_FRAME_OVERLAY_INACTIVE);
606 } 596 }
607 return NULL; 597 return NULL;
608 } 598 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698