html5 拍照上传(Html5在手机端调用相机的方法实现)
html5 拍照上传
Html5在手机端调用相机的方法实现input调用设备录像,相机等…
HTML5官方文档解释:capture属性用于调用设备的摄像头或麦克风。
当accept=”audio/或video/”时capture只有两种值,一种是user,用于调用面向人脸的摄像头(例如手机前置摄像头),一种是environment,用于调用环境摄像头(例如手机后置摄像头)。
当accept=”audio”时,只要有capture就调用设备麦克风,忽略user和environment值。
至于网上提到的camera和filesystem,官方没提。
官方文档:www.w3.org/TR/2018/REC-html-media-capture-20180201/
iOS最遵守遵守HTML5规范,其次是X5内核,安卓的webview基本忽略了capture。
理想情况下应该按照如下开发webview:
1.当accept=”image/”时,capture=”user”调用前置照相机,capture=”其他值”,调用后置照相机
2. 当accept=”video/”时,capture=”user”调用前置录像机,capture=”其他值”,调用后置录像机
3. 当accept=”image/,video/”,capture=”user”调用前置摄像头,capture=”其他值”,调用后置摄像头,默认照相,可切换录像
4. 当accept=”audio/*”时,capture=”放空或者任意值”,调用录音机
5. 当input没有capture时,根据accppt类型给出文件夹选项以及摄像头或者录音机选项
6. input含有multiple时访问文件夹可勾选多文件,调用系统摄像头或者录音机都只是单文件
7. 无multiple时都只能单文件
判断设备类型
var ua = navigator.userAgent.toLowerCase(); if(ua.match(/android/i)) == "android") { alert("android"); } if(ua.match(/iPhone/i)) == "iPhone") { alert("iPhone"); } if(ua.match(/iPad/i)) == "iPad") { alert("iPad"); }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <input type="file" accept="image/*" capture="camera"> <input type="file" accept="video/*" capture="camcorder"> <input type="file" accept="audio/*" capture="microphone"> </body> </html> <script> var file = document.querySelector('input'); if (getIos()) { file.removeAttribute("capture"); //如果是ios设备就删除"capture"属性 } function getIos() { var ua=navigator.userAgent.toLowerCase(); if (ua.match(/iPhone\sOS/i) == "iphone os") { return true; } else { return false; } } </script>
到此这篇关于Html5在手机端调用相机的方法实现的文章就介绍到这了,更多相关Html5手机端调用相机内容请搜索开心学习网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持开心学习网!
- html5+canvas动画(解析html5 canvas实现背景鼠标连线动态效果代码)
- html5导入图片文件(HTML5 实现图片上传预处理功能)
- html5播放视频的元素(HTML5在手机端实现视频全屏展示方法)
- html5app开发用什么平台(Html5与App的通讯方式详解)
- HTML5 <abbr>标签
- html5播放代码(html5 video全屏播放/自动播放的实现示例)
- html5按钮点击跳转(HTML5页面嵌入小程序没有返回按钮及返回页面空白的问题)
- html为什么视频不能自动播放(html5中嵌入视频自动播放的问题解决)
- html5+css样式代码(详解HTML5中CSS外观属性)
- html5css3旋转特效效果(一款利用html5和css3实现的3D立方体旋转效果教程)
- html5底部组件(HTML5 Blob对象的具体使用)
- html5input标签的默认属性(移动端HTML5 input常见问题小结)
- Html5中的<section>标签
- html5的语法变化(详解HTML5.2版本带来的修改)
- html5 canvas绘图(使用html5 canvas绘制圆环动效)
- html5socket源码(五分钟学会HTML5的WebSocket协议)
- 蓝底证件照怎么制作 证件照换底色 换尺寸快速搞定(蓝底证件照怎么制作)
- 你喜欢足球吗 足球如何点亮世界的(足球如何点亮世界的)
- 不可分鸽是什么梗(不可分鸽是什么梗)
- 古代的鸽子是爱情的象征,并非和平的使者(古代的鸽子是爱情的象征)
- 一课译词 放鸽子(一课译词放鸽子)
- 终于来了,淘宝更改账户名测试中,快去看看你能不能修改(淘宝更改账户名测试中)
热门推荐
- vs连接sql语句(vs code连接sql server数据库步骤及遇到的问题小结)
- 香港云主机推荐(香港云主机租用如何选择操作系统?)
- 宝塔面板密码忘记了怎么解锁(宝塔面板忘记用户名密码怎么找回)
- vmware16虚拟机的安装教程(最新虚拟机VMware 14安装教程)
- apache https配置(Apache httpd 安装module mod_expires、mod_deflate的方法)
- docker安装教程图解(Docker在线、离线安装及其常用命令操作)
- php多维数组怎么转换json(php实现的数组转xml案例分析)
- css画三角形几种方法(利用CSS绘制任意角度的扇形示例代码)
- mysql生成唯一订单号(MySQL高并发生成唯一订单号的方法实现)
- NoSQL的优缺点