HTML5 device access 设备访问详解


Posted in HTML / CSS onMay 24, 2018

camera api (含图片预览)

参考地址

主要为利用input type=file, accept="image/*" 进行处理

图片预览方式(两种)

const file = e.target.files[0]
// 方式1 
const url1 = window.URL.createObjectURL(file);
let url2

// 方式2
const reader = new FileReader();
reader.onload = (e) => {
    url2 = e.target.result;
};
reader.readAsDataURL(file);

touch events (触屏事件)

参考地址

  1. touchstart
  2. touchen
  3. touchcancel 电话的接入或者弹出信息等比较高级的事件触发,一般做保存操作
  4. touchmove
  5. geolocation

参考地址

注意谷歌浏览器要https才能提供定位服务

if (navigator.geolocation){
        navigator.geolocation.getCurrentPosition((position) => {
            this.geolocation = `latitude:${position.coords.latitude},longitude:${position.coords.longitude}`
        }, (err) => {
            console.log(err);
        }, {
                enableHighAccuracy: true, 
                maximumAge        : 30000,  // buffer memory timre
                timeout           : 27000   // waiting time 
        })
    } else {
        alert('geolocation not supported!')
    }

device orientation and motion

参考地址 

window.addEventListener('deviceorientation',(doe) => {
        this.absolute = doe.absolute //false 表示方向数据由设备本身坐标系提供
        this.alpha = doe.alpha // 绕Z轴0-360 进入时手机水平正对的方向为0或360
        this.beta = doe.beta // 绕X轴-180~180 描述由前向后旋转
        this.gamma = doe.gamma // 绕Y轴-90~90 描述由左向右旋转
    }, true)

    // chrome v65 只支持accelerationIncludingGravity和interval(应该因为一些限制没有找到),其它浏览器最新版基本都支持
    window.addEventListener('devicemotion', (dme) => {
        this.acceleration = dme.acceleration
        this.accelerationIncludingGravity = dme.accelerationIncludingGravity
        this.rotationRate = dme.rotationRate
        this.interval  = dme.interval 
    }, false)

Pointer Lock(鼠标锁定)

参考地址 

<button onclick="lockPointer();">锁住它!</button>
    <div id="pointer-lock-element" style="width:500px;height:500px;background-color: red"></div>
// 简单示例,将鼠标锁定在 pointer-lock-element 元素内
    let = document.getElementById("pointer-lock-element");
    
    document.addEventListener("mousemove", function(e) {
        var movementX = e.movementX 
            movementY = e.movementY

        // 打印鼠标移动的增量值。
        console.log("X=" + movementX, "Y=" + movementY);
    }, false);

    function lockPointer() {
        elem = document.getElementById("pointer-lock-element");
        elem.requestPointerLock = elem.requestPointerLock    ||
                            elem.mozRequestPointerLock ||
                            elem.webkitRequestPointerLock;
        elem.requestPointerLock();
    }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
使用CSS3实现字体颜色渐变的实现
Mar 09 HTML / CSS
发现两个有趣的CSS3动画效果
Aug 14 HTML / CSS
css3进行截取替代js的substring
Sep 02 HTML / CSS
css3中flex布局宽度不生效的解决
Dec 09 HTML / CSS
css3实现书本翻页效果的示例代码
Mar 08 HTML / CSS
html5仿支付宝密码框的实现代码
Sep 06 HTML / CSS
html5使用canvas画三角形
Dec 15 HTML / CSS
h5调用摄像头的实现方法
Jun 01 HTML / CSS
浅谈HTML5 &amp; CSS3的新交互特性
Jul 19 HTML / CSS
快速创建 HTML5 Canvas 电信网络拓扑图的示例代码
Mar 21 HTML / CSS
Html5适配iphoneX刘海屏的简单实现
Apr 09 HTML / CSS
CSS实现五种常用的2D转换
Dec 06 HTML / CSS
html5-canvas中使用clip抠出一个区域的示例代码
May 25 #HTML / CSS
基于 HTML5 的 WebGL 3D 版俄罗斯方块的示例代码
May 28 #HTML / CSS
HTML5探秘:用requestAnimationFrame优化Web动画
Jun 03 #HTML / CSS
html5触摸事件判断滑动方向的实现
Jun 05 #HTML / CSS
使用Canvas操作像素的方法
Jun 14 #HTML / CSS
Html5移动端获奖无缝滚动动画实现示例
Jun 25 #HTML / CSS
video结合canvas实现视频在线截图功能
Jun 25 #HTML / CSS
You might like
php cli换行示例
2014/04/22 PHP
使用PHP编写发红包程序
2015/07/22 PHP
使用PHP如何实现高效安全的ftp服务器(二)
2015/12/30 PHP
PHP中的使用curl发送请求(GET请求和POST请求)
2017/02/08 PHP
yii2.0框架数据库操作简单示例【添加,修改,删除,查询,打印等】
2020/04/13 PHP
JS动态获取当前时间,并写到特定的区域
2013/05/03 Javascript
使用js判断当前时区TimeZone是否是夏令时
2014/02/23 Javascript
js封装可使用的构造函数继承用法分析
2015/01/28 Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
2015/12/31 Javascript
使用RequireJS库加载JavaScript模块的实例教程
2016/06/06 Javascript
AngularJS使用ng-options指令实现下拉框
2016/08/23 Javascript
vue.js初学入门教程(2)
2016/11/07 Javascript
jQuery插件Echarts实现的渐变色柱状图
2017/03/23 jQuery
jQuery实现字体颜色渐变效果的方法
2017/03/29 jQuery
详解Vue Elementui中的Tag与页面其它元素相互交互的两三事
2018/09/25 Javascript
Vue 中 filter 与 computed 的区别与用法解析
2019/11/21 Javascript
如何在vue 中使用柱状图 并自修改配置
2021/01/21 Vue.js
Python之reload流程实例代码解析
2018/01/29 Python
谈谈python中GUI的选择
2018/03/01 Python
基于python list对象中嵌套元组使用sort时的排序方法
2018/04/18 Python
利用Python将每日一句定时推送至微信的实现方法
2018/08/13 Python
Python实战购物车项目的实现参考
2019/02/20 Python
Python  Django 母版和继承解析
2019/08/09 Python
python修改linux中文件(文件夹)的权限属性操作
2020/03/05 Python
简单了解Python变量作用域正确使用方法
2020/06/12 Python
安装python依赖包psycopg2来调用postgresql的操作
2021/01/01 Python
canvas基础之图形验证码的示例
2018/01/02 HTML / CSS
简约控的天堂:The Undone
2016/12/21 全球购物
英国户外玩具儿童游乐设备网站:TP Toys(蹦床、攀爬框架、秋千、滑梯和游戏屋)
2018/04/09 全球购物
蔻驰西班牙官网:COACH西班牙
2019/01/16 全球购物
Seavenger官网:潜水服、浮潜、靴子和袜子
2020/03/05 全球购物
linux面试相关问题
2013/04/28 面试题
2014年道德讲堂实施方案
2014/03/05 职场文书
2019公司管理制度
2019/04/19 职场文书
详解前端任务构建利器Gulp.js使用指南
2021/04/30 Javascript
Nginx配置根据url参数重定向
2022/04/11 Servers