亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

IOS自定義UIButton九宮格效果

 更新時(shí)間:2019年12月25日 16:04:45   作者:Aftery的博客  
這篇文章主要介紹了IOS自定義UIButton九宮格效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

此篇文章給大家描寫如何寫自定義九宮格,因?yàn)樵陂_(kāi)發(fā)中,這種需求也是常見(jiàn)不少。因此,主要利用UIButton闡述的;

實(shí)列不復(fù)雜,就兩三個(gè)步驟完成:

一、定義寬度與高度(self.view)

#define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width
#define SCREEN_HEIGHT [UIScreen mainScreen].bounds.size.height

#define JHRGB(r,g,b) [UIColor colorWithRed:(r/255.0) green:(g/255.0) blue:(b/255.0) alpha:1.0]
#define JHRandomColor JHRGB(arc4random_uniform(255), arc4random_uniform(255), arc4random_uniform(255))

二、定義九宮格的文字與圖片

@property (nonatomic, strong) NSArray * titlesArr;

@property (nonatomic, strong) UILabel * numberLab;

@property (nonatomic, strong) NSArray * titleimg;

-(NSArray *)titlesArr{
 if (!_titlesArr) {
 _titlesArr = @[@"首頁(yè)",@"采購(gòu)",@"文章",@"社區(qū)",@"服務(wù)",@"掃描",@"定位",@"售后",@"訂單"];
 }
 return _titlesArr;
}
-(NSArray *)titleimg{
 if (!_titleimg) {
 _titleimg = @[@"me",@"msg",@"meg",@"1",@"2",@"3",@"me",@"2",@"3"];
 }
 return _titleimg;
}

三、循環(huán)出9個(gè)UIBtton數(shù)據(jù),以及相關(guān)樣式動(dòng)態(tài)調(diào)整

-(void)setButton{
 NSInteger totalLoc = 3;//一列三個(gè)數(shù)
 CGFloat W = 50;//寬度
 CGFloat H = W;//高度
 CGFloat margin=(self.view.frame.size.width-totalLoc * W)/(totalLoc+1);
 
 for (NSInteger i = 0; i < self.titlesArr.count; i++) {//循環(huán)體
 
 UIButton * btn = [UIButton buttonWithType:UIButtonTypeCustom];//button的定義
 btn.frame = CGRectMake(100, 100, 80, 80);//button大小
 
 [btn setTitle:self.titlesArr[i] forState:UIControlStateNormal];//動(dòng)態(tài)設(shè)置button文本
 [btn setBackgroundImage:[UIImage imageNamed:self.titleimg[i]] forState:UIControlStateNormal];//動(dòng)態(tài)設(shè)置圖片
 [btn setTitleColor:[UIColor darkGrayColor] forState:0];//文本的顏色
 [btn setImageEdgeInsets:UIEdgeInsetsMake(5, 25, 45, 25)];//圖片的大小
 [btn setTitleEdgeInsets:UIEdgeInsetsMake(80, 0, 5, 0)];//文本的位置
 //btn.backgroundColor = [UIColor blueColor];
 
 /*計(jì)算frame*/
 NSInteger row = i / totalLoc;//行號(hào)
 NSInteger loc = i % totalLoc;//列號(hào)
 //0/3=0,1/3=0,2/3=0,3/3=1;
 //0%3=0,1%3=1,2%3=2,3%3=0;
 CGFloat X= margin + (margin + W) * loc;
 CGFloat Y= margin + (margin + H) * row;
 btn.frame = CGRectMake(X, Y, W, H);
 
 //設(shè)置tag值(這里的tag,只是為了讓button的每次點(diǎn)擊都有不同的動(dòng)畫效果)
 btn.tag = i;
 
 [btn addTarget:self action:@selector(clickBtn:) forControlEvents:UIControlEventTouchUpInside];
 
 [self.lgView.imgview addSubview:btn];
 }
}

四、點(diǎn)擊按鈕的事件監(jiān)聽(tīng)

-(void)clickBtn:(UIButton *)btn{
 
 NSString *stringInt = [NSString stringWithFormat:@"%ld",(long)btn.tag];
 
 btn.layer.transform = CATransform3DMakeScale(0.5*arc4random_uniform([stringInt floatValue]), 0.5*arc4random_uniform([stringInt floatValue]), 1);
 
 self.numberLab.text = btn.titleLabel.text;
 NSLog(@"%@wo dian ji l:",stringInt);
 [UIView animateWithDuration:0.5 animations:^{
 
 btn.layer.transform = CATransform3DMakeScale(1, 1, 1);
 
 }];
}

總結(jié):

如下邏輯分析:

1.上面用的是masonry布局,所以我的view容器就沒(méi)用寬度,高度(寫在我的view層里了)。
2.先定義一個(gè)View容器
3.在容器里,循環(huán)體里面定義button,設(shè)置button的屬性等。
4.定義相關(guān)的數(shù)組,如:(文本,圖片)
5.點(diǎn)擊按鈕事件觸發(fā)函數(shù);

就以上信息需要理解的邏輯,把上面的復(fù)制粘貼就可以,項(xiàng)目親測(cè)可以的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • iOS之異常與信號(hào)使用場(chǎng)景分析

    iOS之異常與信號(hào)使用場(chǎng)景分析

    這篇文章主要為大家介紹了iOS之異常與信號(hào)使用場(chǎng)景分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • iOS中謂詞(NSPredicate)的基本入門使用教程

    iOS中謂詞(NSPredicate)的基本入門使用教程

    這篇文章主要給大家介紹了關(guān)于iOS中謂詞(NSPredicate)的基本入門使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • iOS百度地圖簡(jiǎn)單使用詳解

    iOS百度地圖簡(jiǎn)單使用詳解

    百度地圖的功能有很多,本篇文章主要介紹了iOS百度地圖簡(jiǎn)單使用詳解,具有一定的參考價(jià)值,有需要的可以了解一下。
    2016-11-11
  • iOS Touch ID指紋識(shí)別技術(shù)簡(jiǎn)介

    iOS Touch ID指紋識(shí)別技術(shù)簡(jiǎn)介

    這篇文章主要為大家詳細(xì)介紹了iOS Touch ID指紋識(shí)別技術(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • iOS開(kāi)發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決

    iOS開(kāi)發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決

    大家都知道WebViewJavascriptBridge它主要幫助我們優(yōu)雅的實(shí)現(xiàn)OC與JS的交互,下面這篇文章主要給大家介紹了關(guān)于iOS開(kāi)發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-10-10
  • iOS實(shí)現(xiàn)點(diǎn)擊狀態(tài)欄自動(dòng)回到頂部效果詳解

    iOS實(shí)現(xiàn)點(diǎn)擊狀態(tài)欄自動(dòng)回到頂部效果詳解

    在IOS開(kāi)發(fā)過(guò)程中,經(jīng)常會(huì)有這種需求,需要通過(guò)點(diǎn)擊狀態(tài)欄返回到頂部,給用戶更好的體驗(yàn)效果,下面這篇文章給大家詳細(xì)介紹了實(shí)現(xiàn)過(guò)程,有需要的可以參考借鑒。
    2016-09-09
  • iOS實(shí)現(xiàn)輪盤動(dòng)態(tài)效果

    iOS實(shí)現(xiàn)輪盤動(dòng)態(tài)效果

    這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)輪盤動(dòng)態(tài)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • iOS 使用Moya網(wǎng)絡(luò)請(qǐng)求的實(shí)現(xiàn)方法

    iOS 使用Moya網(wǎng)絡(luò)請(qǐng)求的實(shí)現(xiàn)方法

    這篇文章主要介紹了iOS 使用Moya網(wǎng)絡(luò)請(qǐng)求的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • IOS實(shí)現(xiàn)手動(dòng)截圖并保存

    IOS實(shí)現(xiàn)手動(dòng)截圖并保存

    這篇文章主要介紹了IOS實(shí)現(xiàn)手動(dòng)剪裁圖片并保存到相冊(cè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-01-01
  • iOS 統(tǒng)計(jì)Xcode項(xiàng)目代碼行數(shù)的實(shí)例

    iOS 統(tǒng)計(jì)Xcode項(xiàng)目代碼行數(shù)的實(shí)例

    下面小編就為大家分享一篇iOS 統(tǒng)計(jì)Xcode項(xiàng)目代碼行數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01

最新評(píng)論