当前位置: 首页 > news >正文

swift html5 相机调用,Swift调用摄像头拍照或者录制视频

开启摄像头拍摄视频或者照片,需要使用UIKit中的UIImagePickerController类。

直接用代码+注释方式来看吧:

//开启摄像头

@IBAction func btnRecord(sender: AnyObject) {

//第一步,检测摄像头是否可用

if SCCamera.isAvailable(){

//根据指定的SourceType来获取该SourceType下可以用的媒体类型,返回的是一个数组

let mediaTypeArr:NSArray = UIImagePickerController.availableMediaTypesForSourceType(UIImagePickerControllerSourceType.Camera)!

//判断数组中是否存在kUTTypeMovie和kUTTypeImage类型(需要import MobileCoreServices)

//kUTTypeMovie 表示可以录制带有音频的视频

//kUTTypeImage 表示可以拍摄照片

if mediaTypeArr.containsObject(kUTTypeMovie) && mediaTypeArr.containsObject(kUTTypeImage){

//创建一个UIImagePickerController

var pickerControl = UIImagePickerController()

//必须,第一步,设置SourceType,Camera表示相机

pickerControl.sourceType = UIImagePickerControllerSourceType.Camera

//必须,第二步,设置相机的View中可以使用的媒体类型,这里直接使用上面的mediaTypeArr,它包含了视频和图像

pickerControl.mediaTypes = mediaTypeArr as [AnyObject]

//必须,第三步,设置delegate:UIImagePickerControllerDelegate,UINavigationControllerDelegate

//这两个必须都写上,可以进入头文件查看到

pickerControl.delegate = self

//可选,视频最长的录制时间,这里是10秒,默认为10分钟(600秒)

pickerControl.videoMaximumDuration = 10

//可选,设置视频的质量,默认就是TypeMedium

pickerControl.videoQuality = UIImagePickerControllerQualityType.TypeMedium

//设置视频或者图片拍摄好后,是否能编辑,默认为false不能编辑

pickerControl.allowsEditing = true

//必须,第四步,显示

self.presentViewController(pickerControl, animated: true, completion: nil)

}

}else{

SCMessageBox.show(self, title: "提示", contentMsg: "当前设备不支持摄像头", buttonString: "确认", blockHandler: nil)

}

}

代码中的这2个类:SCCamera和SCMessageBox是我自己写的一个封装,把这些常用的操作封装成一个FrameWork,便于项目中快速使用,目前还在逐渐的完善中,后续会放在Github上,请关注我的博客。

这里这2个方法实现如下:

public class SCCamera{

/**

当前设备的相机是否可用

:returns: 可用返回true,否则返回false

*/

public class func isAvailable()->Bool{

return UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera)

}

}

public typealias SCMessageBoxStyle = UIAlertControllerStyle

public typealias SCMessageBoxActionStyle = UIAlertActionStyle

public class SCMessageBox{

/**

获取UIAlertController对象

:param: title 标题提示内容

:param: contentMsg 主要信息内容

:param: boxStyle 窗口样式:Alert或者ActionSheet

:returns:

*/

public class func boxController(title:String,contentMsg:String,boxStyle:SCMessageBoxStyle)->UIAlertController{

return UIAlertController(title: title, message: contentMsg, preferredStyle: boxStyle)

}

/**

获取指定的UIAlertAction对象

:param: buttonString 按钮文本内容

:param: boxActionStyle 按钮类型

:param: blockHandler 点击按钮后的事件回调方法

:returns:

*/

public class func boxAction(buttonString:String,boxActionStyle:SCMessageBoxActionStyle,blockHandler:((UIAlertAction!) -> Void)!) -> UIAlertAction{

return UIAlertAction(title: buttonString, style: boxActionStyle, handler: blockHandler)

}

/**

快速显示一个Alert弹窗

:param: viewControl 需要显示的页面(常用Self表示当前viewControl)

:param: title 弹窗的标题文本内容

:param: contentMsg 弹窗的主要内容

:param: buttonString 按钮的文本内容

:param: blockHandler 按钮点击事件的回调方法

*/

public class func show(viewControl:UIViewController,title:String,contentMsg:String,buttonString:String,blockHandler:((UIAlertAction!) -> Void)!){

let control = self.boxController(title, contentMsg: contentMsg, boxStyle: SCMessageBoxStyle.Alert)

let action = self.boxAction(buttonString, boxActionStyle: SCMessageBoxActionStyle.Default, blockHandler: blockHandler)

control.addAction(action)

viewControl.presentViewController(control, animated: true, completion: nil)

}

}

到目前为止,我们已经可以开启摄像头进行视频和图片的拍摄了,但是还没有定义完成后的事件,我们该如何保存视频和图片呢?

上面代码中,配置了UIImagePickerController的delegate,那么我们就要实现相应的方法:

//拍摄完成(用户点击了Done按钮)

func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [NSObject : AnyObject]){

//info是一个字典,包含了拍摄结果的各种信息

let infodic:NSDictionary = info as NSDictionary

//获取键值UIImagePickerControllerMediaType的值,表示了当前处理的是视频还是图片

let mediaType = infodic["UIImagePickerControllerMediaType"] as! String

//如果是视频的话

if mediaType == kUTTypeMovie as String{

saveMovie(infodic)

}

//如果是图片

else if mediaType == kUTTypeImage as String{

savePicture(infodic)

}

//最后,dismiss拍摄窗口

picker.dismissViewControllerAnimated(true, completion: nil)

}

//保存视频方法

func saveMovie(infodic:NSDictionary){

//系统保存到tmp目录里的视频文件的路径

let mediaUrl: NSURL = infodic[UIImagePickerControllerMediaURL] as! NSURL

let videoPath = mediaUrl.path

//如果视频文件可以保存的话

if UIVideoAtPathIsCompatibleWithSavedPhotosAlbum(videoPath){

//用这个方法来保存视频

UISaveVideoAtPathToSavedPhotosAlbum(videoPath, nil, nil, nil)

}

}

//保存图片方法

func savePicture(infodic:NSDictionary){

//拍摄的原始图片

let originalImage:UIImage?

//用户修改后的图片(如果allowsEditing设置为True,那么用户可以编辑)

let editedImage:UIImage?

//最终要保存的图片

let savedImage:UIImage?

//从字典中获取键值UIImagePickerControllerEditedImage的值,它直接包含了图片数据

editedImage = infodic["UIImagePickerControllerEditedImage"] as? UIImage

//从字典中获取键值UIImagePickerControllerOriginalImage的值,它直接包含了图片数据

originalImage = infodic["UIImagePickerControllerOriginalImage"] as? UIImage

//判断是否有编辑图片,如果有就使用编辑的图片

if (editedImage != nil){

savedImage = editedImage

}else{

savedImage = originalImage

}

//保存图片到用户的相机胶卷中

UIImageWriteToSavedPhotosAlbum(savedImage, nil, nil, nil)

}

这里需要注意到的是,我是怎么知道infodic中有哪些键值的呢?很简单,只需要println下~下面列出了视频和图片两种类型下的字典数据:

视频:

[

_UIImagePickerControllerVideoEditingStart: 0,

UIImagePickerControllerMediaURL: file:///private/var/mobile/Containers/Data/Application/73A1E385-7A25-4318-97A4-60EFE779C5A9/tmp/capture/capturedvideo.MOV,

UIImagePickerControllerMediaType: public.movie,

_UIImagePickerControllerVideoEditingEnd: 10

]

图片:

[

UIImagePickerControllerEditedImage: size {640, 640} orientation 0 scale 1.000000,

UIImagePickerControllerOriginalImage: size {2448, 3264} orientation 3 scale 1.000000,

UIImagePickerControllerCropRect: NSRect: {{965, 717}, {1492, 1493}},

UIImagePickerControllerMediaMetadata: {

DPIHeight = 72;

DPIWidth = 72;

。。。

},

UIImagePickerControllerMediaType: public.image

]

Metadata很长,这里省略了。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • C# 动态生成Word文档
  • 超轻量级MVC框架的设计和实现 (3)
  • html视频位置左上角,html5视频标签的Css对齐和定位
  • Java中对图片文件的类型的获取
  • html5圆环图比例教程,Chart.js 使用实例 - 圆环比例图表
  • Java重定向System.out和System.err
  • 3d怎么保存html格式,html – Internet Explorer保存3D修复
  • java.util.ConcurrentModificationException异常的解决办法
  • 分析思考html网页结构,网页布局WEB标准的HTML结构化
  • html input type text标签属性和方法事件
  • html的id与name属性,input中id和name属性具体有什么不同啊?(示例)
  • 2021河南固高高考成绩查询,2011河南高考状元:理科状元谢远航 720分 固始慈济高中...
  • 北京.NET俱乐部2007年12月2日活动通知
  • html文件记事本打开乱码,如何解决记事本打开出现乱码
  • 2021年广东高考成绩短信查询方式,2014年广东高考成绩查询 短信查询方式
  • flask接收请求并推入栈
  • MySQL几个简单SQL的优化
  • redis学习笔记(三):列表、集合、有序集合
  • SpiderData 2019年2月16日 DApp数据排行榜
  • Wamp集成环境 添加PHP的新版本
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 多线程事务回滚
  • 检测对象或数组
  • 项目管理碎碎念系列之一:干系人管理
  • 原生js练习题---第五课
  • 深度学习之轻量级神经网络在TWS蓝牙音频处理器上的部署
  • 3月27日云栖精选夜读 | 从 “城市大脑”实践,瞭望未来城市源起 ...
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • ​1:1公有云能力整体输出,腾讯云“七剑”下云端
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​软考-高级-信息系统项目管理师教程 第四版【第14章-项目沟通管理-思维导图】​
  • # Spring Cloud Alibaba Nacos_配置中心与服务发现(四)
  • # 服务治理中间件详解:Spring Cloud与Dubbo
  • ## 基础知识
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • (1)常见O(n^2)排序算法解析
  • (TipsTricks)用客户端模板精简JavaScript代码
  • (二)JAVA使用POI操作excel
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (七)微服务分布式云架构spring cloud - common-service 项目构建过程
  • (十一)手动添加用户和文件的特殊权限
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (原)本想说脏话,奈何已放下
  • (原創) 如何將struct塞進vector? (C/C++) (STL)
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)负载均衡,回话保持,cookie
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • ****** 二 ******、软设笔记【数据结构】-KMP算法、树、二叉树
  • .cn根服务器被攻击之后
  • .NET 2.0中新增的一些TryGet,TryParse等方法
  • .net 开发怎么实现前后端分离_前后端分离:分离式开发和一体式发布
  • .net 流——流的类型体系简单介绍
  • .php文件都打不开,打不开php文件怎么办
  • @ModelAttribute注解使用
  • [1204 寻找子串位置] 解题报告