JS弹性运动实现方法分析


Posted in Javascript onDecember 15, 2016

本文实例分析了JS弹性运动实现方法。分享给大家供大家参考,具体如下:

描述:像弹簧一样左右弹动,最后缓慢停下来

一、加减速运动

1.加速运动

var iSpeed=0;
iSpeed++;

速度越来越快,最后冲出去

2.减速运动

var iSpeed=20;
iSpeed--;

速度越来越慢,降到0后开始变负值往反方向运动

二、弹性运动

1.在目标点左边,加速;目标点右边,减速,如

if(div1.offsetLeft<300){
 iSpeed=iSpeed+1;  //等同iSpeed++;
}
else{
 iSpeed=iSpeed-1;
}

这是最简单的弹性运动,缺陷:加速度恒定(应该根据松紧带而变)

if(div1.offsetLeft<300){
 iSpeed=iSpeed+(300-div1.offsetLeft)/50; 
}
else{
 iSpeed=iSpeed-(div1.offsetLeft-300)/50;
}
iSpeed=iSpeed+(300-div1.offsetLeft)/50; ==>iSpeed=iSpeed+300/50-div1.offsetLeft/50;
iSpeed=iSpeed-(div1.offsetLeft-300)/50; ==>iSpeed=iSpeed-div1.offsetLeft/50+300/50;

这两个完全一样 所以不需要if/else

iSpeed+=(300-div1.offsetLeft)/50; 
div1.style.left=div1.offsetLeft+iSpeed+'px';

缺陷2:不会停下来(缺少摩擦力)

iSpeed+=(300-div1.offsetLeft)/50; 
iSpeed*=0.95; //乘一个小数,越来越小
div1.style.left=div1.offsetLeft+iSpeed+'px';

三、带摩擦力的弹性运动

比较好的组合

iSpeed+=(300-div1.offsetLeft)/5; 
iSpeed*=0.7;

注:var iSpeed=0;要放在定时器外面,不然每次都从0开始,加啊乘啊就没用了

四、整合好的弹性运动框架

var iSpeed=0;
var left=0;
function startMove(obj,iTarget){
 clearInterval(obj.timer);
 obj.timer=setInterval(function(){
  iSpeed+=(iTarget-obj.offsetLeft)/5;
  iSpeed*=0.7;  //计算出来的速度是一个小数,如果给它取整,会一直左右移动
  left+=iSpeed;  //把速度存在变量里,变量是可以有小数的
  if(Math.abs(iSpeed)<1 && Math.abs(left-iTarget)<1){ //因为iSpeed和left都是小数,所以永远达不到0和目标点,只能无限接近
   clearInterval(obj.timer);  //虽然速度最后接近于0,看似运动停止了,但定时器还一直开着,所以当速度=0并且到达目标点,关掉(只是速度=0关掉,运动到最右边准备回来那一刹那,速度=0,同理只是到达目标点关掉,一开始往右运动经过中间时会达到目标点,所以必须两者同时满足)
   obj.style.left=iTarget+'px'; //小数无法完全贴合,所以最后直接让他等于目标点,一般人肉眼看不出来
  }
  else{
   obj.style.left=left+'px';  //style.left只能是一个整数,所以每次会把小数抹掉,误差是累计的,最终累加起来就会有1-2像素,用obj.offsetLeft+iSpeed就会无法完全贴合
  }
 },30);
};

五、弹性运动不适用的地方

样式会过界的

比如高度,先变大后变小,如果物体本身高度很小,可能会变成负值,就不对了

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
使用Promise解决多层异步调用的简单学习心得
May 17 Javascript
EasyUI的doCellTip实现鼠标放到单元格上提示单元格内容
Aug 24 Javascript
react router4+redux实现路由权限控制的方法
May 03 Javascript
深入了解javascript 数组的sort方法
Jun 01 Javascript
JS实现全屏预览F11功能的示例代码
Jul 23 Javascript
vue2.0页面前进刷新回退不刷新的实现方法
Jul 31 Javascript
angular4中*ngFor不能对返回来的对象进行循环的解决方法
Sep 12 Javascript
解决微信小程序调用moveToLocation失效问题【超简单】
Apr 12 Javascript
详解小程序input框失焦事件在提交事件前的处理
May 05 Javascript
vue悬浮可拖拽悬浮按钮的实例代码
Aug 20 Javascript
vue2.0 watch里面的 deep和immediate用法说明
Oct 30 Javascript
Java 生成随机字符的示例代码
Jan 13 Javascript
JS经典正则表达式笔试题汇总
Dec 15 #Javascript
javascript中闭包概念与用法深入理解
Dec 15 #Javascript
javascript读取文本节点方法小结
Dec 15 #Javascript
EditPlus中的正则表达式 实战(4)
Dec 15 #Javascript
jQuery validate插件功能与用法详解
Dec 15 #Javascript
EditPlus 正则表达式 实战(3)
Dec 15 #Javascript
js实现点击每个li节点,都弹出其文本值及修改
Dec 15 #Javascript
You might like
手把手教你使用DedeCms V3的在线采集图文教程
2007/04/03 PHP
php mysql操作mysql_connect连接数据库实例详解
2016/12/26 PHP
利用PHP判断是否是连乘数字串的方法示例
2017/07/03 PHP
javascript forEach通用循环遍历方法
2010/10/11 Javascript
利用webqq协议使用python登录qq发消息源码参考
2013/04/08 Javascript
uploadify在Firefox下丢失session问题的解决方法
2013/08/07 Javascript
JavaScript和JQuery的鼠标mouse事件冒泡处理
2015/06/19 Javascript
jquery判断对象是否为空并遍历对象的简单实例
2016/07/26 Javascript
js实现省份下拉菜单效果
2017/02/15 Javascript
vue中如何实现变量和字符串拼接
2017/06/19 Javascript
JavaScript输入分钟、秒倒计时技巧总结(附代码)
2017/08/17 Javascript
Vue from-validate 表单验证的示例代码
2017/09/26 Javascript
五分钟搞懂Vuex实用知识(小结)
2019/08/12 Javascript
使用layui监听器监听select下拉框,事件绑定不成功的解决方法
2019/09/28 Javascript
JavaScript实现PC端四格密码输入框功能
2020/02/19 Javascript
openlayers实现地图弹窗
2020/09/25 Javascript
nodejs处理tcp连接的核心流程
2021/02/26 NodeJs
[00:15]TI9地铁玩家打卡
2019/08/11 DOTA
Python实现邮件的批量发送的示例代码
2018/01/23 Python
python实现关键词提取的示例讲解
2018/04/28 Python
Python实现重建二叉树的三种方法详解
2018/06/23 Python
Python 私有化操作实例分析
2019/11/21 Python
Python 剪绳子的多种思路实现(动态规划和贪心)
2020/02/24 Python
Python如何生成xml文件
2020/06/04 Python
利用PyTorch实现VGG16教程
2020/06/24 Python
canvas烟花特效锦集
2018/01/17 HTML / CSS
基于HTML5 的人脸识别活体认证的实现方法
2016/06/22 HTML / CSS
创意爱尔兰礼物:Creative Irish Gifts
2020/01/29 全球购物
数控技术专科生自我评价
2014/01/08 职场文书
教师简历自我评价
2014/02/03 职场文书
培训班主持词
2014/03/28 职场文书
金融系应届毕业生求职信
2014/05/26 职场文书
美食节策划方案
2014/05/26 职场文书
工会优秀工作者事迹
2014/08/17 职场文书
周年庆典答谢词
2015/01/20 职场文书
浅谈Python实现opencv之图片色素的数值运算和逻辑运算
2021/06/23 Python