亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS Tabbar中間添加凸起可旋轉按鈕功能

2019-10-21 18:42:55
字體:
來源:轉載
供稿:網友

最近的項目中有需求在tabbar中間添加凸起按鈕,并且點擊時按鈕要旋轉,看了仿斗魚的凸起,點擊后是present出來View,而不是像常規的tabbar上添加一個頁面,所以不符合要求,經過一段摸索最后得的一個比較好的效果,下面看效果圖

ios,tabbar,凸起可旋轉按鈕,旋轉按鈕

![效果圖.gif]

##需求分析

* tabbar有5個item,每個對應一個頁面

* 中間item為凸起按鈕

* 中間按鈕點擊后旋轉

##效果實現

* 設置5個item

我們一步步來解決這個問題,首先創建MCTabBarController繼承UITabBarController,然后和常規一樣創建5個item,中間的按鈕不設置圖片,代碼如下

//MCTabBarController.m//添加子控制器- (void)addChildViewControllers{ //圖片大小建議32*32 [self addChildrenViewController:[[ViewController alloc] init] andTitle:@"首頁" andImageName:@"tab1_n" andSelectImage:@"tab1_p"]; [self addChildrenViewController:[[ViewController alloc] init] andTitle:@"擴展" andImageName:@"tab2_n" andSelectImage:@"tab2_p"]; //中間這個不設置東西,只占位 [self addChildrenViewController:[[ViewController alloc] init] andTitle:@"旋轉" andImageName:@"" andSelectImage:@""]; [self addChildrenViewController:[[ViewController alloc] init] andTitle:@"發現" andImageName:@"tab3_n" andSelectImage:@"tab3_p"]; [self addChildrenViewController:[[ViewController alloc] init] andTitle:@"我" andImageName:@"tab4_n" andSelectImage:@"tab4_p"];}- (void)addChildrenViewController:(UIViewController *)childVC andTitle:(NSString *)title andImageName:(NSString *)imageName andSelectImage:(NSString *)selectedImage{ childVC.tabBarItem.image = [UIImage imageNamed:imageName]; childVC.tabBarItem.selectedImage = [UIImage imageNamed:selectedImage]; childVC.title = title;  BaseNavigationController *baseNav = [[BaseNavigationController alloc] initWithRootViewController:childVC];  [self addChildViewController:baseNav];}

這樣實現的效果如下圖所示

ios,tabbar,凸起可旋轉按鈕,旋轉按鈕

[圖一.png]

* 添加凸起按鈕

我們可以在UITabBar上添加我們的凸起按鈕,讓他的位置在沒有設置的中間按鈕偏上,按鈕的點擊和中間按鈕點擊綁定,這里直接在MCTabBarController.m中添加會有問題

1、因為凸起按鈕的frame超出了UITabBar的frame,這樣超出的區域點擊按鈕會沒有響應(圖二紅框區域),原因和解決辦法詳情參考我的這篇[iOS UIButton 點擊無響應的解決辦法],由于要在UITabBar上添加凸起按鈕,并且處理點擊無效的問題,所以這里創建了MCTabBar繼承UITabBar

ios,tabbar,凸起可旋轉按鈕,旋轉按鈕

[圖二.png]

2、由于UITabBar是readonly的,所以我們不能直接對他進行賦值,這里利用KVC訪問私有變量將MCTabBar賦值給"tabBar"

**具體實現**

MCTabBar

```

#import@interface MCTabBar : UITabBar@property (nonatomic, strong) UIButton *centerBtn; //中間按鈕@end``````@implementation MCTabBar- (instancetype)init{ if (self = [super init]){ [self initView]; } return self;}- (void)initView{ _centerBtn = [UIButton buttonWithType:UIButtonTypeCustom]; // 設定button大小為適應圖片 UIImage *normalImage = [UIImage imageNamed:@"tabbar_add"]; _centerBtn.frame = CGRectMake(0, 0, normalImage.size.width, normalImage.size.height); [_centerBtn setImage:normalImage forState:UIControlStateNormal]; //去除選擇時高亮 _centerBtn.adjustsImageWhenHighlighted = NO; //根據圖片調整button的位置(圖片中心在tabbar的中間最上部,這個時候由于按鈕是有一部分超出tabbar的,所以點擊無效,要進行處理) _centerBtn.frame = CGRectMake(([UIScreen mainScreen].bounds.size.width - normalImage.size.width)/2.0, - normalImage.size.height/2.0, normalImage.size.width, normalImage.size.height); [self addSubview:_centerBtn];}//處理超出區域點擊無效的問題- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event{ UIView *view = [super hitTest:point withEvent:event]; if (view == nil){ //轉換坐標 CGPoint tempPoint = [self.centerBtn convertPoint:point fromView:self]; //判斷點擊的點是否在按鈕區域內 if (CGRectContainsPoint(self.centerBtn.bounds, tempPoint)){  //返回按鈕  return _centerBtn; } } return view;}```

利用KVC賦值

```

//MCTabBarController.m- (void)viewDidLoad { [super viewDidLoad];  _mcTabbar = [[MCTabBar alloc] init]; [_mcTabbar.centerBtn addTarget:self action:@selector(buttonAction:) forControlEvents:UIControlEventTouchUpInside]; //選中時的顏色 _mcTabbar.tintColor = [UIColor colorWithRed:27.0/255.0 green:118.0/255.0 blue:208/255.0 alpha:1]; //透明設置為NO,顯示白色,view的高度到tabbar頂部截止,YES的話到底部 _mcTabbar.translucent = NO; //利用KVC 將自己的tabbar賦給系統tabBar [self setValue:_mcTabbar forKeyPath:@"tabBar"];  self.delegate = self; [self addChildViewControllers];}```

* 點擊旋轉

在中間按鈕的點擊事件執行時旋轉第二個index,然后執行旋轉動畫,

在tabbar的代理事件中監聽旋中中間按鈕的事件,然后執行旋轉動畫,其他按鈕則移除動畫,代碼如下

```

- (void)buttonAction:(UIButton *)button{ self.selectedIndex = 2;//關聯中間按鈕 [self rotationAnimation];}//tabbar選擇時的代理- (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *)viewController{ if (tabBarController.selectedIndex == 2){//選中中間的按鈕 [self rotationAnimation]; }else { [_mcTabbar.centerBtn.layer removeAllAnimations]; }}//旋轉動畫- (void)rotationAnimation{ CABasicAnimation *rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"]; rotationAnimation.toValue = [NSNumber numberWithFloat:M_PI*2.0]; rotationAnimation.duration = 3.0; rotationAnimation.repeatCount = HUGE; [_mcTabbar.centerBtn.layer addAnimation:rotationAnimation forKey:@"key"];}

```

* 其他

這里寫了BaseNavigationController繼承自UINavigationController,處理了push后隱藏底部UITabBar的情況,并解決了iPhonX上push時UITabBar上移的問題。

最后,附上Demo地址,如果對你有所幫助,不要吝嗇你的Star?哦![MCTabBarDemo]

(https://github.com/Ccalary/MCTabBarDemo)

總結

以上所述是小編給大家介紹的iOS Tabbar中間添加凸起可旋轉按鈕功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性一区二区三区| 国产精品欧美亚洲777777| 55夜色66夜色国产精品视频| 日本成人在线视频网址| 国产精品日日做人人爱| 欧美极品少妇xxxxⅹ喷水| 亚洲欧美国产日韩天堂区| 亚洲区在线播放| 久久久久久亚洲| 亚洲第一av在线| 精品精品国产国产自在线| 夜夜嗨av一区二区三区免费区| 国产成人av在线| 国产亚洲精品美女久久久久| 国产国产精品人在线视| 国产成人精品免费视频| 欧美日韩综合视频| 91性高湖久久久久久久久_久久99| 国产精品免费福利| 日韩成人黄色av| 成人网中文字幕| 九九精品在线视频| 欧美高清视频在线观看| 2021国产精品视频| 国产精品久久久久免费a∨大胸| 国产不卡一区二区在线播放| 97视频在线观看成人| 日本久久久久久久久久久| 国内精品伊人久久| 亚洲高清一二三区| 亚洲国产又黄又爽女人高潮的| 欧美日韩爱爱视频| 欧美电影在线观看完整版| 国内偷自视频区视频综合| 色综合久久久久久中文网| 欧美大尺度在线观看| 91精品国产91| 欧美成人在线网站| 亚洲男人第一网站| 九九热最新视频//这里只有精品| 亚洲欧美国产精品久久久久久久| 午夜精品久久久久久99热软件| 欧美超级乱淫片喷水| 亚洲欧美中文日韩在线v日本| 一区二区三区四区精品| 久久亚洲精品一区| 久久久亚洲国产| 久久久国产精品亚洲一区| 国产网站欧美日韩免费精品在线观看| 欧美激情精品久久久久久蜜臀| 欧美一级电影免费在线观看| 国产精品国产三级国产aⅴ9色| 午夜伦理精品一区| 亚洲精品永久免费精品| 亚洲欧美日韩中文在线| 亚洲精品网址在线观看| 日韩av观看网址| 国产精品久久久久久久久久99| 欧美日韩一区免费| 国产网站欧美日韩免费精品在线观看| 91久久夜色精品国产网站| 色诱女教师一区二区三区| 色在人av网站天堂精品| 精品国产一区二区三区久久狼黑人| 91国内在线视频| 精品久久久久久中文字幕| 在线一区二区日韩| 精品一区二区三区三区| 久久久爽爽爽美女图片| 最近更新的2019中文字幕| 亚洲欧洲在线播放| 亚洲国产精品女人久久久| 中文字幕v亚洲ⅴv天堂| 91在线免费网站| 亚洲免费小视频| 日韩欧美精品在线观看| 成人免费直播live| 国产精品视频免费观看www| 欧洲成人免费视频| 久久精品一偷一偷国产| 日韩禁在线播放| 亚洲精品视频在线播放| 国产精品久久久久高潮| 国产精品久久久久91| 国产亚洲欧美日韩美女| 国产精品欧美日韩| 日韩美女在线观看一区| 国产精品69久久久久| 亚洲乱亚洲乱妇无码| 欧美性猛交视频| 国产亚洲精品成人av久久ww| 国语自产精品视频在线看| 欧美大肥婆大肥bbbbb| 国产激情久久久久| 日韩视频免费在线观看| 国产成人91久久精品| 国产欧美日韩专区发布| 91精品啪在线观看麻豆免费| 国产精品亚洲欧美导航| 国产日韩一区在线| 日韩精品小视频| 亚洲男子天堂网| 国产亚洲精品va在线观看| 国产成人精品在线| 夜色77av精品影院| 成人在线小视频| 中文字幕亚洲一区二区三区| 亚洲女在线观看| 欧美午夜视频一区二区| 欧美日本高清视频| 久久综合色88| 欧美大尺度电影在线观看| 欧美成人一区二区三区电影| 成人精品一区二区三区电影黑人| 亚洲18私人小影院| 国产精品丝袜久久久久久高清| 日韩av免费观影| 国产色综合天天综合网| 国产精品免费久久久久久| 欧美电影免费观看大全| 欧美大片在线看| 久久久免费高清电视剧观看| 亚洲欧美中文字幕在线一区| 久久精品电影网站| 欧美高清在线观看| 一区二区三区黄色| 欧美一级视频一区二区| 亚洲精品视频播放| 欧美激情亚洲视频| 亚洲二区中文字幕| 欧美高清在线播放| 日韩精品亚洲元码| 亚洲黄色www网站| 97色在线观看免费视频| 国产精品欧美日韩久久| 日韩在线资源网| 国产精品日韩久久久久| 国产成人在线一区二区| 亚洲色图狂野欧美| 久久久综合av| 好吊成人免视频| 亚洲人成伊人成综合网久久久| 久久国产精品久久久久| 成人疯狂猛交xxx| 国产精品白丝av嫩草影院| 亚洲人成亚洲人成在线观看| 日本精品在线视频| 日韩欧美成人免费视频| 国产一区二区视频在线观看| 国产主播喷水一区二区| 97在线观看视频| 亚洲天堂av在线播放| 日韩精品极品在线观看| 日韩在线播放视频| 国内精品久久久久久影视8| 77777少妇光屁股久久一区| 在线观看欧美成人| 日韩av电影手机在线观看| 秋霞av国产精品一区| 久久精品国产精品| 中文字幕欧美国内| 少妇av一区二区三区| 亚洲欧美中文字幕在线一区| 色哟哟网站入口亚洲精品|