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 相关文章推荐
JS获取scrollHeight问题想到的标准问题
May 27 Javascript
JQuery 学习笔记 选择器之三
Jul 23 Javascript
JavaScript栏目列表隐藏/显示简单实现
Apr 03 Javascript
Jquery api 速查表分享
Jan 12 Javascript
javascript DIV实现跟随鼠标移动
Mar 19 Javascript
JavaScript绑定事件监听函数的通用方法
May 14 Javascript
javascript使用闭包模拟对象的私有属性和方法
Oct 05 Javascript
Angular2中Bootstrap界面库ng-bootstrap详解
Oct 18 Javascript
详解在Vue中通过自定义指令获取dom元素
Mar 04 Javascript
canvas实现爱心和彩虹雨效果
Mar 09 Javascript
Angular.js实现动态加载组件详解
May 28 Javascript
利用jquery去掉时光轴头尾部线条的方法实例
Jun 16 jQuery
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
php桌面中心(四) 数据显示
2007/03/11 PHP
两个强悍的php 图像处理类1
2009/06/15 PHP
PHPwind整合最土系统用户同步登录实现方法
2010/12/08 PHP
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
2013/06/29 PHP
php 下载保存文件保存到本地的两种实现方法
2013/08/12 PHP
PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
2016/01/07 PHP
深入理解php printf() 输出格式化的字符串
2016/05/23 PHP
php基于openssl的rsa加密解密示例
2016/07/11 PHP
Javascript 陷阱 window全局对象
2008/11/26 Javascript
jQuery + Flex 通过拖拽方式动态改变图片的代码
2011/08/03 Javascript
javascript实现yield的方法
2013/11/06 Javascript
Nodejs爬虫进阶教程之异步并发控制
2016/02/15 NodeJs
原生js实现查询天气小应用
2016/12/09 Javascript
详解jQuery简单的表单应用
2016/12/16 Javascript
jquery UI Datepicker时间控件冲突问题解决
2016/12/16 Javascript
nodejs中向HTTP响应传送进程的输出
2017/03/19 NodeJs
JavaScript中document.referrer的用法详解
2017/07/04 Javascript
React学习笔记之列表渲染示例详解
2017/08/22 Javascript
详解React之key的使用和实践
2018/09/29 Javascript
原生js实现Flappy Bird小游戏
2018/12/24 Javascript
js中switch语句的学习笔记
2020/03/25 Javascript
[54:54]Newbee vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
python 生成不重复的随机数的代码
2011/05/15 Python
wxpython学习笔记(推荐查看)
2014/06/09 Python
python获取指定时间差的时间实例详解
2017/04/11 Python
pyqt5简介及安装方法介绍
2018/01/31 Python
对python自动生成接口测试的示例讲解
2018/11/30 Python
python 实现list或string按指定分段
2019/12/25 Python
Python有参函数使用代码实例
2020/01/06 Python
python实现双人五子棋(终端版)
2020/12/30 Python
利用CSS3实现平移动画效果示例代码
2016/10/12 HTML / CSS
慕尼黑山地运动、户外服装和体育用品专家:Sporthaus Schuster
2019/08/27 全球购物
介绍一下.net和Java的特点和区别
2012/09/26 面试题
服务员岗位职责
2015/02/03 职场文书
《女娲补天》教学反思
2016/02/20 职场文书
Python 处理表格进行成绩排序的操作代码
2021/07/26 Python