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

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

服务器之家 - 编程语言 - IOS - iOS开发中UITabBarController的使用示例

iOS开发中UITabBarController的使用示例

2020-12-24 15:22TommyYaphetS IOS

这篇文章主要介绍了iOS开发中UITabBarController的使用示例,代码基于Objective-C进行演示,需要的朋友可以参考下

首先我们看一下它的view层级图:
iOS开发中UITabBarController的使用示例

复制代码 代码如下:

- (bool)application:(uiapplication *)application didfinishlaunchingwithoptions:(nsdictionary *)launchoptions 

    self.window = [[uiwindow alloc] initwithframe:[[uiscreen mainscreen] bounds]]; 
    // override point for customization after application launch. 
    self.window.backgroundcolor = [uicolor whitecolor]; 
  
#pragma mark - 设置tabbaritem 
#pragma mark  第一个视图viewcontroller 
     
    hmt_aviewcontroller * tabbarviewa = [[hmt_aviewcontroller alloc] init]; 
    // 设置a视图下----标签栏标题文字(可参照微信或者qq体会) 
    tabbarviewa.tabbaritem.title = @"微信"; 
    // 设置a视图下----标签栏图片(因为自己没有图片,在这里随便设置了个名字) 
    //tabbarviewa.tabbaritem.image = [uiimage imagenamed:@"1.png"]; 
    // 设置a视图下----标签栏信息提示(住:badgevalue是nsstring类型 如下设置了3,就像qq消息有3条未接受一样,给人一种提醒) 
    tabbarviewa.tabbaritem.badgevalue = @"3"; 
    // ios7弃用了----标签栏选中的时候显示一张图片,没选中的时候显示另一张图片 
    //[tabbarviewa.tabbaritem setfinishedselectedimage:actionmenu.selectedicon withfinishedunselectedimage:actionmenu.icon]; 
    // ios7的方法(自己没有图片,所以代码里面的图片都是一个随便取的名字,没有实用意义) 
    //tabbarviewa.tabbaritem.selectedimage = actionmenu.selectedicon; 
     
#pragma mark  第二个视图viewcontroller 
    // 第二个视图viewcontroller 
    hmt_bviewcontroller * tabbarviewb = [[hmt_bviewcontroller alloc] init]; 
    // 设置b视图下----标签栏 
    // 用系统提供的标识(可以算等价于图标和文字)进行设置(参数:uitabbarsystemitem是个枚举值,想要什么形式,就去系统提供的api中找) 
    tabbarviewb.tabbaritem = [[uitabbaritem alloc]initwithtabbarsystemitem:uitabbarsystemitemsearch tag:1]; 
    // 设置b视图下----标签栏信息提示 
    tabbarviewb.tabbaritem.badgevalue = @"go"; 
     
#pragma mark  第三个视图viewcontroller 
    hmt_cviewcontroller * tabbarviewc = [[hmt_cviewcontroller alloc] init]; 
    tabbarviewc.tabbaritem = [[uitabbaritem alloc]initwithtabbarsystemitem:uitabbarsystemitemdownloads tag:2]; 
    // 设置b视图下----标签栏信息提示 
    tabbarviewc.tabbaritem.badgevalue = @"new"; 
     
#pragma mark  第四个视图viewcontroller 
    hmt_dviewcontroller * tabbarviewd = [[hmt_dviewcontroller alloc] init]; 
    tabbarviewd.tabbaritem = [[uitabbaritem alloc]initwithtabbarsystemitem:uitabbarsystemitemfavorites tag:3]; 
    // 设置b视图下----标签栏信息提示 
    tabbarviewd.tabbaritem.badgevalue = @"99"; 
     
#pragma mark  第五个视图viewcontroller 
    hmt_eviewcontroller * tabbarviewe = [[hmt_eviewcontroller alloc] init]; 
    tabbarviewe.tabbaritem = [[uitabbaritem alloc]initwithtabbarsystemitem:uitabbarsystemitemhistory tag:4]; 
    // 设置b视图下----标签栏信息提示 
    tabbarviewe.tabbaritem.badgevalue = @"sky"; 
     
#pragma mark  第六个视图viewcontroller(系统默认能显示的最大视图个数是5个) 
    /* 如果你的viewcontrollers属性添加了多于五个的items,那tab bar controller将会自动插入一个特殊的view controller,
    称为 more view controller,该 controller 将会负责管理多于的items,这个more view controller提供一个自定义的界面,
    用table的方式呈现多余的view controller,并且view controller的数量是不限制的*/ 
    hmt_fviewcontroller * tabbarviewf = [[hmt_fviewcontroller alloc] init]; 
    tabbarviewf.tabbaritem = [[uitabbaritem alloc]initwithtabbarsystemitem:uitabbarsystemitemcontacts tag:5]; 
    // 设置f视图下----标签栏信息提示 
    tabbarviewf.tabbaritem.badgevalue = @"ag"; 
     
     
     
#pragma mark - 设置tabbarcontroller 
     
    // 创建tabbarcontroller 
    uitabbarcontroller * tabbarcontroller = [[uitabbarcontroller alloc]init]; 
    // tabbarcontroller默认是放在最底部的,如果你想调整位置,可以进行下面2部操作(44是iphone中tabbarcontroller和uinavigationcontroller标准高度) 
    //cgrect frame = cgrectmake(0, 20, 320, 44); 
    //tabbarcontroller.tabbar.frame = frame; 
    // 每一个tab都必须有一个content view controller------->viewcontrollers属性,用来存入一个应用的tabbarcontroller有多少个界面切换 
    tabbarcontroller.viewcontrollers = [nsarray arraywithobjects:tabbarviewa,tabbarviewb,tabbarviewc,tabbarviewd,tabbarviewe,tabbarviewf, nil nil]; 
    // 设置着色 
    tabbarcontroller.tabbar.tintcolor = [uicolor greencolor]; 
    // 设置选中图片时候 
    tabbarcontroller.tabbar.selectedimagetintcolor = [uicolor browncolor]; 
    // 设置背景图片(自己没有图片,不进行设置) 
    //tabbarcontroller.tabbar.backgroundimage = [uiimage imagenamed:@"@@@@@"]; 
    // 设置程序启动时默认的viewcontroller视图(设置为3,一共5个viewcontroller,进来时候显示的视图就是第4个-tabbarviewd,下标从0开始) 
    tabbarcontroller.selectedindex = 3; 
     
     
    self.window.rootviewcontroller = tabbarcontroller; 
     
    [self.window makekeyandvisible]; 
    return yes; 

 

最后效果如下图:

iOS开发中UITabBarController的使用示例

uitabbarcontroller的代理方法以及模态显示
首先要实现协议<uitabbarcontrollerdelegate>

复制代码 代码如下:

    // 设置代理
    tabbarcontroller.delegate =self; 
    //uinavigationcontroller *nav = tabbarcontroller.morenavigationcontroller;
    //[nav setnavigationbarhidden:yes animated:yes];

 

// 控制哪些viewcontroller的标签栏能被点击
- (bool)tabbarcontroller:(uitabbarcontroller *)tabbarcontrollershouldselectviewcontroller:(uiviewcontroller *)viewcontroller{
    // 代表hmt_cviewcontroller这个view无法显示,无法点击到它代表的标签栏
    if ([viewcontrolleriskindofclass:[hmt_cviewcontrollerclass]]) {
        returnno;
    }
    returnyes;
}

// 选中哪个标签栏,一个监控作用吧
- (void)tabbarcontroller:(uitabbarcontroller *)tabbarcontrollerdidselectviewcontroller:(uiviewcontroller *)viewcontroller{

}

// more view controller将要开始编辑
- (void)tabbarcontroller:(uitabbarcontroller *)tabbarcontrollerwillbegincustomizingviewcontrollers:(nsarray *)viewcontrollers{

}
// more view controller将要结束编辑
- (void)tabbarcontroller:(uitabbarcontroller *)tabbarcontrollerwillendcustomizingviewcontrollers:(nsarray *)viewcontrollers changed:(bool)changed{

}
// more view controller编辑
- (void)tabbarcontroller:(uitabbarcontroller *)tabbarcontrollerdidendcustomizingviewcontrollers:(nsarray *)viewcontrollers changed:(bool)changed{

}

#import "hmt-aviewcontroller.h"
#import "hmtmodalshowviewcontroller.h"

@interfacehmt_aviewcontroller ()
@end

@implementation hmt_aviewcontroller

- (void)viewdidload
{
    [superviewdidload];
    self.view.backgroundcolor = [uicolorredcolor];
   
    // 创建一个按钮
    uibutton * button = [uibutton buttonwithtype:uibuttontypedetaildisclosure];
    button.frame =cgrectmake(100,100,100, 100);
    [button addtarget:self action:@selector(modalshow)forcontrolevents:uicontroleventtouchupinside];
    [self.view addsubview:button];
// do any additional setup after loading the view.
}

- (void)modalshow{
   
    hmtmodalshowviewcontroller * modalshowvc = [[hmtmodalshowviewcontroller alloc]init];

    //模态视图控制器呈现出来时候的视觉效果
    modalshowvc.modaltransitionstyle =uimodaltransitionstylecrossdissolve;
    /*
     uimodaltransitionstylecoververtical = 0,   //默认,由下往上
     uimodaltransitionstylefliphorizontal,      //水平转动效果
     uimodaltransitionstylecrossdissolve,       //渐变效果
     uimodaltransitionstylepartialcurl,         //书页往上翻动效果
     */
    //模态视图控制器呈现方式,默认全屏
    modalshowvc.modalpresentationstyle =uimodalpresentationfullscreen;
    /*   
     uimodalpresentationfullscreen = 0,
     uimodalpresentationpagesheet,
     uimodalpresentationformsheet,
     uimodalpresentationcurrentcontext,
     uimodalpresentationcustom,
     uimodalpresentationnone = -1,   
     */
   
    uinavigationcontroller * modalshownc = [[uinavigationcontroller alloc] initwithrootviewcontroller:modalshowvc];
   
    //推出模态视图控制器
    [self presentviewcontroller:modalshownc animated:yes completion:^{
        nslog(@"hello world");      
    }];
}


#import "hmtmodalshowviewcontroller.h"

@interfacehmtmodalshowviewcontroller ()

@end

@implementation hmtmodalshowviewcontroller

- (void)viewdidload
{
    [superviewdidload];
// do any additional setup after loading the view.
   
    self.view.backgroundcolor = [uicolor yellowcolor];
   
    // 利用uinavigationcontroller来实现退出控制器
    uibarbuttonitem * barbutton = [[uibarbuttonitem alloc] initwithbarbuttonsystemitem:uibarbuttonsystemitemadd target:self action:@selector(modaldismiss)];
   
    self.navigationitem.leftbarbuttonitem = barbutton;
    self.navigationitem.title ";
   
    //创建一个按钮来实现退出控制器
/*    uibutton * button = [uibutton buttonwithtype:uibuttontypedetaildisclosure];
    button.frame = cgrectmake(100, 100, 100, 100);
    [button addtarget:self action:@selector(modaldismiss) forcontrolevents:uicontroleventtouchupinside];
   
    [self.view addsubview:button];*/
   
}

- (void)modaldismiss{
   //退出模态视图控制器
    [self dismissviewcontrolleranimated:yes completion:^{
        nslog(@"退出goodbye");
    }];
}
@end

 

延伸 · 阅读

精彩推荐
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17