使用自定义NSView在悬停在NSMenuItem上时更改背景颜色

时间:2013-07-12 00:38:41

标签: objective-c macos cocoa nsview nsmenuitem

以下是:

我已创建了一个自定义NSMenuItem,其中包含自定义NSView

一切正常,但我无法让NSMenuItem突出显示(=在鼠标悬停时更改背景颜色)。

我正在尝试在drawRect方法中执行此操作,如此处发布的其他答案所示。

我做错了什么?


NSView子类:

@interface customView : NSView  
@end  
@implementation customView

- (id)initWithFrame:(NSRect)frame
{

    NSRect theRect = NSMakeRect(0, 0, 200, 30);
    self = [super initWithFrame:theRect];
    if (self) {
    NSTrackingArea *   trackingArea = [[NSTrackingArea alloc] initWithRect:theRect
                                                    options: (NSTrackingMouseEnteredAndExited  | NSTrackingActiveInKeyWindow  |NSTrackingActiveAlways)
                                                      owner:self userInfo:nil];
        [self addTrackingArea:trackingArea];
    }

    return self;
}

#define menuItem ([self enclosingMenuItem])

- (void) drawRect: (NSRect) rect {


    BOOL isHighlighted = [menuItem isHighlighted];
    if (isHighlighted) {
        //this nslog never happens
        NSLog(@"it's highlighted");
}



- (void)mouseUp:(NSEvent*) event {
    NSMenuItem* mitem = [self enclosingMenuItem];
    NSMenu* m = [mitem menu];
    [m cancelTracking];


    NSLog(@"you clicked the %ld item",[m indexOfItem: mitem]);
}
@end

NSMenuItem子类:
(我在此处添加自定义视图的子视图,以便我可以通过NSMenuItem实例访问控件)

@interface customItem : NSMenuItem{

}

-(void)setTheText:(NSString*)theString;

@property NSTextField *theLabel;
@end
#import "customItem.h"
#import "customView.h"
@implementation customItem
@synthesize theLabel;
-(id)init{

    if (self){

        customView *cv = [[customView alloc] init];
        theLabel = [[NSTextField alloc] initWithFrame:NSMakeRect(10, 8, 130, 17)];
        [theLabel setEditable:NO];
        [theLabel setBordered:NO];
        NSButton *myButton = [[NSButton alloc] initWithFrame:NSMakeRect(170, 7, 20, 20)];
        NSButton *myButton1 = [[NSButton alloc] initWithFrame:NSMakeRect(150, 7, 20, 20)];

        [myButton setBezelStyle:NSCircularBezelStyle]; 
        [myButton1 setBezelStyle:NSCircularBezelStyle]; 

        [myButton setTitle:@""];
        [myButton1 setTitle:@""];
        [cv addSubview:myButton];
        [cv addSubview:myButton1];
        [cv addSubview:theLabel];
        [self setView:cv];
        [theLabel setStringValue:@"A Value "];

    }

    return self;
}

-(void)setTheText:(NSString *)theString{

    [theLabel setStringValue:theString];
}


@end   

这是App Delegate:

@interface AppDelegate : NSObject <NSApplicationDelegate>{

    NSStatusItem *statusItem;
    IBOutlet NSMenu *theMenu;
}

@property (assign) IBOutlet NSWindow *window;

@end  
#import "customItem.h"
@implementation AppDelegate

- (void)applicationDidFinishLaunching:(NSNotification *)aNotification
{

}

- (void)awakeFromNib{

    statusItem = [[NSStatusBar systemStatusBar]
                  statusItemWithLength:NSSquareStatusItemLength];
    NSBundle *bundle = [NSBundle mainBundle];

    NSImage *statusImage = [[NSImage alloc] initWithContentsOfFile:[bundle pathForResource:@"barIcon" ofType:@"png"]];
   NSImage  *highlightImage = [[NSImage alloc] initWithContentsOfFile:[bundle pathForResource:@"barIcon_H" ofType:@"png"]];

    [statusItem setImage:statusImage];
    [statusItem setAlternateImage:highlightImage];


    [statusItem setMenu:theMenu];

    [theMenu removeAllItems];
     customItem *mi = [[customItem alloc] init];

   [theMenu addItem:mi];
   customItem *mi2 = [[customItem alloc] init];
   [theMenu addItem:mi2];  
}
@end

这就是我得到的:

NSMenuItem Issue Screenschot

3 个答案:

答案 0 :(得分:3)

无需添加布尔值或其他任何内容,您可以在附加到NSView

的自定义NSMenuItem内进行操作
- (void)drawRect:(NSRect)rect {

[super drawRect:rect];

//Handle the hightlight
if ([[self enclosingMenuItem] isHighlighted])
{
    [self.lbl_title setTextColor:[NSColor whiteColor]];
    [self.lbl_amount setTextColor:[NSColor colorWithDeviceRed:151.0f/255.0f green:164.0f/255.0f blue:179.0f/255.0f alpha:1.0f]];
    [[NSColor selectedMenuItemColor] setFill];
}
else
{
    [self.lbl_title setTextColor:[NSColor blackColor]];
    [self.lbl_amount setTextColor:[NSColor whiteColor]];
    [[self backgroundColor] setFill];
}
NSRectFill(rect);}

答案 1 :(得分:0)

好吧,我想我明白了 我在NSView子类中添加了一个公共bool变量 然后我用了

-(void)mouseEntered:(NSEvent *)theEvent

-(void)mouseExited:(NSEvent *)theEvent

将变量设置为YESNO。设置变量i后使用

[self setNeedsDisplay:YES] 

致电

-(void) drawRect: (NSRect) rect 

这就是我的工作方式:)。

答案 2 :(得分:0)

这是更改背景颜色(突出显示项目)而不保留局部变量并强制视图再次绘制的正确方法,

-(void)mouseEntered:(NSEvent *)event {
    self.layer.backgroundColor = [[NSColor blueColor] colorWithAlphaComponent:0.3].CGColor;
    [theLabel setTextColor:[NSColor whiteColor]];
}

-(void)mouseExited:(NSEvent *)event {
    self.layer.backgroundColor = [NSColor clearColor].CGColor;
    [theLabel setTextColor:[NSColor blackColor]];
}

在更改图层背景颜色之前,请确保还设置了[self setWantsLayer:YES]