設(shè)置頭部標題欄

參考:對UIView的擴展(Category)

實現(xiàn)的效果

頭部標題欄.png

.h 文件

#import <UIKit/UIKit.h>

@interface YYFirstViewController : UIViewController

@end

.m 文件

#import "YYFirstViewController.h"
#import "UIView+YYExtension.h" // 引入頭文件

@interface YYFirstViewController ()
@property (nonatomic, strong)UIView *indicatorView; // 指示器
@property (nonatomic, strong)UIButton *selectedBtn; //選中按鈕
@end

@implementation YYFirstViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // 初始化頂部標題欄
    [self setUpTitleView];
    
}

#pragma mark -初始化頂部標題欄
- (void)setUpTitleView{
    CGFloat y =  self.navigationController.navigationBar.height + [UIApplication sharedApplication].statusBarFrame.size.height;
    UIView *titleView = [[UIView alloc]initWithFrame:CGRectMake(0, y, self.view.width, 35)];
//    titleView.backgroundColor = [UIColor whiteColor];
//    titleView.alpha = 0.8; // 會讓內(nèi)部所有內(nèi)容半透明
    // 設(shè)置顏色半透明(三種方式)
    titleView.backgroundColor = [[UIColor whiteColor] colorWithAlphaComponent:0.7];
//    titleView.backgroundColor = [UIColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:0.7];
//    titleView.backgroundColor = [UIColor colorWithWhite:1.0 alpha:0.7];
    [self.view addSubview:titleView];
    
    
    // 創(chuàng)建指示器
    UIView *indicatorView = [[UIView alloc]init];
    indicatorView.backgroundColor = [UIColor redColor];
    indicatorView.height = 2; //(對UIView的擴展(Category))
    indicatorView.y = titleView.height - 2;//(對UIView的擴展(Category))
    self.indicatorView = indicatorView;
    [titleView addSubview:indicatorView];
    
    // 添加子標簽
    NSArray *titles= @[@"全部",
                       @"視頻",
                       @"聲音",
                       @"圖片",
                       @"段子"];
    CGFloat btnWidth = titleView.width / titles.count; //(對UIView的擴展(Category))
    CGFloat btnHeight = titleView.height;
    CGFloat btnY = 0.0;
    for (int i = 0; i < titles.count; i ++) {
        CGFloat btnX = i * btnWidth;
        UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
        btn.frame = CGRectMake(btnX, btnY, btnWidth, btnHeight);
        [btn setTitle:titles[i] forState:UIControlStateNormal];
        [btn setTitleColor:[UIColor grayColor] forState:UIControlStateNormal];
        [btn setTitleColor:[UIColor redColor] forState:UIControlStateDisabled];
        btn.titleLabel.font = [UIFont systemFontOfSize:14];
        [btn addTarget:self action:@selector(titleBtnAction:) forControlEvents:UIControlEventTouchUpInside];
        [titleView addSubview:btn];
        
        if (i == 0) {
            [btn layoutIfNeeded]; // 如果不加這句話,btn 的titleLabel的寬度為0(強制刷新一次)
            [self titleBtnAction:btn];
        }
    }
}

/**
 標題欄選中
 */
- (void)titleBtnAction:(UIButton *)btn{
    
    [UIView animateWithDuration:0.25 animations:^{
        // 交換三部曲
        self.selectedBtn.enabled = true;
        btn.enabled = false;
        self.selectedBtn = btn;
        // 交換三部曲
        /** 這種方法有問題
        self.selectedBtn.selected = false;
        btn.selected = true;
        self.selectedBtn = btn;
        */
        // 改變指示器
        self.indicatorView.width = btn.titleLabel.width;//1.重點  2.(對UIView的擴展(Category))
        self.indicatorView.centerX = btn.centerX; //(對UIView的擴展(Category))
    }];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
}

@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末紊搪,一起剝皮案震驚了整個濱河市妖爷,隨后出現(xiàn)的幾起案子兼蕊,更是在濱河造成了極大的恐慌,老刑警劉巖恳蹲,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡贮喧,警方通過查閱死者的電腦和手機顾瞪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進店門舔庶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玲昧,你說我怎么就攤上這事栖茉。” “怎么了孵延?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵吕漂,是天一觀的道長。 經(jīng)常有香客問我尘应,道長惶凝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任犬钢,我火速辦了婚禮苍鲜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘玷犹。我一直安慰自己混滔,他們只是感情好,可當我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布歹颓。 她就那樣靜靜地躺著坯屿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪巍扛。 梳的紋絲不亂的頭發(fā)上领跛,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天,我揣著相機與錄音吠昭,去河邊找鬼喊括。 笑死,一個胖子當著我的面吹牛矢棚,可吹牛的內(nèi)容都是我干的郑什。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼蒲肋,長吁一口氣:“原來是場噩夢啊……” “哼蹦误!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起肉津,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤强胰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后妹沙,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體偶洋,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年距糖,在試婚紗的時候發(fā)現(xiàn)自己被綠了玄窝。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡悍引,死狀恐怖恩脂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情趣斤,我是刑警寧澤俩块,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站浓领,受9級特大地震影響玉凯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜联贩,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一漫仆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泪幌,春花似錦盲厌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至浴滴,卻和暖如春拓萌,著一層夾襖步出監(jiān)牢的瞬間岁钓,已是汗流浹背升略。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工微王, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人品嚣。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓炕倘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親翰撑。 傳聞我的和親對象是個殘疾皇子罩旋,可洞房花燭夜當晚...
    茶點故事閱讀 45,512評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件眶诈、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,120評論 4 61
  • 你好逝撬,2017 伴著絲絲小雨浴骂,走過冬日霧霾,微信群里宪潮、QQ群里溯警,“新年快樂”的祝福,“元旦快樂”的紅包狡相,都在...
    5780933168ec閱讀 109評論 0 0
  • 晚上上夜班梯轻,去點名,看到老段躲在門口尽棕,正在撫摸一只小狗喳挑,我湊上去,很好奇滔悉,問他蟀悦,這是誰的狗他說不知道,小狗很溫順的...
    水玲瓏英子閱讀 246評論 0 1
  • 似水年華在時光里匆匆流過氧敢,曾經(jīng)豐茂的時光漸漸貧瘠日戈。但我任時光荒蕪,思念成城…… 你的離開孙乖,帶走了...
    多情的風閱讀 273評論 0 3
  • 現(xiàn)如今的各種自媒體越來越成為流行的閱讀方式唯袄,不知道從什么時候開始弯屈,低頭一族成為了社會主流的生活狀態(tài),我們習慣于將長...
    集杰先生閱讀 185評論 0 0