diff options
author | thakis@chromium.org <thakis@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-09 23:44:24 +0000 |
---|---|---|
committer | thakis@chromium.org <thakis@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-09 23:44:24 +0000 |
commit | 13ad1c76c511fba1901c077886665b175c9de5f2 (patch) | |
tree | 4de64e29761b0676b2cc7ac66ed8e3640fb1343a /chrome/browser/cocoa/tabpose_window.mm | |
parent | 5fe6316e730734e9fb2f60f0a8b861f8c1192420 (diff) | |
download | chromium_src-13ad1c76c511fba1901c077886665b175c9de5f2.zip chromium_src-13ad1c76c511fba1901c077886665b175c9de5f2.tar.gz chromium_src-13ad1c76c511fba1901c077886665b175c9de5f2.tar.bz2 |
Mac: Highlight selected tile in tabpose.
BUG=50307
TEST=selected tile now has a blue border
TBR=trungl
Review URL: http://codereview.chromium.org/3140001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@55505 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/cocoa/tabpose_window.mm')
-rw-r--r-- | chrome/browser/cocoa/tabpose_window.mm | 44 |
1 files changed, 27 insertions, 17 deletions
diff --git a/chrome/browser/cocoa/tabpose_window.mm b/chrome/browser/cocoa/tabpose_window.mm index 1cad47a..7a7862f 100644 --- a/chrome/browser/cocoa/tabpose_window.mm +++ b/chrome/browser/cocoa/tabpose_window.mm @@ -370,17 +370,14 @@ void AnimateCALayerFrameFromTo( } - (CALayer*)selectedLayer { - return [allLayers_ objectAtIndex:tileSet_->selected_index()]; + return [allThumbnailLayers_ objectAtIndex:tileSet_->selected_index()]; } - (void)selectTileAtIndex:(int)newIndex { - // TODO(thakis): Have a nicer indicator for the current selection - // (a blue outline, probably). - int oldIndex = tileSet_->selected_index(); - CALayer* oldSelectedLayer = [allLayers_ objectAtIndex:oldIndex]; - oldSelectedLayer.backgroundColor = CGColorGetConstantColor(kCGColorBlack); - CALayer* newSelectedLayer = [allLayers_ objectAtIndex:newIndex]; - newSelectedLayer.backgroundColor = CGColorGetConstantColor(kCGColorWhite); + ScopedCAActionDisabler disabler; + const tabpose::Tile& tile = tileSet_->tile_at(newIndex); + selectionHighlight_.frame = + NSRectToCGRect(NSInsetRect(tile.thumb_rect(), -6, -6)); tileSet_->set_selected_index(newIndex); } @@ -399,6 +396,15 @@ void AnimateCALayerFrameFromTo( bgLayer_.masksToBounds = YES; [rootLayer_ addSublayer:bgLayer_]; + // Selection highlight layer. + darkBlue_.reset(CGColorCreateGenericRGB(0.25, 0.34, 0.86, 1.0)); + selectionHighlight_ = [CALayer layer]; + selectionHighlight_.backgroundColor = darkBlue_; + selectionHighlight_.cornerRadius = 5.0; + selectionHighlight_.zPosition = -1; // Behind other layers. + selectionHighlight_.hidden = YES; + [bgLayer_ addSublayer:selectionHighlight_]; + // Top gradient. CALayer* gradientLayer = [DarkGradientLayer layer]; gradientLayer.frame = CGRectMake( @@ -413,13 +419,13 @@ void AnimateCALayerFrameFromTo( tileSet_->Build(tabStripModel_); tileSet_->Layout(bgLayerRect); - allLayers_.reset( + allThumbnailLayers_.reset( [[NSMutableArray alloc] initWithCapacity:tabStripModel_->count()]); for (int i = 0; i < tabStripModel_->count(); ++i) { CALayer* layer = [CALayer layer]; // Background color as placeholder for now. - layer.backgroundColor = CGColorGetConstantColor(kCGColorBlack); + layer.backgroundColor = CGColorGetConstantColor(kCGColorWhite); AnimateCALayerFrameFromTo( layer, @@ -440,7 +446,7 @@ void AnimateCALayerFrameFromTo( layer.shadowOffset = CGSizeMake(0, -10); [bgLayer_ addSublayer:layer]; - [allLayers_ addObject:layer]; + [allThumbnailLayers_ addObject:layer]; } [self selectTileAtIndex:tileSet_->selected_index()]; } @@ -480,8 +486,8 @@ void AnimateCALayerFrameFromTo( - (void)mouseMoved:(NSEvent*)event { int newIndex = -1; CGPoint p = NSPointToCGPoint([event locationInWindow]); - for (NSUInteger i = 0; i < [allLayers_ count]; ++i) { - CALayer* layer = [allLayers_ objectAtIndex:i]; + for (NSUInteger i = 0; i < [allThumbnailLayers_ count]; ++i) { + CALayer* layer = [allThumbnailLayers_ objectAtIndex:i]; CGPoint lp = [layer convertPoint:p fromLayer:rootLayer_]; if ([static_cast<CALayer*>([layer presentationLayer]) containsPoint:lp]) newIndex = i; @@ -531,17 +537,19 @@ void AnimateCALayerFrameFromTo( // Move the selected layer on top of all other layers. [self selectedLayer].zPosition = 1; + selectionHighlight_.hidden = YES; + // Running animations with shadows is slow, so turn shadows off before // running the exit animation. - for (CALayer* layer in allLayers_.get()) + for (CALayer* layer in allThumbnailLayers_.get()) layer.shadowOpacity = 0.0; } // Animate layers out, all in one transaction. CGFloat duration = kDefaultAnimationDuration * (slomo ? kSlomoFactor : 1); ScopedCAActionSetDuration durationSetter(duration); - for (NSUInteger i = 0; i < [allLayers_ count]; ++i) { - CALayer* layer = [allLayers_ objectAtIndex:i]; + for (NSUInteger i = 0; i < [allThumbnailLayers_ count]; ++i) { + CALayer* layer = [allThumbnailLayers_ objectAtIndex:i]; // |start_thumb_rect_| was relative to |initial_index_|, now this needs to // be relative to |selectedIndex_| (whose start rect was relative to // |initial_index_| too) @@ -570,10 +578,12 @@ void AnimateCALayerFrameFromTo( DCHECK_EQ(tabpose::kFadingIn, state_); state_ = tabpose::kFadedIn; + selectionHighlight_.hidden = NO; + // Running animations with shadows is slow, so turn shadows on only after // the animation is done. ScopedCAActionDisabler disableCAActions; - for (CALayer* layer in allLayers_.get()) + for (CALayer* layer in allThumbnailLayers_.get()) layer.shadowOpacity = 0.5; } } else if ([animationId isEqualToString:kAnimationIdFadeOut]) { |