iOS开发 swift -- 获取相册相机

一 代理

swift一定要遵循UIImagePickerControllerDelegate,UINavigationControllerDelegate俩个代理

二 info.plist

    在info.plist中加入安全域名白名单(右键info.plist用source code打开)
    <key>NSCameraUsageDescription</key>
    <string>访问相机</string>
    <key>NSPhotoLibraryUsageDescription</key>
    <string>访问相册</string>

三 代码示例

func addIcon()  {

        let alertAction = UIAlertController.init(title: nil, message: nil, preferredStyle: .actionSheet)
        alertAction.addAction(UIAlertAction.init(title: "获取相机", style: .default, handler: { (alertCamera) in

            let picker:UIImagePickerController = UIImagePickerController()
            picker.delegate = self as UIImagePickerControllerDelegate & UINavigationControllerDelegate
            picker.sourceType = .camera
            picker.allowsEditing = true
            if UIImagePickerController.isSourceTypeAvailable(.camera){

                self.present(picker, animated: true, completion: { () -> Void in

                })
            }else{
                MBProgressHUD.showForError(to: self.view, text: "为授予防问相机权限", completion: nil)
            }
        }))

        alertAction.addAction(UIAlertAction.init(title: "获取相册", style:.default, handler: { (alertPhpto) in

            let picker:UIImagePickerController = UIImagePickerController()
            picker.delegate = self as UIImagePickerControllerDelegate & UINavigationControllerDelegate
            picker.sourceType = .photoLibrary
            picker.allowsEditing = true

            if UIImagePickerController.isSourceTypeAvailable(.photoLibrary){

                self.present(picker, animated: true, completion: {
                    () -> Void in
                })
            }else{
                MBProgressHUD.showForError(to: self.view, text: "为授予防问相册权限", completion: nil)
            }
        }))

        alertAction.addAction(UIAlertAction.init(title: "取消", style: .cancel, handler: { (alertCancel) in

        }))

        self.present(alertAction, animated: true, completion: nil)
    }

    // MARK: ImagePicker Delegate 选择图片成功后代理
    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {

        if let chosenImage =  info[UIImagePickerControllerOriginalImage] as? UIImage {
            picker.dismiss(animated: true) {
                self.iconImage.image = chosenImage
            }
        //处理传入后台
        }
    }

四 上传到后台

    /// 上传图片
    ///
    /// - Parameters:
    ///   - path: <#path description#>
    ///   - image: <#image description#>
    ///   - completion: <#completion description#>
    class func uploadImage(path: String, image: UIImage, completion: @escaping (_ succeeded: Bool, _ url: String?) -> Void) {

        /* 签名 可忽略
        let timestamp  = String(Int(NSDate().timeIntervalSince1970 * 1000))
        var _paramters = [String: Any]()
        _paramters["timestamp"] = timestamp
        let sortedKeys = _paramters.keys.sorted()
        var temp = sortedKeys.map({ "\($0)=\(_paramters[$0]!)" }).joined(separator: "&")
        temp += "&--------"
        let sign = temp.md5().uppercased()
        _paramters["sign"] = sign
        */

        Alamofire.upload(multipartFormData: { (multipartFormData) in
            let data = UIImageJPEGRepresentation(image, 0.9)
            multipartFormData.append(data!, withName: "file", fileName: "image.png", mimeType: "image/png")

            for (key, value) in _paramters {
                multipartFormData.append((value as AnyObject).data(using: String.Encoding.utf8.rawValue)!, withName: key)
            }
        }, to: Constant.baseURL + path) { (result) in
            switch result {
            case .success(let upload, _, _):
                upload.responseJSON(completionHandler: { (response) in
                    completion(true, JSON(response.data!)["data"].string)
                })
            case .failure(let error):
                print(error)
                completion(false, nil)
            }
        }
    }

如有不妥,请多多指教



作者:Hayley__
链接:http://www.jianshu.com/p/00d2de98c6f4
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值