iOS 用代码搭建UI界面实例
1.背景
学习IOS开发也差不多两个月了,赶鸭子上架的学习模式让我学习比较快,但是真心很累,每天有每天的工作进度,在学习的
时候需要边做一个项目真心有点累,但是看到自己的收获还是值得的。自己原来是做C#开发的,由于公司需求想开展手机业务,
想公司内部的人做,我觉得是机遇,我就选择了iOS。
学习了这么就吐槽下ios的学习环境,很多时候你问别人问题得不会回你,特别是QQ群,所以想写一些比较清楚的教程帮助那些像
我一样摸索前进的新学者更快的进入。我比较常去的一些论坛都是很牛逼的。cocoa China和code4app 这两个是我经常去逛的,还有就
是xcode带的帮助,感谢它们提供的帮助。
2.开发环境
我的开发环境是Xcode 5.1.1,IOS SDK 7.1
3.实现步骤
0>实现后的界面效果
1>新建空项目
2>添加五个文件MainViewController,FirstViewController,SecondViewController,ThirdViewController,FourlViewController,
TestViewController分别继承至 UITabBarController, UIViewController,UIViewController,UIViewController,UIViewController,
UIViewController 后面五个可以随意,是Controller就好了,添加好的结构就是如下面。
3>打开文件AppDelegate.m文件,引进MainViewController.h 头文件,并添加如下代码
- MainViewController * mainview=[[MainViewController alloc] init];
- self.window.rootViewController=mainview;
添加后的AppDelegate.m的文件如下
4>打开文件MainViewController.m,并引进FirstViewController.h ,SecondViewController.h, ThirdViewController.h ,FourlViewController.h
在viewDidLoad 函数添加如下代码
- [self creatControls];
在添加函数
- //将试图控制器添加到tabbar上面
- - (void)creatControls
- {
- FirstViewController * firstview=[[FirstViewController alloc] init];
- firstview.tabBarItem.image=[UIImage imageNamed:@"tab_0.png"];
- firstview.tabBarItem.title=@"界面一";
- UINavigationController * nvifirst=[[UINavigationController alloc] init];
- [nvifirst addChildViewController:firstview];
- SecondViewController * secondview=[[SecondViewController alloc]init];
- secondview.tabBarItem.image=[UIImage imageNamed:@"tab_1.png"];
- secondview.tabBarItem.title=@"界面二";
- UINavigationController * nvisecond=[[UINavigationController alloc] init];
- [nvisecond addChildViewController:secondview];
- ThirdViewController * third=[[ThirdViewController alloc] init];
- third.tabBarItem.image=[UIImage imageNamed:@"tab_2.png"];
- third.tabBarItem.title=@"界面三";
- UINavigationController * nvithird=[[UINavigationController alloc] init];
- [nvithird addChildViewController:third];
- FourlViewController * fourview=[[FourlViewController alloc]init];
- fourview.tabBarItem.image=[UIImage imageNamed:@"tab_3.png"];
- fourview.tabBarItem.title=@"界面四";
- UINavigationController * nvifourview=[[UINavigationController alloc] init];
- [nvifourview addChildViewController:fourview];
- NSArray * controls=[NSArray arrayWithObjects:nvifirst,nvisecond,nvithird,nvifourview, nil];
- self.viewControllers=controls;
- }
5.分别在FirstViewController.m ,SecondViewController.m, ThirdViewController.m ,FourlViewController.m的viewDidLoad函数里分别添加
- self.view.backgroundColor=[UIColor redColor];
- self.navigationItem.title=@"美女";
根据需要修改文字就好了。
6.在FirstViewController.m文件里引入头文件TestViewController.h,并在viewDidLoad函数里分别添加如下代码
- UIBarButtonItem * right=[[UIBarButtonItem alloc]initWithTitle:@"我想要" style:(UIBarButtonItemStyleBordered) target:self action:@selector(select:)];
- self.navigationItem.rightBarButtonItem=right;
再添加函数
- - (void)select:(id)sender
- {
- NSLog(@"你想要什么");
- TestViewController * testview=[[TestViewController alloc] init];
- [self.navigationController pushViewController: testview animated:YES];
- }
7.打开文件TestViewController.m 并在viewDidLoad函数里分别添加如下代码
- UILabel * msg=[[UILabel alloc]init];
- msg.text=@"哈哈好样的";
- [self.view addSubview:msg];
8>编译运行就能得到一个tabbar的界面
4.代码下载
iOS 用代码搭建UI界面实例的更多相关文章
- iOS 用代码+Xib搭建UI界面实例
1.背景 有些我们不能只用代码去构建界面,代码是万能的,你用其他方式可以实现的界面,用代码也一定能 实现,但是我们没必要这样做,有的时候用xib会是更好的选择,代码和xib的优劣地方我们得知道,为了 ...
- 使用XML文件和Java代码控制UI界面
Android推荐使用XML文件设置UI界面,然后用Java代码控制逻辑部分,这体现了MVC思想. MVC全名是Model View Controller,是模型(model)-视图(view)-控制 ...
- Android学习笔记(9):使用XML文件和Java代码控制UI界面
Android推荐使用XML文件设置UI界面.然后用Java代码控制逻辑部分,这体现了MVC思想. MVC全名是Model View Controller.是模型(model)-视图(view)-控制 ...
- iOS纯代码制作欢迎界面——UIScrollView, UIPageControl, UIImageView,UIButton, NSTimer
欢迎界面,还是比较简单的,一个UIScrollView控件,一个UIPageControl,几个UIImageView即可摆平.在这里光玩这些,就显得诚意不足了.特意拓展一下,再加几个UIButton ...
- (六十二)纯代码搭建UI
在Xcode6中,去掉了Empty Application的选项,因此可以通过先创建SingleView,再删除storyboard,并且把工程设置中的main Interface清空. 通过AppD ...
- 用代码控制UI界面
public class MainActivity extends Activity { //当第一次创建Activity时回调该方法 @Override protected void ...
- Android学习:代码控制UI界面示例
package allegro.test2; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; im ...
- Spark UI界面原理
当Spark程序在运行时,会提供一个Web页面查看Application运行状态信息.是否开启UI界面由参数spark.ui.enabled(默认为true)来确定.下面列出Spark UI一些相关配 ...
- Android控制UI界面
⒈使用XML布局文件控制UI界面[推荐] Android推荐使用XML布局文件来控制视图,这样不仅简单.明了,而且可以将应用的视图控制逻辑从Java或Kotlin代码中分离出来,放入XML文件中控制, ...
随机推荐
- SQL SERVER安装序列号
MICROSOFT SQL SERVER 2012 DEVELOPER 版 序列号:YQWTX-G8T4R-QW4XX-BVH62-GP68Y MICROSOFT SQL SERVER 2012 EN ...
- JSTL+MyEclipse8.5+Tomcat配置
使用JSTL的时候需要配置,即导入stdandard.jar和jstl.jar包,并在web.xml下对jstl进行配置.下面是使用步骤: 1. 解压jakarta-taglibs-standard- ...
- oracle中的查询语句(关于出库入库信息表,明细表,把捆包箱表,单位信息表的集中查询)
--查出所有现金中心的单位IDwith AllUnitas(select t.ORGANIZATIONID orgid,t.parentidfrom CDMS_ORGANIZATION t where ...
- C# 控制台程序如何能不显示窗口
创建好控制台程序后,选中项目,右键,属性,输出类型选为“windows 应用程序” 这样就没有dos窗口了
- sql条件中比较性能优化
第一个比第二个性能高. 查询语句意义: 如果codelist中tablecode配置为0时, t.Table_Code = 'SV_RETURN_BILL'不生效. 如果codelist中tablec ...
- [JavaScript 随笔] 垃圾回收
在 JavaScript 中,由于垃圾回收是自动进行的,所以人们在编码时可能不太会注意这方面.但事实是,一些 webapp 在使用一段时间后,会出现卡顿的现象,特别是那些单页应用,包括 WebView ...
- writel(readl(&pwm_timer->tcfg0) | 0xff, &pwm_timer->tcfg0);
解析这句代码什么意思! 神说:选定预分频器0 为什么? 神说:因为实验中选的是timer1,在预分频器0下: 若选择timer4,该如何写这句代码? 首先看tcfg0中选择预分频器1,在看tcfg1里 ...
- (知识分享)软硬件调试九法:第九条规则 如果你不修复一个bug,它将永远存在
1.查证问题确已被修复 如果遵循了“制造失败”这条规则,就知道如何验证你确实修复了问题.无论问题和修复看起来多么明显,你都无法保证修复是有效的,直到做了测试并验证. 2.查证确实你的修复措施解决了问题 ...
- pt-query-digest查询日志分析工具
1.工具介绍 pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog.General log.slowlog,也可以通过SHOWPROCESSLIST或者通过tcp ...
- avalon2学习教程12数据验证
avalon2砍掉了不少功能(如ms-include,ms-data),腾出空间加了其他更有用的功能.数据验证就是其中之一.现在avalon2内置的验证指令是参考之前的oniui验证框架与jquery ...