前面的两篇博客都是学习有关屏幕适配也就是相对布局的东西,这篇博客中将会学习视图间的切换。视图间的切换我们可以用代码完成或者用storyboard来建立各个视图控制器间的关系。在需要用到代码进行切换时会用代码进行视图间的跳转。下面的东西我们会主要介绍到NavigationController来进行视图间的切换。下面也是和之前一样把代码和storyboard结合起来学习。
下面介绍一下我们要实现的功能和效果: App打开的第一个界面是登陆页面,登陆页面由用户名和密码以及一个登陆按钮构成。当登陆成功时会push到第二个页面,第二个页面有三个按钮,A,B和C, 点击不同的按钮然后会跳转到相应的View。
1.首先我们先用我们的storyboard来拖拽出我们要用的控件,再添加一个NavigationController,下面图一是给我们的主视图添加NavigatinController, 图二是最终效果
2.因为要由登陆状态来判断下面的View是否出现,所以主视图和带有A,B,C三个按钮的视图之间的切换不能用storyboard实现,我们要用代码关联实现。下面是登陆成功后要跳转的模块截图:
3.以上拖拽工作到此结束,下面要实现我们的业务逻辑和关联视图之间的关系,为了关联视图时能找到带有三个按钮的视图,我们需要设置一下该视图的StoryboardID,入下图
4.下面来编写我们的代码,上面我们用到了TextField,我们需要处理键盘的回收事件,所以我们的ViewController要遵守UITextFiledDelegate协议,实现有关键盘的方法
(1)遵守UITextFieldDelegate协议
1 2 3 4 | #import <UIKit/UIKit.h> @interface ViewController : UIViewController<UITextFieldDelegate> @end |
(2)在ViewController.m中中进行回调注册和实现协议中相应的方法,代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | -( BOOL ) textFieldShouldReturn:(UITextField *)textField { [self.userName resignFirstResponder]; [self.password resignFirstResponder]; return YES; } - ( void )viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. self.userName.delegate = self; self.password.delegate = self; } |
5.处理完键盘的事儿,就该处理我们当登陆按钮点击时回调的事件了,首先在回调方法中获取TextFiled的值,由值的情况来实现是否进行页面间的切换。 在页面切换时我们得关联两个页面中的关系。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | - (IBAction)tapButton:(id)sender { NSString *username = self.userName.text; NSString *password = self.password.text; if ([username isEqualToString:@ "admin" ] && [password isEqualToString:@ "admin" ]) { //获取storyboard: 通过bundle根据storyboard的名字来获取我们的storyboard, UIStoryboard *story = [UIStoryboard storyboardWithName:@ "Main" bundle:[NSBundle mainBundle]]; //由storyboard根据myView的storyBoardID来获取我们要切换的视图 UIViewController *myView = [story instantiateViewControllerWithIdentifier:@ "myView" ]; //由navigationController推向我们要推向的view [self.navigationController pushViewController:myView animated:YES]; } } |
代码说明:关联两个View需要三部
1.获取storyboard: 通过bundle的名获取bundle, 在通过storyborad的名字来获取我们的storyboard;
2.在由storyboard获取storyboardID是myView的View;
3.执行由当前View推向我们获取到的myView;
至此我们的主要代码就编写完成,接下来看一下运行效果吧:
先简单的说这些吧,以后学到了新的内容在更新博客内容,欢迎批评指正。