在oc中使用UIImagePickerController只要设置好代理、写代理方法就行了,但是在swift中编译没有什么问题,但是运行的时候会报错,选择一张图片,会显示库是私有的,不能访问,遇到这样的问题很好的解决办法就是在info.plist文件中添加Privacy - Photo Library Usage DescriptionPrivacy - Camera Usage Description 两个字符串属性

下面是代码片段

1.在类中设置代理方法

UIImagePickerControllerDelegate,UINavigationControllerDelegate


2.UIImagePickerController对象的创建

 lazy var imagePicker: UIImagePickerController = {
        let imgPicker = UIImagePickerController()
       imgPicker.modalPresentationStyle = UIModalPresentationStyle.fullScreen
        imgPicker.allowsEditing = true
        imgPicker.delegate = self 
        return imgPicker
    }()

3.图片获取的选择模式,以及UIImagePickerController的代理方法实现

func selectHeadImageFromCamera() {
        
        let alertVC = UIAlertController(title: nil,message: nil,preferredStyle: .actionSheet)
        
        let cancelAction = UIAlertAction(title: "取消",style: .default) { (action) in
            
            
        }
        
       
        weak var weakSelf = self
        let cameralAction = UIAlertAction(title: "拍照",style: .default) { (action) in
            
            weakSelf?.clickedButtonAtIndex(index: 0)
        }
        
        let pictureAction = UIAlertAction(title: "相册",style: .default) { (action) in
            
             weakSelf?.clickedButtonAtIndex(index: 1)
        }
        
        alertVC.addAction(cameralAction)
        alertVC.addAction(pictureAction)
        alertVC.addAction(cancelAction)
        
        self.present(alertVC,animated: true,completion: nil)
        
    }
    
    //#pram mark --UIImagePickerControllerDelegate
    
    func imagePickerController(_ picker: UIImagePickerController,didFinishPickingMediawithInfo info: [String : Any]) {
        
        self.hideHud()
        self.showHud(in: self.view,hint: "上传中...")
        let image:UIImage = info[UIImagePickerControllerOriginalImage] as! UIImage
        picker.dismiss(animated: true,completion: nil)
        
        if image != nil {
            
             self.updateUserHeadPortrait(image: image)
        }
        else
        {
            self.hideHud()
            self.showHint("上传失败")
        }
        
    }
    
    func updateUserHeadPortrait(image:UIImage){
        
      
        let newImage = self.imageWithImage(image: image,scaletoSize: CGSize(width: 150.0,height: 150.0))
        weak var weakSelf = self
        if newImage != nil {
            weak var weakSelf = self
            NetService.apiUpdateUserHeadPortait(newImage,success: { (success) in
                
                weakSelf?.imageView?.image = newImage
                ManagerTool.shared.currentUserInfo.babyHeadPortrait = success
                weakSelf?.hideHud()
                weakSelf?.showHint("上传成功")
                
            },failure: { (failure) in
                weakSelf?.hideHud()
                weakSelf?.showHint("上传失败")
            })
        }
    }
    
    func imageWithImage(image:UIImage,scaletoSize:CGSize) -> UIImage {
        
        UIGraphicsBeginImageContext(scaletoSize)
        image.draw(in: CGRect(x: 0,y: 0,width: scaletoSize.width,height: scaletoSize.height))
        let newImage:UIImage = UIGraphicsGetimageFromCurrentimageContext()!
        UIGraphicsEndImageContext()
        
        return newImage
    }
    
    
    func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
        
        self.imagePicker.dismiss(animated: true,completion: nil)
    }
    
    func clickedButtonAtIndex(index:Int) {
        
        
        if index == 0
        {
            print("\(index)")
           
            if Platform.isSimulator
            {
                self.hideHud()
                self.showHint("模拟器不支持拍照功能")
            }
            else
            {
                if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera){
                    self.imagePicker.sourceType = UIImagePickerControllerSourceType.camera
                    
                    if UIImagePickerController.isCameraDeviceAvailable(UIImagePickerControllerCameraDevice.front){
                        self.imagePicker.cameraDevice = UIImagePickerControllerCameraDevice.front
                    }
                    self.imagePicker.mediaTypes = [kUTTypeImage as String]
                    self.present(self.imagePicker,completion: nil)
                }
            }

        }
        else if index == 1{
            
            self.imagePicker.sourceType = UIImagePickerControllerSourceType.photoLibrary
            self.imagePicker.mediaTypes = [kUTTypeImage as String];
            self.present(self.imagePicker,completion: nil)
        }
        
    }

swift3.0之UIImagePickerController的使用和注意事项的更多相关文章

  1. ios – UITextFieldDelegate vs UITextField控件事件

    处理编辑开始或编辑结束的相同问题.它可以通过适当的委托方法或适当的事件来完成.如果控件事件可以进行必要的工作,那么textField代理是什么?

  2. swift详解之十一------------协议、委托(代理)模式

    协议、委托(代理)模式注:本小节总结协议以及依靠协议实现委托,这将在以后经常被使用。很简单的例子说明下,在协议中用static在实现类里可以用static或者class在协议中使用mutating变异方法。然后他就一共实现了两个协议,一个sayHello一个hmtl的这时候这两个方法就都可以用了当然我们的协议也是可以继承的。

  3. Swift 委托/代理设计模式

    Swift中的委托/代理模式与object-c的代理模式基本一致。代理模式的基本思想就是将我需要来完成的工作交给(委托给)另一个有我所规定的做这项工作能力的人来处理。代理模式的实现需借助于我们上一篇文章所讲的协议。比如说我找到了玛雅房屋让他们去帮我租租房。我只需要告诉他们我要一个大致什么位置,多大,什么类型,价格范围等,他们就可以帮我去租房。玛雅房屋就是接受委托的对象,因为他有满足我要求的能力。

  4. Swift实现委托代理的N种方式

    首先理清概念,delegate只是一种模式理念,不是具体方法。OK1.extension继承法:赋予某根类扩展“空方法”,使其子类继承后可重写成为代理。就要你成为我的奴隶2.protocal协议法:只要实现了指定protocal即可成为代理下蛋的鸡就是好鸡3.闭包+Tuple代理:swift中方法也是firstclassvalue这不是人,这不是妖,这是人妖4.继承NSObject使用methodForSelector,使用OC中NSObject提供的的“反射”机制完成调用无耻下作的典范

  5. Swift:界面传值大全

    声明了代理属性之后,我们需要在处理界面跳转(返回)的方法中处理协议传值的逻辑了。

  6. Swift设计模式之保护代理模式

    转自Swift设计模式原文Design-Patterns-In-Swift

  7. swift设计模式学习 - 代理模式

    代理模式的组成抽象角色:通过接口或抽象类声明真实角色实现的业务方法。代理模式的基本实现上图是最基本的代理模式的结构图,下面将用Swift代码来实现一个基本代理模式:以上是一个最基本的代理模式的构成,这样可以用Proxy来代替RealSubject,从而对客户端隐藏真实的对象。高扩展性以上是我对于代理模式的理解,如果有不对的地方欢迎大家交流,最后谢谢大家的阅读~~

  8. swift3.0之UIImagePickerController的使用和注意事项

    在oc中使用UIImagePickerController只要设置好代理、写代理方法就行了,但是在swift中编译没有什么问题,但是运行的时候会报错,选择一张图片,会显示库是私有的,不能访问,遇到这样的问题很好的解决办法就是在info.plist文件中添加Privacy-PhotoLibraryUsageDescription和Privacy-CameraUsageDescription两个字符串

  9. KVC原理剖析

    协议定义KVC全称是KeyValueCoding,定义在NSkeyvalueCoding.h文件中,是一个非正式协议。基础操作KVC主要对三种类型进行操作,基础数据类型及常量、对象类型、集合类型。在使用KVC时,直接将属性名当做key,并设置value,即可对属性进行赋值。在KVC进行属性赋值时,内部会对基础数据类型做处理,不需要手动做NSNumber的转换。集合属性操作根据KVO的实现原理,是在运行时生成新的子类并重写其setter方法,在其内容发生改变时发送消息。

  10. Java代理模式的示例详解

    代理模式(Proxy Parttern)为一个对象提供一个替身,来控制这个对象的访问,即通过代理对象来访问目标对象。本文将通过示例详细讲解一下这个模式,需要的可以参考一下

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部