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绘制出各种几何图形
Aug 17 HTML / CSS
CSS3教程(3):border-color网页边框色彩
Apr 02 HTML / CSS
用CSS3实现Win8风格的方格导航菜单效果
Apr 10 HTML / CSS
css3实现图片遮罩效果鼠标hover以后出现文字
Nov 05 HTML / CSS
css3和jquery实现自定义checkbox和radiobox组件
Apr 22 HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 HTML / CSS
CSS 说明横向进度条最后显示文字的实现代码
Nov 10 HTML / CSS
html5调用摄像头功能的实现代码
May 07 HTML / CSS
HTML5 3D衣服摇摆动画特效
Mar 17 HTML / CSS
使用phonegap获取位置信息的实现方法
Mar 31 HTML / CSS
从零实现一个自定义html5播放器的示例代码
Aug 01 HTML / CSS
将SVG图引入到HTML页面的实现
Sep 20 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面向对象全攻略 (二) 实例化对象 使用对象成员
2009/09/30 PHP
PHP 获取文件路径(灵活应用__FILE__)
2013/02/15 PHP
解析php函数method_exists()与is_callable()的区别
2013/06/21 PHP
在Linux系统下一键重新安装WordPress的脚本示例
2015/06/30 PHP
PHP 网站修改默认访问文件的nginx配置
2017/05/27 PHP
ThinkPHP框架中使用Memcached缓存数据的方法
2018/03/31 PHP
Yii框架实现对数据库的CURD操作示例
2019/09/03 PHP
PHP实现基本留言板功能原理与步骤详解
2020/03/26 PHP
js 获取服务器控件值的代码
2010/03/05 Javascript
js实现GridView单选效果自动设置交替行、选中行、鼠标移动行背景色
2010/05/27 Javascript
javascript 实现 秒杀,团购 倒计时展示的记录 分享
2013/07/12 Javascript
Javascript 按位取反运算符 (~)
2014/02/04 Javascript
JavaScript作用域链示例分享
2014/05/27 Javascript
JS数组的遍历方式for循环与for...in
2014/07/31 Javascript
jQuery获取页面及个元素高度、宽度的总结——超实用
2015/07/28 Javascript
drag-and-drop实现图片浏览器预览
2015/08/06 Javascript
jQuery实现图片轮播特效代码分享
2015/09/15 Javascript
javascript省市区三级联动下拉框菜单实例演示
2015/11/29 Javascript
Bootstrap实现圆角、圆形头像和响应式图片
2016/12/14 Javascript
收集前端面试题之url、href、src
2018/03/22 Javascript
Smartour 让网页导览变得更简单(推荐)
2019/07/19 Javascript
[03:07]DOTA2英雄基础教程 冰霜诅咒极寒幽魂
2013/12/06 DOTA
Python松散正则表达式用法分析
2016/04/29 Python
python3 requests中使用ip代理池随机生成ip的实例
2018/05/07 Python
Python中__slots__属性介绍与基本使用方法
2018/09/05 Python
python3注册全局热键的实现
2020/03/22 Python
Html5 video标签视频的最佳实践
2020/02/26 HTML / CSS
澳大利亚香水在线商店:City Perfume
2020/09/02 全球购物
编辑个人求职信范文
2013/09/21 职场文书
毕业生的求职信范文分享
2013/12/04 职场文书
打架检讨书300字
2014/02/02 职场文书
三月学雷锋月活动总结
2014/04/28 职场文书
四风问题班子对照检查材料
2014/09/27 职场文书
企业整改报告范文
2014/11/08 职场文书
MySQL sql_mode的使用详解
2021/05/08 MySQL
MySQL数据库Innodb 引擎实现mvcc锁
2022/05/06 MySQL