zoukankan      html  css  js  c++  java
  • js运动基础之匀速运动

    单个属性匀速运动
     1     /**
     2      * 单属性匀速运动
     3      */
     4     function fnSingleUniformMove(oDom, sAttr, iTarget, fn){
     5         var iSpeed, iCur;
     6         clearInterval(oDom.timer); // 开启定时器前先清除定时器,避免动画重复叠加
     7         oDom.timer = setInterval(function(){
     8 
     9             // 计算当前值
    10             if(sAttr == 'opacity'){
    11                 iCur = Math.round(fnGetStyle(oDom, sAttr) * 100);
    12             }else{
    13                 iCur = parseInt(fnGetStyle(oDom, sAttr));
    14             }
    15 
    16             // 设置速度
    17             if(iTarget < iCur){
    18                 iSpeed = -10;
    19             }else{
    20                 iSpeed = 10;
    21             }
    22 
    23             // 当目标点和当前值差值小于速度时速度等于差值
    24             if(Math.abs(iTarget - iCur) < Math.abs(iSpeed)){
    25                 iSpeed = iTarget - iCur;
    26             }
    27 
    28             // 运动停止判断
    29             if(iTarget == iCur){
    30                 clearInterval(oDom.timer);
    31                 fn&&fn();
    32             }else{
    33                 if(sAttr == 'opacity'){
    34                     oDom.style.opacity = ( iCur + iSpeed ) / 100;
    35                     oDom.style.filter = 'alpha(opacity: ' + (iCur + iSpeed) + ')';
    36                 }else{
    37                     oDom.style[sAttr] = iCur + iSpeed + 'px';
    38                 }
    39             }
    40         }, 30);
    41     };
    多属性同时改变的匀速运动
     1     /**
     2      * 多属性匀速运动
     3      */
     4     function fnMultiUniformMove(oDom, json, fn){
     5         var iSpeed, iCur, bStop;
     6         clearInterval(oDom.timer); // 开启定时器前先清除定时器,避免动画重复叠加
     7         oDom.timer = setInterval(function(){
     8             bStop = true; // 进行for in 循环前为true,如果有一个没达到目标点下面就会让他变为false,最后判断该值是否为true来决定是否关闭定时器
     9             for(var sAttr in json){
    10                 // 计算当前值
    11                 if(sAttr == 'opacity'){
    12                     iCur = Math.round(fnGetStyle(oDom, sAttr) * 100);
    13                 }else{
    14                     iCur = parseInt(fnGetStyle(oDom, sAttr));
    15                 }
    16 
    17                 // 设置速度
    18                 if(json[sAttr] < iCur){
    19                     iSpeed = -10;
    20                 }else{
    21                     iSpeed = 10;
    22                 }
    23 
    24                 // 当目标点和当前值差值小于速度时速度等于差值
    25                 if(Math.abs(json[sAttr] - iCur) < Math.abs(iSpeed)){
    26                     iSpeed = json[sAttr] - iCur;
    27                 }
    28 
    29                 // 单属性运动停止判断
    30                 if(json[sAttr] != iCur){
    31                     bStop = false;
    32                     if(sAttr == 'opacity'){
    33                         oDom.style.opacity = ( iCur + iSpeed ) / 100;
    34                         oDom.style.filter = 'alpha(opacity: ' + (iCur + iSpeed) + ')';
    35                     }else{
    36                         oDom.style[sAttr] = iCur + iSpeed + 'px';
    37                     }
    38                 }
    39             }
    40 
    41             // 整体运动停止的判断
    42             if(bStop){
    43                 clearInterval(oDom.timer);
    44                 fn&&fn();
    45             }
    46         }, 30);
    47     };
    获取元素样式的方法
    1     // 获取元素的某个样式的值
    2     function fnGetStyle(oDom, sAttr){
    3         if(getComputedStyle){
    4             return getComputedStyle(oDom, null)[sAttr]; // getComputedStyle获取自定义值时返回undefined
    5         }else{
    6             return oDom.currentStyle[sAttr]; // currentStyle和getAttribute一样可以读取自定义的值(这样opacity的值才能被获取)
    7         };
    8     };
  • 相关阅读:
    【转载】实体框架之领域驱动实践(七):模型对象的生命周期 仓储
    【转载】实体框架之领域驱动实践(四):存储过程 领域驱动的反模式
    【转载】实体框架之领域驱动实践(五):聚合
    VC6.0下配置boost库使用正则表达式(解决问题)
    boost regexpre 用于MFC时出现 'boost' : is not a class or namespace name错误
    VC技巧:在程序的状态栏中实现进度条
    正则表达式 boost regexp的安装
    最近在做实验希望实现基于JNI技术在Java中使用 Slex.dll
    利用BCGControlBar 实现状态条显示Progressbar
    正则表达式30分钟入门教程
  • 原文地址:https://www.cnblogs.com/tyxloveyfq/p/4300349.html
Copyright © 2011-2022 走看看