blob: c8ca0cdef3c875e88db8d8f3b95a1d4673636067 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#import "chrome/browser/ui/cocoa/app_menu/app_menu_button_cell.h"
#include "base/mac/scoped_nsobject.h"
#include "ui/gfx/scoped_ns_graphics_context_save_gstate_mac.h"
@implementation AppMenuButtonCell
- (void)drawBezelWithFrame:(NSRect)frame inView:(NSView*)controlView {
gfx::ScopedNSGraphicsContextSaveGState scopedGState;
// Inset the rect to match the appearance of the layout of interface builder.
// The bounding rect of buttons is actually larger than the display rect shown
// there.
frame = NSInsetRect(frame, 0.0, 1.0);
// Stroking the rect gives a weak stroke. Filling and insetting gives a
// strong, un-anti-aliased border.
[[NSColor colorWithDeviceWhite:0.663 alpha:1.0] set];
NSRectFill(frame);
frame = NSInsetRect(frame, 1.0, 1.0);
// The default state should be a subtle gray gradient.
if (![self isHighlighted]) {
NSColor* end = [NSColor colorWithDeviceWhite:0.922 alpha:1.0];
base::scoped_nsobject<NSGradient> gradient(
[[NSGradient alloc] initWithStartingColor:[NSColor whiteColor]
endingColor:end]);
[gradient drawInRect:frame angle:90.0];
} else {
// |+selectedMenuItemColor| appears to be a gradient, so just filling the
// rect with that color produces the desired effect.
[[NSColor selectedMenuItemColor] set];
NSRectFill(frame);
}
}
- (NSBackgroundStyle)interiorBackgroundStyle {
if ([self isHighlighted])
return NSBackgroundStyleDark;
return [super interiorBackgroundStyle];
}
@end
|