这篇文章主要介绍了JS实现匀加速与匀减速运动的方法,涉及javascript结合时间函数与数学运算动态操作页面元素样式的相关实现技巧,需要的朋友可以参考下

本文实例讲述了JS实现匀加速与匀减速运动的方法。分享给大家供大家参考,具体如下:

/*

* 动画帧函数

*

* */

var requestFrame=function(){

var prefixList=['webkit','moz','ms'];

var func;

for(var i=0;i

func=window[prefixList[i]+"RequestAnimationFrame"];

if(func){

return function(callback){

func(callback);

}

}

}

return function(callback){

setTimeout(callback,67);

}

}();

/*

* 匀加速运动

*

* */

function animate_easeIn(element,from,to,duration,callback){

var time=+new Date;

var distance=to-from;

var a=2*distance/(duration*duration); //加速度a=2x/t^2(包含方向)

var func=function(){

var time2,offsetDis,durTime;

time2=+new Date;

durTime=time2-time; //运动的时间间隔

offsetDis=Math.ceil(a*durTime*durTime/2);//X=a*t^2/2

if(duration

element.css('left',to+'px');

callback();

}else{

element.css('left',from+offsetDis+'px');

requestFrame(func);

}

}

func();

}

/*

* 匀减速运动

*

* */

function animate_easeOut(element,from,to,duration,callback){

var time=+new Date;

var distance=Math.abs(to-from);

var a=2*distance/(duration*duration); //x=a*t^2/2 求出加速度

var v0=Math.sqrt(distance*2*a); // 根据公式:2as=v^2求出初速度

var func=function(){

var time2,offsetDis,durTime,pos;

time2=+new Date;

durTime=time2-time;

offsetDis=Math.ceil(v0*durTime-a*durTime*durTime/2); //根据s=v0*t+1/2*a*t^2求出位移x

if(duration

element.css('left',to+'px');

callback();

}else{

pos=from>to? from-offsetDis : from+offsetDis;

element.css('left',pos+'px');

requestFrame(func);

}

}

func();

}

php 加减速 操作,JS实现匀加速与匀减速运动的代码分享相关推荐

  1. java模拟加速匀速减速_JS实现匀加速与匀减速运动的方法示例

    本文实例讲述了JS实现匀加速与匀减速运动的方法.分享给大家供大家参考,具体如下: /* * 动画帧函数 * * */ var requestFrame=function(){ var prefixLi ...

  2. html轮播带缩略图,js带缩略图的图片轮播效果代码分享

    本文实例讲述了js带缩略图的图片轮播效果.分享给大家供大家参考.具体如下: 这是一款基于javaScript实现带缩略图的图片轮播特效代码,实现过程很简单. 运行效果图:--------------- ...

  3. php 加减速 操作,手动挡减挡减速正确方法 加挡先加速减挡先减速

    手动挡的汽车应该怎么开呢?很多人不知道手动挡减速正确方法,所以在开手动挡车的时候手忙脚乱的.其实,在加挡前"轰"油门把车速先提起来,在减挡前"收"油门把车速先降 ...

  4. C语言步进电机自动加减速,步进电机正反转和加速减速c源程序

    这是一个群里朋友发给我的步进电机实现正转反转和加速减速的单片机c语言源程序,这里给大家共享下,有需要的朋友直接复制到keil里编译就可以了,程序已测试成功. /******************** ...

  5. js的匀加速,匀减速运动

    /*          * 动画帧函数          * * */ var requestFrame=function(){             var prefixList=['webkit ...

  6. html省市区选择器代码,js实现一个省市区三级联动选择框代码分享

    运行效果: ================================================= 部分代码: ====================================== ...

  7. vue 怎么样不重复往数组里插入数据_Vue.js在数组中插入重复数据的实现代码分享...

    1.在默认的情况下,Vue.js默认不支持往数组中加入重复的数据.可以使用track-by="$index"来实现. 2.不使用track-by="$index" ...

  8. js获取传统节假日_js判断节假日的代码分享

    js判断节假日实例代码 效果展示: /************************************************************* * 判断某天是不是工作日 * * @ ...

  9. html图片轮播代码渐隐,js淡入淡出的图片轮播效果代码分享

    本文实例讲述了淡入淡出的js图片轮播效果代码.分享给大家供大家参考.具体如下: 运行效果图:----------------------查看效果----------------------- 小提示: ...

最新文章

  1. 深度学习中的随机梯度下降(SGD)简介
  2. Servlet防止页面被客户端缓存
  3. 理解Kubernetes(2): 应用的各种访问方式
  4. activiti根据当前节点获取下一个节点信息
  5. VMware vCenter Converter Standalone 5.0的安装
  6. debian安装ibus中文输入法
  7. 组态软件与PLC远程控制的配置
  8. 【听课笔记】复旦大学遗传学_03基因与基因突变
  9. 手机打印文件怎么打印出来,如何用手机打印文件
  10. H3C忘记密码,优盘重置
  11. mysql InnoDB存储引擎的介绍
  12. 《神经科学:探索脑》学习笔记(第19章 脑的节律)
  13. redis HyperLogLog原理
  14. redis:redis介绍和安装、普通连接和连接池、redis 5大数据类型之字符串、Hash、列表、其他操作(通用)、管道、django使用redis、接口缓存
  15. C++ 7z解压缩编译及使用
  16. 计算机应用实训室建设方案,计算机应用实训基地建设方案.doc
  17. 【PMSM】一. 经典电流环、速度环设计(上)
  18. SOLIDWORKS实用技巧:弹簧扣特征
  19. php 个人账户转账,支付宝单笔转账到支付宝个人账户接口 ( PHP 版 )
  20. 新民航安保标准十一起实施 机场安防智慧升级

热门文章

  1. 什么是大票零担?ZETA如何实现大票零担货物追踪可视化?
  2. USACO 木瓜的丛林
  3. 数据结构---模式匹配算法
  4. Kali2.0关于flash的简单安装
  5. IT运维管理指什么?如何建立有效的IT运维管理系统?
  6. 安卓开发基础入门系列教程
  7. cv2.rectangle不会修改原图像
  8. 【Electron-vue】构建桌面应用(23)- Error: spawn EACCESS
  9. 一步一图,AMD Ryzen虚拟机安装Mac OS 10.14.6,看完保证能成功!
  10. 第7章用户界面设计工具