简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

html5摇一摇代码优化包括DeviceMotionEvent等等

来源:易贤网   阅读:1057 次  日期:2015-01-29 16:30:43

温馨提示:易贤网小编为您整理了“html5摇一摇代码优化包括DeviceMotionEvent等等”,方便广大网友查阅!

首先对DeviceMotionEvent进行优化;

去除无用的代码,重新封装DeviceMotionEven

代码如下:

if(window.DeviceMotionEvent) {

var speed = 25;//定义一个数值

var x = y = z = lastX = lastY = lastZ = 0;//重置所有数值

window.addEventListener('devicemotion', function(){

var acceleration =event.accelerationIncludingGravity;//将传感值赋给acceleration

x = acceleration.x;

y = acceleration.y;

z = acceleration.z;

if(Math.abs(x-lastX) > speed || Math.abs(y-lastY) > speed ) {

// TODO:在此处可以实现摇一摇之后所要进行的数据逻辑操作

donghua();

}

lastX = x;

lastY = y;

lastZ = z;

}, false);

}

由于实际项目中有很多需求无法很好的实现,

比如:动画不执行完毕就不能继续执行DeviceMotionEvent事件;

所以做了进一步优化;

代码如下:

var f=1;

function donghua(){

//动画事件

$(".img").animate({left:'0',opacity:'1'},700,function(){f=1;});

});

if(window.DeviceMotionEvent) {

var speed = 25;//定义一个数值

var x = y = z = lastX = lastY = lastZ = 0;//重置所有数值

window.addEventListener('devicemotion', function(){

var acceleration =event.accelerationIncludingGravity;//将传感值赋给acceleration

x = acceleration.x;

y = acceleration.y;

z = acceleration.z;

if(Math.abs(x-lastX) > speed || Math.abs(y-lastY) > speed ) {

// TODO:在此处可以实现摇一摇之后所要进行的数据逻辑操作

if(f==1){

donghua();

f=0;

}

}

lastX = x;

lastY = y;

lastZ = z;

}, false);

}

现在就完美了

更多信息请查看IT技术专栏

更多信息请查看网页制作
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:html5 css3实例教程
下一篇:浅谈html5 响应式布局
易贤网手机网站地址:html5摇一摇代码优化包括DeviceMotionEvent等等
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!