delegate簡單實現(xiàn)

Simulator Screen Shot 2016年10月20日 上午9.59.45.png

Simulator Screen Shot 2016年10月20日 上午9.59.51.png

如圖,導航標題欄是一個自定義view苏章,通過點擊手勢來切換不同的控制器寂嘉。首先,來看下這個自定義view的實現(xiàn):

#import <UIKit/UIKit.h>

@protocol SegmentedViewDelegate <NSObject>

/**
 *  自定義segment的點擊代理方法
 *
 *  @param index 選中按鈕的index;
 */
- (void)selectAtIndex:(NSUInteger)index;

@end

@interface SegmentedView : UIImageView

@property(nonatomic,weak) id<SegmentedViewDelegate> delegate;

@end

#import "SegmentedView.h"

@interface SegmentedView () {
    UIImageView *_leftView;
    UIImageView *_rightView;
    UILabel *_leftLabel;
    UILabel *_rightLabel;
}

@end

@implementation SegmentedView

- (id)init {
    if (self = [super init]) {
        [self prepareUI];
    }
    return self;
}

- (void)selectIndex:(NSUInteger)index {
    if (index == 0) {
        _leftView.image = [UIImage imageNamed:@"ZXselect_left"];
        _rightView.image = nil;
        _leftLabel.textColor = [UIColor whiteColor];
        _rightLabel.textColor = [UIColor blackColor];
        _leftLabel.userInteractionEnabled = NO;
        _rightLabel.userInteractionEnabled = YES;
    }
    else if (index == 1) {
        _leftView.image = nil;
        _rightView.image = [UIImage imageNamed:@"ZXselect_right"];
        _leftLabel.textColor = [UIColor blackColor];
        _rightLabel.textColor = [UIColor whiteColor];
        _leftLabel.userInteractionEnabled = YES;
        _rightLabel.userInteractionEnabled = NO;
    }
}

- (void)prepareUI {
    __weak SegmentedView *weakSelf = self;
    self.userInteractionEnabled = YES;
    self.image = [UIImage imageNamed:@"ZXselect_bg"];
    
    _leftView = [UIImageView new];
    _leftView.image = [UIImage imageNamed:@"ZXselect_left"];
    [self addSubview:_leftView];
    [_leftView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.left.equalTo(weakSelf);
        make.width.equalTo(weakSelf).multipliedBy(0.5);
        make.height.equalTo(weakSelf);
    }];
    
    _rightView = [UIImageView new];
    [self addSubview:_rightView];
    [_rightView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.right.equalTo(weakSelf);
        make.width.equalTo(weakSelf).multipliedBy(0.5);
        make.height.equalTo(weakSelf);
    }];
    
    _leftLabel = [UILabel new];
    _leftLabel.userInteractionEnabled = YES;
    _leftLabel.text = @"資訊";
    _leftLabel.textAlignment = NSTextAlignmentCenter;
    _leftLabel.textColor = [UIColor whiteColor];
    _leftLabel.font = [UIFont systemFontOfSize:14];
    [self addSubview:_leftLabel];
    [_leftLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.left.bottom.right.equalTo(_leftView);
    }];
    UITapGestureRecognizer *tapL = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapSegmentedView:)];
    [_leftLabel addGestureRecognizer:tapL];
    
    _rightLabel = [UILabel new];
    _rightLabel.userInteractionEnabled = YES;
    _rightLabel.text = @"消息";
    _rightLabel.textAlignment = NSTextAlignmentCenter;
    _rightLabel.textColor = [UIColor blackColor];
    _rightLabel.font = [UIFont systemFontOfSize:14];
    [self addSubview:_rightLabel];
    [_rightLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.left.bottom.right.equalTo(_rightView);
    }];
    UITapGestureRecognizer *tapR = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapSegmentedView:)];
    [_rightLabel addGestureRecognizer:tapR];
}

- (void)tapSegmentedView:(UITapGestureRecognizer *)tap {
    NSInteger index;
    if (tap.view == _leftView) {
        index = 0;
    }else{
        index = 1;
    }
    [self selectIndex:index];
    if (_delegate && [_delegate respondsToSelector:@selector(selectAtIndex:)]) {
        [_delegate selectAtIndex:index];
    }
}

在控制器中枫绅,實現(xiàn)代理方法泉孩。控制器.m文件:

#import "InformationController.h"
#import "SegmentedView.h"
#import "InfoChildController.h"
#import "MessageChildController.h"
#import "UITabBarController+HideTabBar.h"

@interface InformationController () <SegmentedViewDelegate> {
    SegmentedView *_segmentedView;
    InfoChildController *_infoChildController;
    MessageChildController *_messageChildController;
}

@end

@implementation InformationController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.fd_prefersNavigationBarHidden = NO;
    [self prepareNavigationBar];
    [self prepareChildViewController];
}

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
    [self.tabBarController setTabBarHidden:NO myClass:self];
}

- (void)prepareNavigationBar {
    self.navigationItem.leftBarButtonItem = nil;
    _segmentedView = [[SegmentedView alloc] init];
    _segmentedView.delegate = self;
    _segmentedView.bounds = CGRectMake(0, 0, 210, 25);
    self.navigationItem.titleView = _segmentedView;
}

- (void)prepareChildViewController {
    _infoChildController = [[InfoChildController alloc] init];
    [self addChildViewController:_infoChildController];
    [self.view addSubview:_infoChildController.view];
    _messageChildController = [[MessageChildController alloc] init];
    [self addChildViewController:_messageChildController];
    [self.view addSubview:_messageChildController.view];
    _messageChildController.view.hidden = YES;
}

#pragma mark - SegmentedViewDelegate
- (void)selectAtIndex:(NSUInteger)index {
    if (index == 0) {
        _infoChildController.view.hidden = NO;
        _messageChildController.view.hidden = YES;
    }
    else {
        _infoChildController.view.hidden = YES;
        _messageChildController.view.hidden = NO;
    }
}

@end
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末并淋,一起剝皮案震驚了整個濱河市寓搬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌县耽,老刑警劉巖句喷,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異兔毙,居然都是意外死亡唾琼,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門澎剥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锡溯,“玉大人,你說我怎么就攤上這事哑姚〖婪梗” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵叙量,是天一觀的道長倡蝙。 經(jīng)常有香客問我,道長宛乃,這世上最難降的妖魔是什么悠咱? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮征炼,結果婚禮上析既,老公的妹妹穿的比我還像新娘。我一直安慰自己谆奥,他們只是感情好眼坏,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著酸些,像睡著了一般宰译。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上魄懂,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天沿侈,我揣著相機與錄音,去河邊找鬼市栗。 笑死缀拭,一個胖子當著我的面吹牛,可吹牛的內容都是我干的填帽。 我是一名探鬼主播蛛淋,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼篡腌!你這毒婦竟也來了褐荷?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤嘹悼,失蹤者是張志新(化名)和其女友劉穎叛甫,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體杨伙,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡合溺,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了缀台。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棠赛。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖膛腐,靈堂內的尸體忽然破棺而出睛约,到底是詐尸還是另有隱情,我是刑警寧澤哲身,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布辩涝,位于F島的核電站,受9級特大地震影響勘天,放射性物質發(fā)生泄漏怔揩。R本人自食惡果不足惜捉邢,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望商膊。 院中可真熱鬧伏伐,春花似錦、人聲如沸晕拆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽实幕。三九已至吝镣,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間昆庇,已是汗流浹背末贾。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留整吆,地道東北人未舟。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像掂为,于是被迫代替她去往敵國和親裕膀。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,506評論 25 707
  • 發(fā)現(xiàn) 關注 消息 iOS 第三方庫勇哗、插件昼扛、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,024評論 4 62
  • #幸福是需要修出來的~每天進步1%~幸福實修09班~09.王文婷 ,銀川# 20170719(17/30) 【幸福...
    愛與幸福文婷閱讀 162評論 0 0
  • 擁抱未來貴不貴啊扰法?擁抱未來怎么樣蛹含?最近總在網(wǎng)上看到有人問這樣的問題。擁抱未來最近這么火塞颁?好多人不停提它浦箱。而且還挺奇...
    朵朵育兒經(jīng)驗交流閱讀 211評論 0 0
  • 夢里還為了它與親人爭執(zhí),媽媽幫著我 是啊祠锣,喜歡酷窥,可卻不是非有不可 因為一心想穿給你看,因此才念念不忘 我放下執(zhí)念了...
    一只獨角獸閱讀 217評論 0 0