点击按钮时无法关闭模态视图

时间:2011-10-14 07:25:13

标签: iphone objective-c xcode modalviewcontroller

在“FirstViewController”中,我声明了一个显示模态视图“InfoViewController”的按钮。

在“InfoViewController”中,我声明了一个带有“modalViewButton”UIButton的工具栏,它取消了模态视图。但是“OK”UIButton不起作用。我不知道为什么。

这是FirstViewController.h

#import <UIKit/UIKit.h>
#import "InfoViewController.h"

@interface FirstViewController : UIViewController 
{
    InfoViewController *infoViewController; 
}

@property (nonatomic, retain) InfoViewController *infoViewController;
@end

这是FirstViewController.m

#import "FirstViewController.h"
@implementation FirstViewController
@synthesize infoViewController;

- (IBAction)modalViewAction:(id)sender
{  
    if (self.infoViewController == nil)
        self.infoViewController = [[[InfoViewController alloc] initWithNibName:
                                NSStringFromClass([InfoViewController class]) bundle:nil] autorelease];
    [self presentModalViewController:self.infoViewController animated:YES];
}

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

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

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];   
}

#pragma mark - View lifecycle

- (void)viewDidLoad
{
    [super viewDidLoad];

    UIButton* modalViewButton = [UIButton buttonWithType:UIButtonTypeInfoLight];
    [modalViewButton addTarget:self 
                    action:@selector(modalViewAction:) 
          forControlEvents:UIControlEventTouchUpInside];
    UIBarButtonItem *modalBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:modalViewButton];
    self.navigationItem.leftBarButtonItem = modalBarButtonItem;
    [modalBarButtonItem release];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
}

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

@end

这是InfoViewController.h

#import <UIKit/UIKit.h>     
@interface InfoViewController : UIViewController 
{

}
-(IBAction)infoDismissAction:(id)sender;
@end

这是InfoViewController.m

#import "InfoViewController.h"

@implementation InfoViewController

- (IBAction)infoDismissAction:(id)sender
{
    [self.parentViewController dismissModalViewControllerAnimated:YES];
}

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

    }
    return self;
}

- (void)dealloc
{
    [super dealloc];
}    

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
}

#pragma mark - View lifecycle

- (void)viewDidLoad
{
    [super viewDidLoad];

    UILabel *infoLabel = [[UILabel alloc] init];
    infoLabel.frame = CGRectMake(50, 100, 100, 40);     
    infoLabel.textAlignment = UITextAlignmentCenter;        
    infoLabel.text = @"About";      
    [self.view addSubview:infoLabel];       

    UIToolbar *toolBar;
    toolBar = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 0, 320, 50)];
    toolBar.frame = CGRectMake(0, 0, 320, 50);
    toolBar.barStyle = UIBarStyleDefault;
    [toolBar sizeToFit];    

    UIBarButtonItem *flexibleSpace = [[[UIBarButtonItem alloc] initWithBarButtonSystemItem:                               UIBarButtonSystemItemFlexibleSpace 
                                                                                target:nil 
                                                                                        action:nil] autorelease];

    UIBarButtonItem *doneButton = [[UIBarButtonItem alloc] initWithTitle:@"OK" 
                                                                   style:UIBarButtonItemStyleBordered 
                                                              target:self 
                                                              action:@selector(infoDismissAction:)];

    UIBarButtonItem* infoTitle = [[UIBarButtonItem alloc] initWithTitle:@"About" 
                                                              style:UIBarButtonItemStylePlain 
                                                             target:self action:nil];

    NSArray *barButtons = [[NSArray alloc] initWithObjects:flexibleSpace,flexibleSpace,infoTitle,flexibleSpace,doneButton,nil];

    [toolBar setItems:barButtons];

    [self.view addSubview:toolBar]; 

    [toolBar release];
    [infoTitle release];
    [doneButton release];
    [barButtons release];
    [infoLabel release];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
}

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

@end

5 个答案:

答案 0 :(得分:3)

我会用委托方法解决这个问题。

首先在modalViewController中创建一个协议

@protocol ModalViewDelegate <NSObject>

 - (void)didDismissModalView;

@end

并在同一modalVC中设置委托属性:

id<ModalViewDelegate> dismissDelegate;

然后创建一个调用modalVC中的委托的buttonActionMeth:

- (void)methodCalledByButton:(id)sender 
{
    // Call the delegate to dismiss the modal view
    [self.dismissDelegate didDismissModalView];
}

现在您的modalVC已经完成,您必须准备调用modalVC的mainVC: 您必须使MainViewController符合委托:

@interface MainViewController : UIViewController <ModalViewDelegate>

在你分配ModalViewController的地方,你必须设置你在modalViewController中所做的委托属性:

self.myModalViewController.dismissDelegate = self;

现在MainViewController监听委托,你唯一需要做的就是实现delegateMethod。

-(void)didDismissModalView
{
    [self dismissModalViewControllerAnimated:YES];
}

现在你的ModalVC将在按钮上解除(至少在你正确调用方法时)

希望这一切都有意义。 祝你好运。

答案 1 :(得分:1)

您只能关闭当前显示的模态视图,因此在您的方法infoDismissAction:中,您应该执行以下操作之一

1)[self dismissModalViewControllerAnimated:YES];

2)发送至parent view controller消息,表示当前的模态视图应被解除,并发送对该视图的引用。

第二种方法更好,因为它更安全。

答案 2 :(得分:0)

-infoDismissAction尝试拨打[self dismissModalViewControllerAnimated:YES];

答案 3 :(得分:0)

这里是iphone和ipad模型视图的最佳示例代码。

弹出窗口有许多可配置的项目。可以将它们设置为动画,以便滑动或弹出到显示屏上。一旦可见,可以通过点击屏幕或在编程延迟后解除它们。您也可以根据需要调整背景和文字颜色。

下载sample code from here.

答案 4 :(得分:0)

目前的答案已被弃用。这是更新的代码:

[self dismissViewControllerAnimated:NO completion:nil];