zoukankan      html  css  js  c++  java
  • [f]添加css3动画的方法

     添加css3的一些动画的属性

    使用方法:

    css3(oDiv[0], 'scale', 300)('rotate', 300);
    css3(oDiv[0], 'animation', '"dd" .50s ease-in-out 0s');

    ps:可以完成一个变形继续下一个变形;

      dd为具体动画的样式;

    @-webkit-keyframes 'dd' {
            0% { -webkit-transform:rotate(0deg);
        }
            50% {-webkit-transform:rotate(40deg);
        }
            100% {-webkit-transform:roate(70deg);
        }
    }

    函数如下: 

    function css3(obj, attr, value) {
      if (arguments.length == 2) {
        if (attr == 'scale' || attr == 'rotate' || attr == 'rotateY' || attr == 'translateZ') {
          var arr = ["Webkit", "Moz", "O", "ms", ""];
          var sVal = '';
          if (!obj.$Transform) {
            obj.$Transform = {};
          }
          for (var i = 0; i < arr.length; i++) {
            obj.style[arr[i] + "Transform"] = sVal;
            switch (attr) {
              case 'scale':
                sVal = typeof(obj.$Transform[attr]) == 'number' ? obj.$Transform[attr] : 100;
                break;
              default:
                sVal = obj.$Transform[attr] ? obj.$Transform[attr] : 0;
            }
          }
        }
        var sCur = obj.currentStyle ? obj.currentStyle[attr] : document.defaultView.getComputedStyle(obj, false)[attr];
        if (attr == 'opacity') {
          return parseInt(parseFloat(sCur) * 100);
        } else {
          return parseInt(sCur);
        }
      } else
      if (arguments.length == 3) {
        switch (attr) {
          case 'scale':
          case 'rotate':
          case 'rotateY':
          case 'translateZ':
          case 'animation':
            setCss3(obj, attr, value);
            break;
          case 'width':
          case 'height':
          case 'paddingLeft':
          case 'paddingTop':
          case 'paddingRight':
          case 'paddingBottom':
            value = Math.max(value, 0);
          case 'left':
          case 'top':
          case 'marginLeft':
          case 'marginTop':
          case 'marginRight':
          case 'marginBottom':
            obj.style[attr] = value + 'px';
            break;
          case 'opacity':
            obj.style.filter = "alpha(opacity:" + value + ")";
            obj.style.opacity = value / 100;
            break;
          default:
            obj.style[attr] = value;
        }
      }
      return function(attr_in, value_in) {
        css(obj, attr_in, value_in)
      };
    }
    
    function setCss3(obj, attr, value) {
      var sTr = "";
      var sVal = "";
      var arr = ["Webkit", "Moz", "O", "ms", ""];
      if (!obj["$Transform"]) {
        obj["$Transform"] = {};
      }
      if (attr == 'animation') {
        for (var i = 0; i < arr.length; i++) {
          obj.style[arr[i] + 'Animation'] = value;
        }
      } else {
        obj["$Transform"][attr] = parseInt(value);
        for (sTr in obj["$Transform"]) {
          switch (sTr) {
            case 'scale':
              sVal += sTr + "(" + (obj["$Transform"][sTr] / 100) + ") ";
              break;
            case 'rotate':
            case 'rotateY':
              sVal += sTr + "(" + (obj["$Transform"][sTr]) + "deg) ";
              break;
            case 'translateZ':
              sVal += sTr + "(" + (obj["$Transform"][sTr]) + "px) ";
              break;
          }
        }
        for (var i = 0; i < arr.length; i++) {
          obj.style[arr[i] + "Transform"] = sVal;
        }
      }
    }
  • 相关阅读:
    分享25个高质量的移动设备wordpress主题(Mobile theme)
    一个强大专业的响应式jQuery幻灯效果插件:Royal Slider
    超过30个超棒的漂亮iphone 4s墙纸
    帮助你自动生成已经过去的时间的jQuery插件 Smart Time Ago
    分享20个响应式web设计的必备jQuery插件
    2012年度最新免费web开发设计资源荟萃
    myEclipse 下载
    extjs 配置与表格使用
    mysql 4.0.26 安装流程
    spring+ehcache 实现原理
  • 原文地址:https://www.cnblogs.com/niubenbit/p/4079062.html
Copyright © 2011-2022 走看看