NSButton鼠標(biāo)懸停、滑過、點(diǎn)擊事件

?AppKit和UIKit還是有很多區(qū)別的,國(guó)內(nèi)的資源比較少,做Mac開發(fā)的人也很少,導(dǎo)致我學(xué)的過程中常常伴著各種翻墻到國(guó)外網(wǎng)站去找,之前我也發(fā)過相關(guān)的文章,有興趣的同學(xué)可以看下。

說正題,我自己寫了一個(gè)繼承NSButton的類,處理了一些簡(jiǎn)單的東西。包括NSButton的鼠標(biāo)懸停、滑過、點(diǎn)擊更換圖片,因?yàn)镹SButton與UIButton不同,它沒有UIControlEvent這個(gè)枚舉,所以很多東西需要我們自己去寫。直接上代碼了

.m

#import "HSButton.h"

@implementation HSButton

{

NSString *imageName;

}

- (instancetype)initWithCoder:(NSCoder *)coder {

self = [super initWithCoder:coder];

if (self) {

imageName = self.image.name;

[HS_control setBtn:self textColor:[NSColor whiteColor]];

[self.cell setHighlightsBy:NSContentsCellMask];

self.alternateImage = [NSImage imageNamed:[NSString stringWithFormat:@"%@%@", imageName, @"_c"]];

// 設(shè)置圖片鋪滿button

[self.cell setImageScaling:NSImageScaleAxesIndependently];

// 去掉button邊框

[self setBordered:NO];

[self bezelStyle];

}

return self;

}

- (void)drawRect:(NSRect)dirtyRect {

[super drawRect:dirtyRect];

[HS_control setBtn:self textColor:[NSColor whiteColor]];

NSTrackingArea *area_V =[[NSTrackingArea alloc] initWithRect:self.bounds options:NSTrackingMouseEnteredAndExited|NSTrackingActiveInKeyWindow owner:self userInfo:nil];

[self addTrackingArea:area_V];

// Drawing code here.

}

- (void)mouseExited:(NSEvent *)event {

[self setImage:[NSImage imageNamed:imageName]];

}

- (void)mouseEntered:(NSEvent *)event {

[self setImage:[NSImage imageNamed:[NSString stringWithFormat:@"%@%@", imageName, @"_m"]]];

}

//- (void)mouseDown:(NSEvent *)event {

//? ? NSLog(@"按下");

//? ? [self setImage:[NSImage imageNamed:[NSString stringWithFormat:@"%@%@", imageName, @"_c"]]];

//}

//

//- (void)mouseUp:(NSEvent *)event {

//? ? [self setImage:[NSImage imageNamed:[NSString stringWithFormat:@"%@%@", imageName, @"_m"]]];

//? ? NSLog(@"抬起");

//}

- (void)mouseMoved:(NSEvent *)event {

}

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

注意:我讓公司美工做圖的時(shí)候每個(gè)按鈕給了我三種狀態(tài),命名統(tǒng)一規(guī)范(不嫌麻煩的話也可以自己命名),_c代表按下狀態(tài)圖片,_m代表滑過時(shí)候的狀態(tài)圖片。 eg:圖片名稱為 “myImage”,按下圖片就為“myImage_c”,對(duì)應(yīng)滑過圖片就是 “myImage_m”,這樣所有需要三種狀態(tài)的按鈕都會(huì)繼承這個(gè)類。

其中上面代碼中有兩個(gè)我注釋掉的方法mouseDown、mouseUp,分別為按下、抬起,起初我是想用這兩個(gè)方法,改變button的背景圖片,但是問題來了,這兩個(gè)方法會(huì)和button的select方法沖突?。?!這就蛋疼了,雖然可以用mouseDown代替select方法,但是就起不到封裝的目的了,如果想判斷這兩個(gè)方法的發(fā)起時(shí)間也有方法,但是實(shí)在是麻煩,最后找到了這個(gè)屬性alternateImage,雖然以前就知道,但是之前都不好使,原來它要搭配[self.cell setHighlightsBy:NSContentsCellMask];使用。

最后,因?yàn)楣疽蟮陌粹o比較統(tǒng)一,所以很多屬性我都是直接寫在了這個(gè)類里面,如果需要的同學(xué)可以單獨(dú)寫在外面賦值。

補(bǔ)充:代碼中有一個(gè)方法,是改變button字體顏色的[HS_control setBtn:self textColor:[NSColor whiteColor]];


+ (void)setBtn:(NSButton *)btn textColor:(NSColor *)textColor

{

NSMutableAttributedString *attrTitle = [[NSMutableAttributedString alloc]

initWithAttributedString:[btn attributedTitle]];

NSUInteger len = [attrTitle length];

NSRange range = NSMakeRange(0, len);

[attrTitle addAttribute:NSForegroundColorAttributeName

value:textColor

range:range];

[attrTitle fixAttributesInRange:range];

[btn setAttributedTitle:attrTitle];

}


如果有問題,歡迎交流 ?Demo?下載地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1.oc基本語(yǔ)法 // // main.m // oc基本語(yǔ)法 // // Created by lanou on...
    GOT_HODOR閱讀 556評(píng)論 0 0
  • iOS開發(fā)系列--網(wǎng)絡(luò)開發(fā) 概覽 大部分應(yīng)用程序都或多或少會(huì)牽扯到網(wǎng)絡(luò)開發(fā),例如說新浪微博、微信等,這些應(yīng)用本身可...
    lichengjin閱讀 4,036評(píng)論 2 7
  • 我與老王的連續(xù)寫作計(jì)劃,今天正好21天。 寫一點(diǎn)關(guān)于這21天連續(xù)寫作的體會(huì)。 我是偶爾在朋友圈看到了一篇轉(zhuǎn)載至簡(jiǎn)書...
    貓兒刺閱讀 350評(píng)論 2 1
  • 今天聽到一個(gè)詞,云端學(xué)習(xí)。聽到云端,腦袋里立馬冒出各種云,百度云,阿里云,騰訊云……云端學(xué)習(xí)是干啥的?把知識(shí)放到云...
    海星_love閱讀 2,185評(píng)論 0 0
  • 看了簡(jiǎn)友溪水映月的寶塔詩(shī)《竹林戀情》,以為是家鄉(xiāng)人為老家竹林集的抒情,看了之后方覺不是,盡管如此,還是讓我想起了自...
    林木成蔭閱讀 403評(píng)論 4 26

友情鏈接更多精彩內(nèi)容