html5在线设备信息查看,HTML5 device access 设备访问详解

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 (触屏事件)

touchstart

touchen

touchcancel 电话的接入或者弹出信息等比较高级的事件触发,一般做保存操作

touchmove

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(鼠标锁定)

锁住它!

// 简单示例,将鼠标锁定在 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();

}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值