2012-06-25 10 views

Odpowiedz

69

Jeśli chcesz używać mouseEntered: i mouseExited:, musisz użyć NSTrackingArea. Oto referencja NSTrackingArea Class Reference.

Przykład:

//Add this to Your imageView subclass 

-(void)mouseEntered:(NSEvent *)theEvent { 
    NSLog(@"Mouse entered"); 
} 

-(void)mouseExited:(NSEvent *)theEvent 
{ 
    NSLog(@"Mouse exited"); 
} 

-(void)updateTrackingAreas 
{ 
    [super updateTrackingAreas]; 
    if(trackingArea != nil) { 
     [self removeTrackingArea:trackingArea]; 
     [trackingArea release]; 
    } 

    int opts = (NSTrackingMouseEnteredAndExited | NSTrackingActiveAlways); 
    trackingArea = [ [NSTrackingArea alloc] initWithRect:[self bounds] 
               options:opts 
                owner:self 
               userInfo:nil]; 
    [self addTrackingArea:trackingArea]; 
} 
+36

Just another "dlaczego mam do czynienia z tego gówna" moment z API Apple. – ArtOfWarfare

+14

@ArtOfWarfare Albo rzeczywistość posiadania złożonej hierarchii widoków i niemożności wywoływania potencjalnie setek tysięcy metod, gdy użytkownik po prostu przesuwa wskaźnik nad porcją interfejsu użytkownika. To jest wiek stary ** Nigdy nie sondować, zawsze ciągnąć. ** – bbum

+0

Bingoo, pracował jak amulet – Pete

5

Swift 3 Wersja odpowiedzi @Justin Boo „s:

private var trackingArea: NSTrackingArea? 

override func updateTrackingAreas() { 
    if let trackingArea = self.trackingArea { 
     self.removeTrackingArea(trackingArea) 
    } 

    let options: NSTrackingAreaOptions = [.mouseEnteredAndExited, .activeAlways] 
    let trackingArea = NSTrackingArea(rect: self.bounds, options: options, owner: self, userInfo: nil) 
    self.addTrackingArea(trackingArea) 
} 
Powiązane problemy