服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS的UI开发中UITabBarControlle的基本使用教程

iOS的UI开发中UITabBarControlle的基本使用教程

2020-12-30 13:35文顶顶 IOS

这篇文章主要介绍了iOS的UI开发中UITabBarControlle的基本使用教程,代码基于传统的Objective-C,需要的朋友可以参考下

uitabbarcontroller的基本使用

一、简单介绍

uitabbarcontroller和uinavigationcontroller类似,uitabbarcontroller也可以轻松地管理多个控制器,轻松完成控制器之间的切换,典型的例子就是qq、微信等应⽤。

iOS的UI开发中UITabBarControlle的基本使用教程

二、uitabbarcontroller的使用

1.使用步骤:

(1)初始化uitabbarcontroller

(2)设置uiwindow的rootviewcontroller为uitabbarcontroller

(3)创建相应的子控制器(viewcontroller)

(4)把子控制器添加到uitabbarcontroller

2.代码示例

新建一个空的文件,在application的代理中编码

yyappdelegate.m文件

复制代码 代码如下:


//
//  yyappdelegate.m
//  01-uitabbar控制器基本使用
//
//  created by 孔医己 on 14-6-7.
//  copyright (c) 2014年 itcast. all rights reserved.
//

 

#import "yyappdelegate.h"

@implementation yyappdelegate

- (bool)application:(uiapplication *)application didfinishlaunchingwithoptions:(nsdictionary *)launchoptions
{
    //1.创建window
    self.window = [[uiwindow alloc] initwithframe:[[uiscreen mainscreen] bounds]];
    self.window.backgroundcolor = [uicolor whitecolor];
   
    //a.初始化一个tabbar控制器
    uitabbarcontroller *tb=[[uitabbarcontroller alloc]init];
    //设置控制器为window的根控制器
    self.window.rootviewcontroller=tb;
   
    //b.创建子控制器
    uiviewcontroller *c1=[[uiviewcontroller alloc]init];
    c1.view.backgroundcolor=[uicolor graycolor];
    c1.view.backgroundcolor=[uicolor greencolor];
    c1.tabbaritem.title=@"消息";
    c1.tabbaritem.image=[uiimage imagenamed:@"tab_recent_nor"];
    c1.tabbaritem.badgevalue=@"123";
   
    uiviewcontroller *c2=[[uiviewcontroller alloc]init];
    c2.view.backgroundcolor=[uicolor browncolor];
    c2.tabbaritem.title=@"联系人";
    c2.tabbaritem.image=[uiimage imagenamed:@"tab_buddy_nor"];
   
    uiviewcontroller *c3=[[uiviewcontroller alloc]init];
    c3.tabbaritem.title=@"动态";
    c3.tabbaritem.image=[uiimage imagenamed:@"tab_qworld_nor"];
    
    uiviewcontroller *c4=[[uiviewcontroller alloc]init];
    c4.tabbaritem.title=@"设置";
    c4.tabbaritem.image=[uiimage imagenamed:@"tab_me_nor"];
  
   
    //c.添加子控制器到itabbarcontroller中
    //c.1第一种方式
//    [tb addchildviewcontroller:c1];
//    [tb addchildviewcontroller:c2];
   
    //c.2第二种方式
    tb.viewcontrollers=@[c1,c2,c3,c4];
   
   
    //2.设置window为主窗口并显示出来
    [self.window makekeyandvisible];
    return yes;
}

@end


实现效果:

 

iOS的UI开发中UITabBarControlle的基本使用教程


三、重要说明

1.uitabbar

下方的工具条称为uitabbar ,如果uitabbarcontroller有n个子控制器,那么uitabbar内部就会有n 个uitabbarbutton作为子控件与之对应。

注意:uitabbarbutton在uitabbar中得位置是均分的,uitabbar的高度为49。

在上面的程序中,uitabbarcontroller有4个子控制器,所以uitabbar中有4个uitabbarbutton,uitabbar的结构⼤大致如下图所示:

iOS的UI开发中UITabBarControlle的基本使用教程

2.uitabbarbutton

uitabbarbutton⾥面显⽰什么内容,由对应子控制器的tabbaritem属性来决定

 c1.tabbaritem.title=@"消息";
 c1.tabbaritem.image=[uiimage imagenamed:@"tab_recent_nor"];

iOS的UI开发中UITabBarControlle的基本使用教程

3.有两种方式可以往uitabbarcontroller中添加子控制器

(1)[tb addchildviewcontroller:c1];

(2)tb.viewcontrollers=@[c1,c2,c3,c4];

注意:展示的顺序和添加的顺序一致,和导航控制器中不同,展现在眼前的是第一个添加的控制器对应的view。

uitabbarcontroller生命周期(使用storyoard搭建)
一、uitabbarcontroller在storyoard中得搭建

1.新建一个项目,把storyboard中默认的控制器删除,拖uitab bar controller。
2.创建viewcontroller,添加到uitab bar controller中去(连线)。

iOS的UI开发中UITabBarControlle的基本使用教程

注意点:连线的顺序就是将来显示的顺序,显示在眼前的为第一个连线的view。
提示:控制器的界面对应的tabbarbutton和图片显示什么内容,由它的控制器确定。
3.设置子控制器的uitabbar等信息。

iOS的UI开发中UITabBarControlle的基本使用教程

4.运行效果

iOS的UI开发中UITabBarControlle的基本使用教程

二、uitabbarcontroller的生命周期演示
思路:新建三个控制器类来对控制器进行分别管理,重写内部的生命周期方法就可以了解uitabbarcontroller内部管理机制。
 
分析代码:

复制代码 代码如下:


//
//  yybaseviewcontroller.m
//  02-uitabbarcontroller
//
//  created by 孔医己 on 14-6-8.
//  copyright (c) 2014年 itcast. all rights reserved.
//

 

#import "yybaseviewcontroller.h"

@interface yybaseviewcontroller ()

@end

 

复制代码 代码如下:


@implementation yybaseviewcontroller

 

// 当控制器的view加载完毕就调用
- (void)viewdidload
{
    [super viewdidload];
    nslog(@"%@ -  控制器的view加载完毕", [self class]);
}

// 控制器即将显示的时候调用
- (void)viewwillappear:(bool)animated
{
    [super viewwillappear:yes];
    nslog(@"%@ -  控制器即将显示", [self class]);
}

// 控制器完全显示的时候调用
- (void)viewdidappear:(bool)animated
{
    [super viewdidappear:animated];
    nslog(@"%@ -  控制器完全显示", [self class]);
}

// 控制器即将消失的时候调用
- (void)viewwilldisappear:(bool)animated
{
    [super viewwilldisappear:animated];
    nslog(@"%@ -  控制器即将消失", [self class]);
}
// 控制器完全消失的时候调用
- (void)viewdiddisappear:(bool)animated
{
    [super viewdiddisappear:animated];
    nslog(@"%@ -  控制器完全消失", [self class]);
}

- (void)viewwillunload
{
    [super viewwillunload];
    nslog(@"%@ -  view即将被销毁", [self class]);
}

- (void)viewdidunload
{
    [super viewdidunload];
    nslog(@"%@ -  view完全被销毁", [self class]);
}

- (void)dealloc
{
    nslog(@"%@",  [self class]);
}

@end


(1)运行程序,打印输出为:

 

 

说明iOS的UI开发中UITabBarControlle的基本使用教程:当把三个子控制器都添加给uitabbarcontroller来管理后,当程序启动时它只会加载第一个添加的控制器的view。
(2)点击联系人按钮,切换到第二个界面。打印输出为:

iOS的UI开发中UITabBarControlle的基本使用教程

说明:先把第一个view移开,再把新的view添加上去,但是第一个view并没有被销毁。
(3)重新点击消息界面,打印如下:

iOS的UI开发中UITabBarControlle的基本使用教程

说明:先重新切换到消息界面,one控制器直接即将显示,没有进行加载证明了(2)中第一个view移除后并没有被销毁(因为它的控制器还存在,有一个强引用引用着它),且two的view移除后也没有被销毁。无论怎么切换,控制器和view都不会被销毁。
uinavigationcontroller和uitabbarcontroller一个通过栈来管理,一个通过普通的数组来进行管理。
 
补充说明:uitabbarcontroller中的uitabbar实际高度为49.
在application的下面方法中打印uitabbar的frame进行查看。

复制代码 代码如下:

- (void)applicationdidbecomeactive:(uiapplication *)application
{
    // restart any tasks that were paused (or not yet started) while the application was inactive. if the application was previously in the background, optionally refresh the user interface.
    uitabbarcontroller *tb=(uitabbarcontroller*)self.window.rootviewcontroller;
    nslog(@"%@",nsstringfromcgrect(tb.tabbar.frame));
}


打印结果为:

 

iOS的UI开发中UITabBarControlle的基本使用教程

延伸 · 阅读

精彩推荐
  • IOSiOS实现控制屏幕常亮不变暗的方法示例

    iOS实现控制屏幕常亮不变暗的方法示例

    最近在工作中遇到了要将iOS屏幕保持常亮的需求,所以下面这篇文章主要给大家介绍了关于利用iOS如何实现控制屏幕常亮不变暗的方法,文中给出了详细的...

    随风13332021-04-02
  • IOSiOS自定义UICollectionViewFlowLayout实现图片浏览效果

    iOS自定义UICollectionViewFlowLayout实现图片浏览效果

    这篇文章主要介绍了iOS自定义UICollectionViewFlowLayout实现图片浏览效果的相关资料,需要的朋友可以参考下...

    jiangamh8882021-01-11
  • IOSiOS开发之视图切换

    iOS开发之视图切换

    在iOS开发中视图的切换是很频繁的,独立的视图应用在实际开发过程中并不常见,除非你的应用足够简单。在iOS开发中常用的视图切换有三种,今天我们将...

    执着丶执念5272021-01-16
  • IOS详解iOS中多个网络请求的同步问题总结

    详解iOS中多个网络请求的同步问题总结

    这篇文章主要介绍了详解iOS中多个网络请求的同步问题总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    liang199111302021-03-15
  • IOSiOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和Masonry简单使用)

    iOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和

    这篇文章主要介绍了iOS中滑动控制屏幕亮度和系统音量(附加AVAudioPlayer基本用法和Masonry简单使用)的相关资料,需要的朋友可以参考下...

    CodingFire13652021-02-26
  • IOSiOS开发技巧之状态栏字体颜色的设置方法

    iOS开发技巧之状态栏字体颜色的设置方法

    有时候我们需要根据不同的背景修改状态栏字体的颜色,下面这篇文章主要给大家介绍了关于iOS开发技巧之状态栏字体颜色的设置方法,文中通过示例代码...

    梦想家-mxj8922021-05-10
  • IOSiOS中MD5加密算法的介绍和使用

    iOS中MD5加密算法的介绍和使用

    MD5加密是最常用的加密方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码。对输入信息生成唯一的128位散列值(32个字符)。这篇文...

    LYSNote5432021-02-04
  • IOSiOS中UILabel实现长按复制功能实例代码

    iOS中UILabel实现长按复制功能实例代码

    在iOS开发过程中,有时候会用到UILabel展示的内容,那么就设计到点击UILabel复制它上面展示的内容的功能,也就是Label长按复制功能,下面这篇文章主要给大...

    devilx12792021-04-02