`

iPhone开发多视图技术总结之一:ModalView(模态视图) .

    博客分类:
  • ios
ios 
阅读更多
实现的功能:1)通过弹出一个ModalView(模态视图),实现多视图;2)主界面上点击按钮弹出Info界面,在该界面上点击返回,返回到主界面。

关键词:多视图 MultiView模态视图 ModalView



1、创建一个Empty Application工程,命名为:MultiView-ModalView,如下图
[img]

[/img]

[img]

[/img]







2、选中工程中的Group MultiView-ModalView,然后按住CMD(Windows键)+N,新建视图控制器MainViewController,如下图
[img]

[/img]



3、依照上步操作,新建视图控制器InfoViewController。





4、编辑MainViewController.xib,添加一个Label和Button,如下图

[img]

[/img]






5、编辑InfoViewController.xib,添加一个Label和Button,如下图
[img]

[/img]





6、修改MainViewController.h,如下
#import <UIKit/UIKit.h>
#import "InfoViewController.h"
@interface MainViewController : UIViewController
@property(nonatomic,retain)InfoViewController *infoViewController;

-(IBAction)showInfoView:(id)sender;
@end



将操作showInfoView与MainViewController.xib中的button的Touch Up Inisde进行关联。






7、修改MainViewController.m,主要是实现showInfoView方法,如下
#import "MainViewController.h"

@interface MainViewController ()

@end

@implementation MainViewController
@synthesize infoViewController;

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // Custom initialization
    }
    return self;
}

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view from its nib.
    //设置背景颜色
    self.view.backgroundColor = [UIColor grayColor];
}

-(void)dealloc{
    [infoViewController release];
}

-(IBAction)showInfoView:(id)sender{
    if(infoViewController == nil){
        infoViewController = [[InfoViewController alloc]initWithNibName:@"InfoViewController" bundle:nil];
        //NSLog(@"infoViewController is nil");
    }else{
        //NSLog(@"infoViewController is not nil");
    }
    infoViewController.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
    
    //[self presentModalViewController:infoViewController animated:YES];//备注1
    [self presentViewController:infoViewController animated:YES completion:^{//备注2
        NSLog(@"show InfoView!");
    }];
    
    //presentedViewController
    NSLog(@"self.presentedViewController=%@",self.presentedViewController);//备注3
}

- (void)viewDidUnload
{
    [super viewDidUnload];
    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;
    infoViewController = nil;
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

@end





备注1、备注2:备注中的方法已经废弃,被备注2中的presentViewController代替;参数completion实现一个回调,当MainViewController的viewDidDisappear调用之后,该回调会被调用。
备注3:在MainViewController中调用self.presentedViewController,返回的是由MainViewController present出的视图控制器,在这里即是:infoViewController。







8、修改InfoViewController.h,如下
#import <UIKit/UIKit.h>

@interface InfoViewController : UIViewController

-(IBAction)backMainView:(id)sender;
@end


将操作backMainView与InfoViewController.xib中的button的Touch Up Inisde进行关联。







9、修改InfoViewController.m,主要是实现方法backMainView,如下
#import "InfoViewController.h"

@interface InfoViewController ()

@end

@implementation InfoViewController

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
    if (self) {
        // Custom initialization
    }
    return self;
}

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view from its nib.
    //设置背景颜色
    self.view.backgroundColor = [UIColor greenColor];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
    // Release any retained subviews of the main view.
    // e.g. self.myOutlet = nil;
}

-(IBAction)backMainView:(id)sender{ 
    NSLog(@"self.parentViewController=%@",self.parentViewController);
    //[self.parentViewController dismissViewControllerAnimated:YES completion:nil];//备注4
    
    /*
     If this view controller is a child of a containing view controller (e.g. a navigation controller or tab bar
     controller,) this is the containing view controller.  Note that as of 5.0 this no longer will return the
     presenting view controller.
     */
    NSLog(@"self.presentedViewController=%@",self.presentedViewController);
    //[self.presentedViewController dismissViewControllerAnimated:YES completion:nil]; //备注5
    
    NSLog(@"self.presentingViewController=%@",self.presentingViewController);
    //[self.presentingViewController dismissViewControllerAnimated:YES completion:nil];//备注6
    
    // Dismiss the current modal child. Uses a vertical sheet transition if animated. This method has been replaced by dismissViewControllerAnimated:completion:
    // It will be DEPRECATED, plan accordingly.
    //[self dismissModalViewControllerAnimated:YES];//备注7
    [self dismissViewControllerAnimated:YES completion:nil];//备注8
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

@end






备注4:不能正常工作,该代码不能实现返回到MainViewController的功能,因为MainViewController并不是InfoViewController的父视图控制器(父子试图控制器以后会讲到),该方法的注释如下:
/*
  If this view controller is a child of a containing view controller (e.g. a navigation controller or tab bar
  controller,) this is the containing view controller.  Note that as of 5.0 this no longer will return the
  presenting view controller.
*/

备注5:不能正常工作,该代码也不能实现返回到MainViewController的功能,备注3中已解释过self.presentedViewController,在此处一定返回空。

备注6:可以正常工作,改代码可以实现返回到MainViewController的功能, self.presentingViewController返回的视图控制器是指present出当前视图控制器(即:infoViewController)的视图控制器,当然是MainViewController。

备注7、8:可以正常工作,改代码可以实现返回到MainViewController的功能,备注7中的方法已经废弃,已被备注8中的方法代替;现在要考虑的问题是:为什么[self dismissViewControllerAnimated:YES completion:nil]与[self.presentingViewController dismissViewControllerAnimated:YES completion:nil]实现了同样的功能?

类UIViewController的dismissViewControllerAnimated方法有一段注释如下:

The presenting view controller is responsible for dismissing the view controller it presented. If you call this method on the presented view controller itself, it automatically forwards the message to the presenting view controller.


什么意思呢?MainViewController把InforViewController 展示出来了,同样也要负责把InforViewController退出,如果直接在InforViewController中发出(调用)dismissViewControllerAnimated消息,这个消息会自动转给MainViewController,所以,在InforViewController中执行[self dismissViewControllerAnimated:YES completion:nil]与[self.presentingViewController dismissViewControllerAnimated:YES completion:nil]两种调用,效果是一样的,调用前者就等同于调用后者。建议用后者,更容易理解。





10、编译、运行,效果如下
[img]

[/img]
[img]

[/img]
















  • 大小: 152.9 KB
  • 大小: 167.7 KB
  • 大小: 163 KB
  • 大小: 12 KB
  • 大小: 12.3 KB
  • 大小: 74.6 KB
  • 大小: 75.1 KB
分享到:
评论

相关推荐

    iPhone开发【八】多视图技术总结之一:ModalView(模态视图)

    本文将深入探讨"iPhone开发【八】多视图技术总结之一:ModalView(模态视图)"这一主题,旨在帮助开发者更好地理解和运用模态视图在实际项目中的应用。 首先,模态视图(Modal View)是一种在当前视图之上显示一个...

    iphone开发实例 02-Modal Alert.

    在iOS应用开发中,"iPhone开发实例 02-Modal Alert"主要涉及到的是苹果设备上显示模态警告视图(Modal Alert)的技术。模态警告视图是一种常见的人机交互方式,它会在用户当前操作的界面之上弹出一个临时窗口,以...

    ios-弹出一个View.zip

    总的来说,"ios-弹出一个View.zip"这个项目涵盖了iOS开发中关于弹出视图的基本概念和实践,包括模态视图的弹出、动作表的使用,以及可能的自定义视图和动画效果。通过研究这个项目,开发者可以更深入地理解iOS UI...

    ModalViewSample

    ModalViewSample是一个针对iOS开发的示例项目,主要展示了如何在iOS应用中使用Modal View。在iOS编程中,Modal View是一种常见的用户界面元素,用于显示临时或重要信息,或者要求用户进行确认或输入数据。这个样本...

    iPhone源码分析(委托模式)

    `方法,处理ModalView关闭后的工作,例如关闭模态视图并返回到MainView。 总结来说,委托模式在iOS开发中起到了关键的作用,它允许对象间进行灵活的通信,同时保持了良好的封装性。在这个例子中,...

    iphone的alterview

    7. **模态对话框(Modal Dialogs)**:`AlterView`通常是模态的,意味着用户必须与之交互后才能继续使用应用。在Android中,这可以通过设置`DialogFragment`的`setCancelable(false)`来实现。 8. **权限管理...

    斯坦福大学iPhone教程11-13.zip

    - **模态视图控制器(Modal View Controller)**:用于显示全屏或半屏的视图,通常用于请求用户输入。 2. **联系人管理(12-AddressBook.pdf)** - **联系人框架(Contacts Framework)**:iOS提供的API,用于...

    ios-TechPopList.zip

    在iOS开发中,弹出视图通常用于显示临时通知、菜单选项或用户输入,可以是模态视图(modal view)或自定义视图组件。这种设计模式提供了良好的用户体验,因为它不会中断当前的任务流,而是以非侵入性的方式呈现信息...

    iPhone调用相机或者打开相册获取图片

    它可以作为一个模态视图控制器(Modal View Controller)呈现给用户,从而获取图片。 二、使用 UIImagePickerController 获取图片 要使用 UIImagePickerController 获取图片,首先需要创建一个 ...

    IOS应用源码——超炫的弹出框选择列表效果.zip

    在iOS SDK中,我们可以使用UIPopoverController类来实现这一功能,但在iPhone上,由于屏幕尺寸限制,我们更倾向于使用模态视图(Modal View)或自定义视图来模拟类似的效果。 在这个源码中,开发者可能利用了...

    iPhone界面设计指南

    #### 六、模态视图(Modal View) - **应用场景**:用于呈现独立于当前界面的临时内容或对话框,常见于信息确认、设置调整等。 #### 七、表视图、文本视图和网页视图(Table, Text, Web Views) - **表视图(Table ...

    ios-页面拉伸.zip

    如果页面是作为模态视图(modal view)出现,那么可以使用不同的呈现风格,如`.fullScreen`、`.overFullScreen`或`.popover`等,来实现类似拉伸的效果。 7. **Storyboard & XIB**: 这个示例可能使用了Storyboard...

    iOS开发中ViewController的页面跳转和弹出模态

    在iOS开发中,ViewController是Model-View-Controller (MVC)设计模式的核心组成部分,负责处理数据和控制视图的展示。页面跳转和模态弹出是ViewController的主要交互方式,帮助用户在应用的不同功能间导航。 页面...

    斯坦福ios7公开课全18集英文字幕

    【斯坦福ios7公开课全18集英文字幕】是一套由斯坦福大学提供的iOS开发课程,涵盖了iOS 7应用程序的开发技术。本课程旨在帮助开发者深入理解如何为iPhone和iPad构建高质量的应用程序,尤其针对iOS 7的新特性和最佳...

    iOS-程序导航演示以及启动图demo

    3. **StackView**:在iOS 9之后引入的UIStackView可以方便地管理和排列多个子视图,为实现复杂的布局提供便利,同时也可以在导航中起到过渡和分隔的作用。 4. **PageViewController**:适合创建滑动浏览的页面,如...

    两个viewcontroller的界面切换

    在iOS应用开发中,View Controller(视图控制器)是构建用户界面的核心组件。"两个viewcontroller的界面切换"这一主题涉及到如何在iPhone应用程序中平滑地从一个ViewController过渡到另一个,同时实现动画效果,以...

    iOS8 人机交互指南

    临时视图(TemporaryViews)包括警告框(Alert)、操作菜单(ActionSheet)、模态视图(ModalView)等。这些视图通常用于显示临时信息或要求用户做进一步的操作。 设计尺寸 iOS8中还涉及不同设备的设计尺寸,包括...

Global site tag (gtag.js) - Google Analytics