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实现的非常实用的鼠标悬停特效演示
Nov 05 HTML / CSS
CSS3弹性盒模型开发笔记(二)
Apr 26 HTML / CSS
详解CSS3实现响应式手风琴效果
Jun 10 HTML / CSS
详解HTML5 canvas绘图基本使用方法
Jan 29 HTML / CSS
HTML5是否真的可以取代Flash
Feb 10 HTML / CSS
HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)
Jul 15 HTML / CSS
HTML5中判断用户是否正在浏览页面的方法
May 03 HTML / CSS
canvas需要在标签里直接定义宽高
Dec 17 HTML / CSS
图片上传插件ImgUploadJS:用HTML5 File API 实现截图粘贴上传、拖拽上传
Jan 20 HTML / CSS
HTML5拖拉上传文件的简单实例
Jan 11 HTML / CSS
html5 移动端视频video的android兼容(去除播放控件、全屏)
Mar 26 HTML / CSS
VW、VH适配移动端的解决方案与常见问题
May 21 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
颠覆常识!无色透明的咖啡诞生了(中日双语)
2021/03/03 咖啡文化
Body是什么,该怎么喝出咖啡里的口感
2021/03/03 咖啡文化
探讨如何使用SimpleXML函数来加载和解析XML文档
2013/06/07 PHP
PHP屏蔽过滤指定关键字的方法
2014/11/03 PHP
在Windows系统下使用PHP生成Word文档的教程
2015/07/03 PHP
Zend Framework教程之Zend_Config_Ini用法分析
2016/03/23 PHP
PHP获取网站中各文章的第一张图片的代码示例
2016/05/20 PHP
PHP使用imagick扩展实现合并图像的方法
2017/04/25 PHP
Laravle eloquent 多对多模型关联实例详解
2017/11/22 PHP
PHP随机数函数rand()与mt_rand()的讲解
2019/03/25 PHP
Laravel5.7 数据库操作迁移的实现方法
2019/04/12 PHP
使用百度地图api实现根据地址查询经纬度
2014/12/11 Javascript
通过sails和阿里大于实现短信验证
2017/01/04 Javascript
jquery easyui dataGrid动态改变排序字段名的方法
2017/03/02 Javascript
dropload.js插件下拉刷新和上拉加载使用详解
2017/10/20 Javascript
使用vue-cli打包过程中的步骤以及问题的解决
2018/05/08 Javascript
解决vant-UI库修改样式无效的问题
2020/11/03 Javascript
Python里隐藏的“禅”
2014/06/16 Python
Python读取mp3中ID3信息的方法
2015/03/05 Python
Windows安装Python、pip、easy_install的方法
2017/03/05 Python
Python 自动化表单提交实例代码
2017/06/08 Python
使用python实现个性化词云的方法
2017/06/16 Python
python网络爬虫 Scrapy中selenium用法详解
2019/09/28 Python
django的模型类管理器——数据库操作的封装详解
2020/04/01 Python
离线状态下在jupyter notebook中使用plotly实例
2020/04/24 Python
Python实现动态循环输出文字功能
2020/05/07 Python
html5使用canvas画一条线
2014/12/15 HTML / CSS
Baby Tulai澳大利亚:美国婴儿背带品牌
2018/10/15 全球购物
什么是GWT的Module
2013/01/20 面试题
美术教师自我鉴定
2014/02/12 职场文书
生物技术专业求职信
2014/06/10 职场文书
2014年仓管员工作总结
2014/11/18 职场文书
2015年档案管理工作总结
2015/04/08 职场文书
撤诉申请怎么写
2015/05/19 职场文书
安全教育观后感
2015/06/17 职场文书
2016年公务员六五普法心得体会
2016/01/21 职场文书