iphone下添加系统图片和拍照

本文探讨了在iPad环境中使用UIImagePickerController获取照片库时遇到的问题及解决方案。通过UIPopoverController的引入,成功解决了无法直接调用UIImagePickerController的问题。

- (void)addPhoto

{

    UIImagePickerController * imagePickerController = [[UIImagePickerControlleralloc]init];

    imagePickerController.navigationBar.tintColor = [UIColorcolorWithRed:72.0/255.0green:106.0/255.0blue:154.0/255.0alpha:1.0];

imagePickerController.sourceType =UIImagePickerControllerSourceTypePhotoLibrary;

imagePickerController.delegate =self;

imagePickerController.allowsEditing =NO;

[selfpresentModalViewController:imagePickerController animated:YES];

[imagePickerController release];

}


- (void)takePhoto

{

    if (![UIImagePickerControllerisSourceTypeAvailable:UIImagePickerControllerSourceTypeCamera]) 

    {

        UIAlertView *alert = [[UIAlertViewalloc] initWithTitle:nil 

                                                        message:@"该设备不支持拍照功能" 

                                                       delegate:nil 

                                              cancelButtonTitle:nil 

                                              otherButtonTitles:@"",nil];

        [alert show];

        [alert release];

    }

    else

    {

        UIImagePickerController * imagePickerController = [[UIImagePickerControlleralloc]init];

        imagePickerController.sourceType =UIImagePickerControllerSourceTypeCamera;

        imagePickerController.delegate = self;

        imagePickerController.allowsEditing =NO;

        [self presentModalViewController:imagePickerControlleranimated:YES];

        [imagePickerController release];

    }

}



我们知道,在iPhone中获取照片库常用的方法如下:

 

UIImagePickerController *m_imagePicker = [[UIImagePickerController alloc] init];
    if ([UIImagePickerController isSourceTypeAvailable:
         UIImagePickerControllerSourceTypePhotoLibrary]) {
        m_imagePicker.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
        m_imagePicker.delegate = self;
        //        [m_imagePicker.navigationBar.subviews];
        [m_imagePicker setAllowsEditing:NO];
        //m_imagePicker.allowsImageEditing = NO;
        [self presentModalViewController:m_imagePicker animated:YES];
        [m_imagePicker release];
    }else {
        UIAlertView *alert = [[UIAlertView alloc]initWithTitle:nil message:@"Error accessing photo library!" delegate:nil cancelButtonTitle:@"Close" otherButtonTitles:nil];
        [alert show];
        [alert release];
    }

 

这对iPhone的操作是没有问题的。但是当我们在iPad环境中却有问题了,当我们运行时会报如下错误:

 

Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'On iPad, UIImagePickerController must be presented via UIPopoverController'

 

所以我们必须通过UIPopoverController来实现才行。具体实现如下:

 

UIImagePickerController *m_imagePicker = [[UIImagePickerController alloc] init];
    if ([UIImagePickerController isSourceTypeAvailable:
         UIImagePickerControllerSourceTypePhotoLibrary]) {
        m_imagePicker.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
        m_imagePicker.delegate = self;
        [m_imagePicker setAllowsEditing:NO];
        UIPopoverController *popover = [[UIPopoverController alloc] initWithContentViewController:m_imagePicker];
        self.popoverController = popover;
        //popoverController.delegate = self;
        
        [popoverController presentPopoverFromRect:CGRectMake(0, 0, 300, 300) inView:self.view permittedArrowDirections:UIPopoverArrowDirectionAny animated:YES];
        
        //[self presentModalViewController:m_imagePicker animated:YES];
        [popover release];
        [m_imagePicker release];
    }else {
        UIAlertView *alert = [[UIAlertView alloc]initWithTitle:nil message:@"Error accessing photo library!" delegate:nil cancelButtonTitle:@"Close" otherButtonTitles:nil];
        [alert show];
        [alert release];
    }
这里需要注意,对局部UIPopoverController对象popover我们赋给了一个全局的UIPopoverController对象popoverController。而不能直接调用popover。因为在popover对象还可见时,是不能够被释放的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值