腾讯技术总结!超实用的HTML 5接口全方位测试总结文

目录:

一、让音乐随心而动 – 音频处理 Web audio API
二、捕捉用户摄像头 – 媒体流 Media Capture
三、你是逗逼? – 语音识别 Web Speech API
四、让我尽情呵护你 – 设备电量 Battery API
五、获取用户位置 – 地理位置 Geolocation API
六、把用户捧在手心 – 环境光 Ambient Light API

HTML5时代 II

七、陀螺仪 Deviceorientation
八、Websocket
九、NFC
十、震动 - Vibration API
十一、网络环境 Connection API

那么,各位看官起来摇一摇,活动活动筋骨,热热身。。。(PS:为什么我会联想到喝前摇一摇,吃(fan)货(tong)天赋?)。

DeviceMotion:

简介

装逼说法:设备移动传感器。

通俗说法:检测设备运动及运动状况,可以通过该接口获取到设备运动的方向和速度等相关信息

核心代码

这货其实就是一个事件,简单地通过事件监听就可以获取到相关的设备运动信息

window.addEventListener("devicemotion", function(event) {}, false);

最简单的设备运动,我们基本上可以认为是前后、左右、上下这么6个方向上的,装换成3D环境中来讲的话,就是在x、y和z轴上运动,这三个轴上的信息,都包含在了event对象中。我们可以通过这种方式获得

window.addEventListener("devicemotion", function(event) {
    var eventacceleration = event.acceleration;
    document.querySelector('#devicemotion').innerHTML = "acceleration:<br>"+
    eventacceleration.x+"<br>"+
    eventacceleration.y+"<br>"+
    eventacceleration.z
}, false);

想看效果的话,这个时候就可以掏出手机,扫描下面的这个二维码

1da7a7e95c64fcc2aa054a0ea2894ad51435222999.png

http://aaaa.sinaapp.com/deviceDemo/acceleration.html

不要问我为什么手机躺在桌面上,上面的数字还在不停地抖动,咱们文化人应该都知道什么叫相对静止。上面的三个不断变化的数字,就是你设备的运动数据了。如果你在惊讶为什么我都已经移动过手机,为什么上面的数字貌似也没什么大的变化~那么我会告诉你说:有本事你的眼睛跟着你的手机一样快速移动啊,运动过程中你就能发现这个值的变化了。没有这个本事吧!~自己尝试修改下那个demo。把运动中值的变化都记录下来看看。。。(PS:反正我不弄。)

还有一种比较理想的设备运动方式就是不产生位移,只是快速的旋转手机。这个旋转的信息同样也被反馈在了event对象中

window.addEventListener("devicemotion", function(event) {
    eventrotationRate = event.rotationRate;
    document.querySelector('#devicemotion').innerHTML = 'rotationRate:<br>'+
    eventrotationRate.alpha+'<br>'+
    eventrotationRate.beta+"<br>"+
    eventrotationRate.gamma
}, false);

同样的,下面的二维码也就是为了说明上面的这段代码,alpha、beta以及gamma就是旋转设备时的加速度。

1435214168_73_w177_h176.png

http://aaaa.sinaapp.com/deviceDemo/rotationRate.html

可能有的童鞋会觉得~有了这个旋转应该就能实现一些手机左右旋转产生视差的效果了,其实是不行的~因为这货和上面的一样,设备停止后,我们可以认为他的值归0~。真正想要实现手机旋转视差,我们需要用到的就是另外一个event的属性accelerationIncludingGravity。从字面上理解这个属性就是重力加速度。

window.addEventListener("devicemotion", function(event) {
    eventaccelerationIncludingGravity = event.accelerationIncludingGravity;
    document.querySelector('#devicemotion').innerHTML = "accelerationIncludingGravity:<br>"+
    eventaccelerationIncludingGravity.x+"<br>"+
    eventaccelerationIncludingGravity.y+"<br>"+
    eventaccelerationIncludingGravity.z
}, false);

下面的这个二维码应该可以帮助到你来理解这个属性

1435215045_85_w176_h175.png

http://aaaa.sinaapp.com/deviceDemo/accelerationIncludingGravity.html

至此,devicemotion这个事件就差不多了,可见,这货功能还是蛮强大的,如果你有一定的的数学和物理学的基础,那么,轻巧几行代码,实现个高尔夫球游戏玩玩,立马给人感觉高大上了。看谁还敢说程序员没有妹纸。。

通过这个devicemotion吧,还能实现些什么就各自去脑洞大开吧,比如说玩烂了的摇一摇,设备倾斜视差,重力感应类的小游戏。我们貌似还能通过这个属性,去做个基于HTML5的计步器玩玩?

其实,devicemotion还有一个好基友,这里也推荐给大家看一眼吧:

deviceorientation

这个事件和devicemotion的使用方法基本一致

window.addEventListener("deviceorientation", function(event) {
    document.querySelector('#deviceorientation').innerHTML = 
    event.alpha+'<br>'+
    event.beta+"<br>"+
    event.gamma+'<br>';
}, false);

这里的alpha、beta和gamma所指的就是手机设备的各种倾斜角度,如果你不能理解哪个是alpha、哪个是beta和gamma,那么你还是自己掏出手机,扫描下这个二维码。自己感受吧。(PS:我是真不爱画图,可能辛苦半天画出来的图,也有童鞋没明白)。

1435216564_27_w175_h176.png

有前面devicemotion好基友的帮忙,似乎能做的东西又可以更多一点了。咱们前面貌似提及过&ldquo;喝前摇一摇&rdquo;。摇完之后,自然是要打开瓶盖痛饮一番了,结合旋转加速度,我们是不是可以尝试些一个拧瓶盖比赛的游戏了?怕长胖?要不,拧个螺丝钉也行。

说到游戏,特别上面还提及到了比赛。那么实时通信必然是不可少了。以往为了达到实时通信,也有不少的方法:轮询、长轮询、长连接、flash等各种方式。这些方法各自的弊端也是比较明显的,这里就不逐个展开细说了。这里主要给大家提交到的就是下面这货:

webSocket

简介

浏览器与服务器全双工通信(full-duplex)。

核心代码

var ws = new WebSocket('ws://127.0.0.1:8808/');//建立服务器连接ws.onopen = function(){
	systemInfo.innerHTML = '<p>和websocket服务器连接成功</p>';
}//接收到服务器返回的数据ws.onmessage = function(e){
	systemInfo.innerHTML += '<p>'+e.data+'</p>';
}//断开服务器连接ws.onclose = function(){
	systemInfo.innerHTML += '<p>WebSocket服务器连接关闭</p>';
}//ws发生错误ws.onerror = function(e){
	console.log(e);
	systemInfo.innerHTML += '<p>WebSocket发生错误</p>';
}

对于webSocket,有兴趣了解更多的朋友直接转移到我的另外一篇文章《移动前端系列&mdash;&mdash;websocket实时互动小游戏

websocket的数据发送和接收,其实也都是依赖于网络的,webSocket自己也对网络状况这块通过事件的方式做出了相应,比如说上面的onclose、onerror。但是就目前来说,很多页面上可能并没有用webSocket,这么一来,对于网络何时断开了,可能捕获就没那么容易了,更何况,webSocket在网络信息这块,可能还并不是那么的完美。比如说,我想获取当前连接的网络类型。

网络类型这块我们暂且先放半分钟,我们先看一下如何动态判断网络连接是否断开,所指动态判断网络连接断开,指的是,页面不刷新的情况下,实时地知道当前网络是否可用。以往,我们想得到这种数据,我们一般的实现方法是通过轮询去访问服务器上的一个文件,如果文件正常响应,说明网络是通的;如果文件不响应,那么就认为网络是不通的。这种方式感觉挺靠谱,但是可以想象,轮询请求,会耗费多少服务器资源。下面这货出来之后,以往的这种方式就可以进博物馆了。

onLine

简介:

判断当前网络是否有效

用法也是相当地简单:

if (navigator.onLine) {
    alert('online');
} else {
    alert('offline');
}

我们可以通过事件的监听,去实时获取到网络状态的变化

window.addEventListener('offline', function(e) {alert('offline');})
window.addEventListener('online', function(e) {alert('online');})

这样以来,实时获取网络状态俨然和服务器已经没有半毛钱关系了。

好了,半分钟时间已到,我们回头来看看我前面说的那个问题,获取网络类型,所指网络类型,值的是2G、3G、4G、蓝牙等等。其实,我个人觉得,这个网络类型完全可以放到online那个事件对象里面去。但是很遗憾,至少目前没放,暂不清楚是基于什么考虑的。我们目前想要获取这个网络类型,需要通过另外一个属性

connection

connection也是navigator的一个属性,他包含了一些当前连接的基本信息,其中connection.type值的就是当前的网络类型。其值包含了一下几个:

bluetooth  cellular  ethernet  none  wifi  wimax  wimax  unknown

当网络类型发生变化时,同样的也是可以通过事件监听的方式来实时获取到网络类型。代码实现如下:

var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection;
var type = connection.type;
function updateConnectionStatus() {
    alert("网络由 " + type + " 变化为 " + connection.type);
}
//监听网络类型发生变化
connection.addEventListener('typechange', updateConnectionStatus);

有了这些,我们就可以根据不同的网络环境去加载不同的资源去最大程度上丰富用户体验。

我们上面所提及到的,很多都是和网络(互联网)相关,但是有的时候,我们想在没有网络的环境下,也想传送一些数据该怎么办。这种情况可能在不久的将来,在我们的网页里面也能实现了,这个就是接下来的NFC(为什么我会想到KFC)

NFC

简介:

近场通信/近距离无线通信技术。

其实说实在的,这个功能我并没有在我的页面里面调试出来。主要的一个原因是~这货目前只是在firefox os系统里面的firefox浏览器里面实现了,手头上没这设备。不过从他们官网的例子中,我大概地可以感受得到这货的好用,有兴趣的同学自行前往学习:https://developer.mozilla.org/en-US/docs/Web/API/NFC_API/Using_the_NFC_API

当然了,如果你手头上刚好有两部带有NFC芯片的三星手机,可以试试。解锁屏幕,将两部三星手机后壳贴近,听见&ldquo;滴&rdquo;的一声后,注意看屏幕上的变化。然后点击屏幕,再去看看另外一个手机上发生了什么。

清脆&ldquo;滴&rdquo;的一声,多好的用户行为反馈,忍不住还多尝试了几次,忽然就感觉这种靠声音的提醒,似乎忽略了一些失聪的人群。如果加上点震动的话~似乎就完美了。不是于是乎,咱们本片的最后一个话题引出。

vibrate

简介:

设备震动

核心代码:

navigator.vibrate = navigator.vibrate ||  navigator.webkitVibrate || 
                                navigator.mozVibrate || navigator.msVibrate;
navigator.vibrate(value);
navigator.vibrate(0);

vibrate的参数为震动的时间,

如果值为0,说明停止震动

值为一个数组的话,奇数项表示的是震动时间,偶数项表示的为间隔时间。

比如:vibrate(1000,1000,2000)  就是表示震动1秒之后暂停1秒,再震动2秒

有兴趣的,扫下这个二维码可体验

1435222467_54_w175_h174111111111.png

http://1.aaaa.sinaapp.com/deviceDemo/Vibration.html

一口气说了这么一堆,其实后面的这几个点,都还在标准化的路上,不同机型/平台支持不太一致,在实际项目中使用还是要注意点区别对待的~你们先回味着,我一个人先伤一会儿心去。腾讯技术总结!超实用的HTML 5接口全方位测试总结文

转载于:https://my.oschina.net/ppmeng/blog/789634

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
腾讯X5内核是一款支持多进程、支持硬件加速、支持自定义内核扩展的WebView内核。在Android开发中,使用腾讯X5内核可以提高WebView的性能和稳定性,下面是一些优化和实践总结: 1. 引入腾讯X5内核 引入腾讯X5内核需要在项目中添加相应的依赖库,然后在代码中进行初始化和使用。具体步骤可以参考腾讯官方档。 2. 启用硬件加速 在使用腾讯X5内核时,可以启用硬件加速来提高WebView的渲染速度。具体可以通过设置WebView的LayerType属性来实现,例如: ``` webView.setLayerType(View.LAYER_TYPE_HARDWARE, null); ``` 3. 使用预加载 预加载可以在用户点击链接之前就开始加载下一页的内容,以提高用户体验和减少页面加载时间。腾讯X5内核提供了预加载功能,可以通过设置WebView的预加载模式来实现,例如: ``` webView.getX5WebViewExtension().setPageCacheCapacity(5); // 设置最大缓存页面数为5 webView.getX5WebViewExtension().setPreload(true); // 开启预加载模式 ``` 4. 优化JSBridge通信 JSBridge是一种用于WebView和Native代码之间通信的技术,但是在使用过程中容易出现性能问题。为了优化JSBridge通信,可以使用腾讯X5内核提供的基于V8引擎的JSBridge,它可以提高通信效率和稳定性。 5. 避免WebView内存泄漏 在使用WebView时,需要注意避免内存泄漏问题。具体可以通过以下方式来避免: - 及时释放WebView对象 - 使用静态内部类或弱引用来持有WebView对象 - 在Activity的onDestroy()方法中调用WebView的destroy()方法 总之,腾讯X5内核是一款非常强大的WebView内核,可以帮助我们优化WebView的性能和稳定性。在使用中,需要注意以上几点优化和实践。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值