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 相关文章推荐
javascript的字符串按引用复制和传递,按值来比较介绍与应用
Dec 28 Javascript
Jquery Uploadify多文件上传带进度条且传递自己的参数
Aug 28 Javascript
浅析offsetLeft,Left,clientLeft之间的区别
Nov 30 Javascript
js比较日期大小的方法
May 12 Javascript
javascript DIV实现跟随鼠标移动
Mar 19 Javascript
AngularJS ng-template寄宿方式用法分析
Nov 07 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
Nov 21 Javascript
微信小程序Redux绑定实例详解
Jun 07 Javascript
vue组件的写法汇总
Apr 12 Javascript
Vue ElementUi同时校验多个表单(巧用new promise)
Jun 06 Javascript
Vue加载json文件的方法简单示例
Jan 28 Javascript
wepy--用vantUI 实现上弹列表并选择相应的值操作
Nov 03 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
DC动画电影《黑暗正义联盟》曝预告 5月5日上线数字平台
2020/04/09 欧美动漫
使用无限生命期Session的方法
2006/10/09 PHP
浅析ThinkPHP中的pathinfo模式和URL重写
2014/01/06 PHP
php实现监控varnish缓存服务器的状态
2014/12/30 PHP
CI框架中site_url()和base_url()的区别
2015/01/07 PHP
javascript字典探测用户名工具
2006/10/05 Javascript
动态载入/删除/更新外部 JavaScript/Css 文件的代码
2010/07/03 Javascript
JQuery实现简单时尚快捷的气泡提示插件
2012/12/20 Javascript
关于jQuery对象数据缓存Cache原理以及jQuery.data详解
2013/04/07 Javascript
js实现的切换面板实例代码
2013/06/17 Javascript
页面定时刷新(1秒刷新一次)
2013/11/22 Javascript
JS计算网页停留时间代码
2014/04/28 Javascript
nodejs npm包管理的配置方法及常用命令介绍
2014/06/05 NodeJs
JS键盘版计算器的制作方法
2016/12/03 Javascript
微信小程序 switch组件详解及简单实例
2017/01/10 Javascript
js实现登录框鼠标拖拽效果
2017/03/09 Javascript
nodejs构建本地web测试服务器 如何解决访问静态资源问题
2017/07/14 NodeJs
基于Vue实例生命周期(全面解析)
2017/08/16 Javascript
微信小程序模板和模块化用法实例分析
2017/11/28 Javascript
JavaScript实现快速排序的方法分析
2018/01/10 Javascript
vue使用pdfjs显示PDF可复制的实现方法
2018/12/14 Javascript
python使用xmlrpc实例讲解
2013/12/17 Python
Python中import导入上一级目录模块及循环import问题的解决
2016/06/04 Python
django1.8使用表单上传文件的实现方法
2016/11/04 Python
python实现维吉尼亚算法
2019/03/20 Python
python中的split()函数和os.path.split()函数使用详解
2019/12/21 Python
Python使用socketServer包搭建简易服务器过程详解
2020/06/12 Python
美国诺德斯特龙百货官网:Nordstrom
2016/08/23 全球购物
Sephora丝芙兰澳洲官方网站:国际知名化妆品购物
2016/10/27 全球购物
加拿大领先的时尚和体育零售商:Sporting Life
2019/12/15 全球购物
视光学毕业生自荐书范文
2014/02/13 职场文书
《小蝌蚪找妈妈》教学反思
2014/02/21 职场文书
金融管理毕业生求职信
2014/03/03 职场文书
校庆口号
2014/06/20 职场文书
刘公岛导游词
2015/02/05 职场文书
微软PC Health Check电脑健康状况检查应用下载(Win11配置检测工具)
2021/06/26 数码科技