iOS 实现简单的界面切换
以下是在iOS中最简单的界面切换示例。使用了多个Controller,并演示Controller之间在切换界面时的代码处理。
实现的应用界面:
![]()
![]()
首先,创建一个window-based application,即:
![]()
使用window-base application的目的是,尽量从最基本的情况下说明程序的编写过程。项目创建好后,即可以编译运行,执行结果是白屏页面:
![]()
编写第一个视图和控制器,我管它叫Topic,即主题,因此控制器命名为:TopicController,视图TopicView。
创建TopicController:
![]()
这样将创建3个文件:
![]()
视图xib文件也一同创建了。而且:
![]()
会自动生成File’s Owner的Class。
在MainWindow.xib中,将刚刚创建的控制器(TopicController)加进来。
先要拖拽一个View Controller进来:
![]()
然后,给View Controller改名:
![]()
下面,要把这个Controller设置给WindowDemoAppDelegate。在它的头文件中:
#import <UIKit/UIKit.h>
#import "TopicController.h"@interface WindowDemoAppDelegate : NSObject
<UIApplicationDelegate> {
UIWindow
*window;
IBOutlet
TopicController *topicController;
}@property (nonatomic, retain) IBOutlet UIWindow *window;
@end
在实现文件中:
#import "WindowDemoAppDelegate.h"
@implementation WindowDemoAppDelegate
@synthesize window;
#pragma mark –
#pragma mark Application lifecycle- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override
point for customization after application launch.
[self.window
addSubview:topicController.view];[self.window
makeKeyAndVisible];
return
YES;
}
然后,为了看的清楚,把TopicController.xib文件中的视图颜色改为绿色:
![]()
运行应用,会看到如下效果:
![]()
为该界面添加一个按钮:
![]()
为该按钮创建处理方法。在TopicController的头文件中:
#import <UIKit/UIKit.h>
@interface TopicController : UIViewController {
}
-(IBAction) getDetail:(id)sender;
@end
在实现文件中:
#import "TopicController.h"
@implementation TopicController
-(IBAction) getDetail:(id)sender{
NSLog(@"get
detail …");
}
在IB中,将按钮和控制器的Action连接:
![]()
再次运行应用,可看到日志中的打印内容:
![]()
按照上面创建Controller的方法,再创建一个DetailController。先把DetailController.xib的视图设置颜色,为了以后调试观察识别。
![]()
然后,我需要点击TopicController视图中按钮切换到DetailController视图。这需要在下面代码中想办法:
#import "TopicController.h"
@implementation TopicController
-(IBAction) getDetail:(id)sender{
NSLog(@"get
detail …");
}
基本思路是找到window实例,可通过window的rootViewController属性设置新的控制器实例(比如DetailController),取代TopicController。代码可这样写:
#import "TopicController.h"
#import "DetailController.h"@implementation TopicController
-(IBAction) getDetail:(id)sender{
NSLog(@"get
detail …, window.views: %@",self.view.window.subviews);
DetailController *detailController=[[DetailController alloc]
initWithNibName:@"DetailController" bundle:nil];
self.view.window.rootViewController=detailController;
NSLog(@"window.views:
%@",detailController.view.window.subviews);
}
加上这部分代码后,点击按钮就可生效,产生这样的效果:
![]()
![]()
上面的代码做一下解释:
- 首先创建了一个新的DetailController实例
- 然后,当前的controller的view属性,可以获得window实例,通过window实例的rootViewController属性的设置,将当前的控制器替换为新的控制器
- window对象是一个非常重要的类,你可以把它看作ios开发的画框,视图是放在画框里的,window有个subvews列表,里面可以存放多个View
- 当设置window.rootViewController属性的时候,window会自动将该属性的UIViewController的view添加到window的subview中,这也是为什么日志中打印的window.subviews列表中有两个实例的原因
这个代码很不完备,比如存在内存泄漏,需要这样:
DetailController *detailController=[[[DetailController alloc]
initWithNibName:@"DetailController" bundle:nil]
autorelease];
因为,这个detailController这句话后,计数器为1了,再赋值给window.rootViewController属性,就是2了。因此这里要做自动释放。
这个代码还有个问题,就是看上去很别扭,在一个控制器代码里去创建另一个控制器。这一方面很容易出问题,另一方面,代码的结构不清晰。下面用委托模式给代码解耦,也为下一步做返回按钮做准备。
委托模式,一般用protocol来实现。先写个protocol:
#import <UIKit/UIKit.h>
@protocol SwitchViewDelegate
-(void)getDetail;
@end
然后,需要让UIApplicationDelegate实现类实现该protocol:
#import <UIKit/UIKit.h>
#import "TopicController.h"
#import "SwitchViewDelegate.h"@interface WindowDemoAppDelegate : NSObject
<UIApplicationDelegate,SwitchViewDelegate>
{
UIWindow
*window;
IBOutlet
TopicController *topicController;
}@property (nonatomic, retain) IBOutlet UIWindow *window;
@end
在实现类中:
#import "WindowDemoAppDelegate.h"
#import "DetailController.h"@implementation WindowDemoAppDelegate
@synthesize window;
#pragma mark –
#pragma mark Application lifecycle- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override
point for customization after application launch.
[self.window
addSubview:topicController.view];
topicController.delegate=self;[self.window
makeKeyAndVisible];
return
YES;
}- (void)applicationWillResignActive:(UIApplication *)application
{
}- (void)applicationDidEnterBackground:(UIApplication
*)application {
}- (void)applicationWillEnterForeground:(UIApplication
*)application {
}- (void)applicationDidBecomeActive:(UIApplication *)application
{
}- (void)applicationWillTerminate:(UIApplication *)application
{
}#pragma mark –
#pragma mark Memory management- (void)applicationDidReceiveMemoryWarning:(UIApplication
*)application {
}- (void)dealloc {
[window
release];
[super
dealloc];
}-(void)getDetail{
DetailController *detailController=[[[DetailController alloc]
initWithNibName:@"DetailController" bundle:nil] autorelease];
self.window.rootViewController=detailController;
}@end
另外,就是要为控制器里增加delegate属性,头文件:
#import <UIKit/UIKit.h>
#import "SwitchViewDelegate.h"@interface TopicController : UIViewController {
id<SwitchViewDelegate>
delegate;
}@property(nonatomic,retain)
id<SwitchViewDelegate>
delegate;-(IBAction) getDetail:(id)sender;
@end
实现文件:
#import "TopicController.h"
#import "DetailController.h"@implementation TopicController
@synthesize delegate;
-(IBAction) getDetail:(id)sender{
NSLog(@"get
detail …, window.views: %@",self.view.window.subviews);
[delegate
getDetail];
}
实现的效果和上面的是类似的,但是引入委托模式后,代码的架构就比较清楚了,利于以后的维护。
iOS 实现简单的界面切换的更多相关文章
- 编写最简单的 iPhone 界面切换应用
编写最简单的 iPhone 界面切换应用 以下是在iOS中最简单的界面切换示例.使用了多个Controller,并演示Controller之间在切换界面时的代码处理. 实现的应用界面: 首先,创建 ...
- [android] 界面切换的核心方法
根据效果图拆分界面 主体部分 View ==> ViewGroup ==> RelativeLayout,主体部分使用RelativeLayout作为占位 View和ViewGroup的区 ...
- Unity iOS混合开发界面切换思路
Unity iOS混合开发界面切换思路 最近有很多博友QQ 私信 或则 留言联系我,请教iOS和Unity界面之前相互切换的问题,源代码就不私下发你们了,界面跳转功能的代码我直接贴到下面好了,顺带说i ...
- iOS 简单引导界面
代码地址如下:http://www.demodashi.com/demo/11607.html 前言 现在很多APP在用户第一次用的时候,由于用户可能并不知道其中一些功能点的时候,这个时候就需要我们来 ...
- iOS开发简单介绍
概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的iOS程序.但是这里我想强调一下,前面的 ...
- Linux启动界面切换:图形界面-字符界面(转)
Linux字符界面切换到图形界面 由字符界面切换到图形界面可用两种简单方法实现: 1.在字符界面输入startx或init 5 . 2.通过编辑/etc/inittab文件实现默认进入图形界面. 把其 ...
- Html5 Egret游戏开发 成语大挑战(五)界面切换和数据处理
经过前面的制作,使用Egret的Wing很快完成了开始界面和选关卡界面,下面通常来说就是游戏界面,但此时界面切换和关卡数据还没有准备好,这次讲解界面的切换和关卡数据的解析.前面多次修改了Main.ts ...
- 参考_Android中,如何新建一个界面,并且实现从当前界面切换到到刚才新建的(另外一个)界面
参考地址: http://www.crifan.com/android_how_to_create_new_ui_and_switch_to_another_new_ui/ 想要实现,在Android ...
- WPF如何实现类似iPhone界面切换的效果(转载)
WPF如何实现类似iPhone界面切换的效果 (version .1) 转自:http://blog.csdn.net/fallincloud/article/details/6968764 在论坛上 ...
随机推荐
- [cf1495D]BFS Trees
记$d_{G}(x,y)$表示无向图$G$中从$x$到$y$的最短路,设给定的图为$G=(V,E)$,$T$为其生成树,$E_{T}$为$T$的边集 下面,考虑计算$f(x,y)$-- 首先,对于一棵 ...
- es基本概念
电商实时数据分析平台需要学些什么? [运营指标,流量指标,销售转化指标,客户价值指标,商品指标,营销指标,风险控制指标,市场竞争指标]等电商指标数据. 检索,数据更新,排序,分词,query等缓存机 ...
- 访问ajax请求后的结果
let getJPM = (function() { let result; let url ="xxx"; $.ajax({ type: "post", ur ...
- Devs--开源规则引擎介绍
Devs Devs是一款轻量级的规则引擎. 开源地址:https://github.com/CrankZ/devs 基础概念 此规则引擎的基础概念有字段.条件.规则等. 其中字段组成条件,条件组成规则 ...
- springboot 配置多数据源实例代码(分包方式)
目录 1.数据库 2.pom与yml 2.1.pom中的依赖部分 2.2.yml数据库配置部分 3.数据源配置类 DataSourceConfig 3.1.DataSourceConfig1.java ...
- 从一个简单的Delete删数据场景谈TiDB数据库开发规范的重要性
故事背景 前段时间上线了一个从Oracle迁移到TiDB的项目,某一天应用端反馈有一个诡异的现象,就是有张小表做全表delete的时候执行比较慢,而且有越来越慢的迹象.这个表每次删除的数据不超过20行 ...
- Codeforces 1461F - Mathematical Expression(分类讨论+找性质+dp)
现场 1 小时 44 分钟过掉此题,祭之 大力分类讨论. 如果 \(|s|=1\),那么显然所有位置都只能填上这个字符,因为你只能这么填. scanf("%d",&n);m ...
- Codeforces 547E - Mike and Friends(AC 自动机+树状数组)
题面传送门 好久每做过 AC 自动机的题了--做几个题回忆一下罢 AC 自动机能够解决多串匹配问题,注意是匹配,碰到前后缀的问题那多半不在 AC 自动机能解决的范围内. 在初学 AC 自动机的时候相信 ...
- python3安装,支持openssl,支持采集https
python3安装,支持openssl,支持采集https 坑好多,特别是安装的时候,各种不匹配,服务器默认配置是python2,升级3后,采集的时候用到openssl,花了两天也没搞定各种错误,也许 ...
- Oracle-一张表中增加计算某列值重复的次数列,并且把表中其他列也显示出来,或者在显示过程中做一些过滤
总结: 1.计算某列值(数值or字符串)重复的次数 select 列1,count( 列1 or *) count1 from table1 group by 列1 输出的表为:第一列是保留唯一值的 ...