IOS 九宮格布局實(shí)現(xiàn)方法
以前剛開(kāi)始搞iOS的時(shí)候大部分都是通過(guò)計(jì)算frame來(lái)布局視圖,搞著搞著貌似都是用自動(dòng)布局來(lái)搞定了,因?yàn)樽詣?dòng)布局實(shí)在太方便、太好用了,所以當(dāng)我昨天突然回看以前代碼的時(shí)候突然看到了以前寫(xiě)的九宮格布局,感覺(jué)很多東西都忘了,所以今天特意在這里記錄一下,并且通過(guò)幾個(gè)簡(jiǎn)單的宏定義來(lái)完成布局的需求,具體大家看代碼吧,都有注釋 很好懂:
// // ButtonContainerView.h // chemuchao // // Created by 遇見(jiàn)遠(yuǎn)洋 on 16/3/7. // Copyright © 2016年 zhaoxiaolu. All rights reserved. // #import <UIKit/UIKit.h> //按鈕點(diǎn)擊block typedef void(^spitlotBtnClick)(UIButton * btn); @interface ButtonContainerView : UIView @property (nonatomic,copy)spitlotBtnClick spitlotBlock;/**<<#展示對(duì)話內(nèi)容的tableview#>*/ @end
這里給大家推薦一個(gè)寫(xiě)注釋的好方法吧,在聲明屬性的時(shí)候,我們?nèi)绻朐趧e的地方調(diào)用這個(gè)屬性的時(shí)候在下方有提示 如圖:

只需要跟我在上面聲明屬性的時(shí)候一樣 在最后加上
/**<這是要寫(xiě)的提示文字*/
使用這種方式聲明的屬性,在外面調(diào)用的時(shí)候就會(huì)有提示,好像跑題了,接下來(lái)點(diǎn)M的代碼吧:
//
// ButtonContainerView.m
// chemuchao
//
// Created by 遇見(jiàn)遠(yuǎn)洋 on 16/3/7.
// Copyright © 2016年 zhaoxiaolu. All rights reserved.
//
#import "ButtonContainerView.h"
#import "UIView+Extension.h"
//狀態(tài)欄高度
#define kStateHeight 20
//總行數(shù)
#define kRows 2
//總列數(shù)
#define kCols 4
//九宮格個(gè)數(shù)
#define kCount 8
//九宮格之間的間隙
#define kMargin 5
//字體大小
#define kFont15 [UIFont systemFontOfSize:15]
@interface ButtonContainerView ()
@property (nonatomic,strong)NSMutableArray * btns;
@property (nonatomic,strong)NSArray * btnTitles;
@end
@implementation ButtonContainerView
- (NSMutableArray *)btns
{
if (!_btns) {
_btns = [NSMutableArray array];
}
return _btns;
}
-(NSArray *)btnTitles {
if (!_btnTitles) {
_btnTitles = @[@"堵成狗",@"堵成翔",@"路太窄",@"沒(méi)燈",@"路不平",@"積水多",@"顛簸",@"路太臟"];
}
return _btnTitles;
}
- (instancetype)initWithFrame:(CGRect)frame{
if (self = [super initWithFrame:frame]) {
[self setupUI];
}
return self;
}
- (void)setupUI {
for (int i = 0; i < kCount; i++) {
UIButton * btn = [[UIButton alloc]init];
[btn setTitle:self.btnTitles[i] forState:UIControlStateNormal];
[self addSubview:btn];
btn.layer.borderWidth = 1;
btn.layer.borderColor = [UIColor redColor].CGColor;
btn.titleLabel.font = [UIFont systemFontOfSize:13];
[btn setTitleColor:[UIColor grayColor] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(spitlotBtnClick:) forControlEvents:UIControlEventTouchUpInside];
[self.btns addObject:btn];
}
}
-(void)layoutSubviews {
[super layoutSubviews];
[self.btns enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
UIButton * btn = obj;
btn.tag = idx;
//行號(hào)
NSUInteger row = idx/kCols;
//列號(hào)
NSUInteger col = idx%kCols;
CGFloat btnW = (self.width - kMargin*(kCols + 1))/kCols;
CGFloat btnH = (self.height - kMargin*(kRows + 1))/kRows -10;
CGFloat btnX = kMargin + col*(kMargin + btnW);
CGFloat btnY = kMargin + row*(kMargin + btnH) + kStateHeight;
btn.frame = CGRectMake(btnX, btnY, btnW, btnH);
}];
}
#pragma mark 按鈕點(diǎn)擊事件
- (void)spitlotBtnClick:(UIButton *)sender {
NSAssert(self.spitlotBlock != nil, @"傳入的block不能為空");
//執(zhí)行block
self.spitlotBlock(sender);
}
@end
你只需要更換幾個(gè)宏定義就可以定制你的九宮格布局了,例如總行數(shù)、總列數(shù)、九宮格個(gè)數(shù),簡(jiǎn)單吧 復(fù)用性還是很高的,當(dāng)然對(duì)于使用自動(dòng)布局的你來(lái)說(shuō),可以無(wú)視我。
希望通過(guò)此文能幫助大家開(kāi)發(fā) IOS九宮格的開(kāi)發(fā),謝謝大家對(duì)本站的支持!
- IOS自定義UIButton九宮格效果
- iOS實(shí)現(xiàn)九宮格自動(dòng)生成視圖
- 關(guān)于iOS自帶九宮格拼音鍵盤(pán)和Emoji表情之間的一些坑
- iOS仿郵箱大師的九宮格手勢(shì)密碼解鎖
- 深入解析iOS應(yīng)用開(kāi)發(fā)中九宮格視圖布局的相關(guān)計(jì)算方法
- 詳解iOS應(yīng)用UI開(kāi)發(fā)中的九宮格坐標(biāo)計(jì)算與字典轉(zhuǎn)換模型
- 使用Swift代碼實(shí)現(xiàn)iOS手勢(shì)解鎖、指紋解鎖實(shí)例詳解
- iOS實(shí)現(xiàn)手勢(shì)解鎖操作
- iOS實(shí)現(xiàn)九宮格連線手勢(shì)解鎖
相關(guān)文章
IOS property屬性詳細(xì)介紹使用注意事項(xiàng)
這篇文章主要介紹了IOS property屬性詳細(xì)介紹使用注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2017-02-02
iOS自帶動(dòng)畫(huà)效果的實(shí)例代碼
本文給大家分享ios自帶動(dòng)畫(huà)效果的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2016-12-12
iOS 判斷頁(yè)面中的該填項(xiàng)是否填完整,改變按鈕狀態(tài)的方法
下面小編就為大家分享一篇iOS 判斷頁(yè)面中的該填項(xiàng)是否填完整,改變按鈕狀態(tài)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
如何利用FutureBuilder提高開(kāi)發(fā)效率
這篇文章主要給大家介紹了關(guān)于如何利用FutureBuilder提高開(kāi)發(fā)效率的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
iOS開(kāi)發(fā)筆記--詳解UILabel的相關(guān)屬性設(shè)置
這篇文章主要介紹了iOS開(kāi)發(fā)筆記--詳解UILabel的相關(guān)屬性設(shè)置,對(duì)初學(xué)者具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11
ios 單利的完整使用實(shí)例 及銷(xiāo)毀 宏定義
下面小編就為大家分享一篇ios 單利的完整使用實(shí)例 及銷(xiāo)毀 宏定義,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
詳解ios中的SQL數(shù)據(jù)庫(kù)文件加密 (使用sqlcipher)
本篇文章主要介紹了ios中的SQL數(shù)據(jù)庫(kù)文件加密 (使用sqlcipher),具有一定的參考價(jià)值,這里整理了詳細(xì)的代碼,感興趣的小伙伴們可以參考一下。2016-12-12

