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实现类似翻书效果的过渡动画的示例代码
Sep 06 HTML / CSS
CSS3 选择器 基本选择器介绍
Jan 21 HTML / CSS
Web页面中八种创建多列等高(等高列布局)的实现技术
Dec 24 HTML / CSS
css3背景图片透明叠加属性cross-fade简介及用法实例
Jan 08 HTML / CSS
使用css3制作登录表单的步骤
Apr 07 HTML / CSS
HTML5 canvas基本绘图之绘制曲线
Jun 27 HTML / CSS
Html5实现文件异步上传功能
May 19 HTML / CSS
HTML5给汉字加拼音收起展开组件的实现代码
Apr 08 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
May 14 HTML / CSS
recorder.js 基于Html5录音功能的实现
May 26 HTML / CSS
Html分层的box-shadow效果的示例代码
Mar 30 HTML / CSS
css3 文字断裂效果
Apr 22 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
改变Apache端口等配置修改方法
2008/06/05 PHP
php实现aes加密类分享
2014/02/16 PHP
CI框架中zip类应用示例
2014/06/17 PHP
设定php简写功能的方法
2019/11/28 PHP
javascript权威指南 学习笔记之javascript数据类型
2011/09/24 Javascript
JS中产生20位随机数以0-9为例也可以是a-z A-Z
2014/08/01 Javascript
javascript随机抽取0-100之间不重复的10个数
2016/02/25 Javascript
Javascript数组中push方法用法分析
2016/10/31 Javascript
JS中用EL表达式获取上下文参数值的方法
2018/03/28 Javascript
微信小程序之判断页面滚动方向的示例代码
2018/08/30 Javascript
angularjs请求数据的方法示例
2019/08/06 Javascript
非常实用的jQuery代码段集锦【检测浏览器、滚动、复制、淡入淡出等】
2019/08/08 jQuery
Nodejs 识别图片类型的方法
2019/08/15 NodeJs
JQuery 实现文件下载的常用方法分析
2019/10/29 jQuery
在vant 中使用cell组件 定义图标该图片和位置操作
2020/11/02 Javascript
python使用cookielib库示例分享
2014/03/03 Python
Python决策树分类算法学习
2017/12/22 Python
利用python对Excel中的特定数据提取并写入新表的方法
2018/06/14 Python
python简易实现任意位数的水仙花实例
2018/11/13 Python
详解Django模版中加载静态文件配置方法
2019/07/21 Python
Python实现图片批量加入水印代码实例
2019/11/30 Python
pytorch 实现模型不同层设置不同的学习率方式
2020/01/06 Python
Gucci法国官方网站:意大利奢侈品牌
2018/07/25 全球购物
印尼网上商店:Alfacart.com
2019/03/11 全球购物
初任培训自我鉴定
2013/10/07 职场文书
女大学生自我鉴定
2013/12/09 职场文书
2014小学植树节活动总结
2014/03/10 职场文书
护理专科毕业自荐信范文
2014/04/21 职场文书
创业融资计划书
2014/04/25 职场文书
技术经济专业求职信
2014/09/03 职场文书
银行委托书范本
2014/09/28 职场文书
部门2015年度工作总结
2015/04/29 职场文书
2016年乡镇综治宣传月活动总结
2016/03/16 职场文书
pytest进阶教程之fixture函数详解
2021/03/29 Python
python flask框架快速入门
2021/05/14 Python
使用CSS实现小三角边框原理解析
2021/11/07 HTML / CSS