• 鼠标经过方向感知


    <!DOCTYPE html>
    <html >
    <head>
    <meta charset="UTF-8">
    <title>666</title>
    <style>
    /* the important bits */
    li {
      -webkit-perspective: 400px;
              perspective: 400px;
    }
    
    .info {
      -webkit-transform: rotate3d(1, 0, 0, 90deg);
              transform: rotate3d(1, 0, 0, 90deg);
       100%;
      height: 100%;
      padding: 20px;
      position: absolute;
      top: 0;
      left: 0;
      border-radius: 4px;
      pointer-events: none;
      background-color: rgba(26, 188, 156, 0.9);
    }
    
    .in-top .info {
      -webkit-transform-origin: 50% 0%;
              transform-origin: 50% 0%;
      -webkit-animation: in-top 300ms ease 0ms 1 forwards;
              animation: in-top 300ms ease 0ms 1 forwards;
    }
    
    .in-right .info {
      -webkit-transform-origin: 100% 0%;
              transform-origin: 100% 0%;
      -webkit-animation: in-right 300ms ease 0ms 1 forwards;
              animation: in-right 300ms ease 0ms 1 forwards;
    }
    
    .in-bottom .info {
      -webkit-transform-origin: 50% 100%;
              transform-origin: 50% 100%;
      -webkit-animation: in-bottom 300ms ease 0ms 1 forwards;
              animation: in-bottom 300ms ease 0ms 1 forwards;
    }
    
    .in-left .info {
      -webkit-transform-origin: 0% 0%;
              transform-origin: 0% 0%;
      -webkit-animation: in-left 300ms ease 0ms 1 forwards;
              animation: in-left 300ms ease 0ms 1 forwards;
    }
    
    .out-top .info {
      -webkit-transform-origin: 50% 0%;
              transform-origin: 50% 0%;
      -webkit-animation: out-top 300ms ease 0ms 1 forwards;
              animation: out-top 300ms ease 0ms 1 forwards;
    }
    
    .out-right .info {
      -webkit-transform-origin: 100% 50%;
              transform-origin: 100% 50%;
      -webkit-animation: out-right 300ms ease 0ms 1 forwards;
              animation: out-right 300ms ease 0ms 1 forwards;
    }
    
    .out-bottom .info {
      -webkit-transform-origin: 50% 100%;
              transform-origin: 50% 100%;
      -webkit-animation: out-bottom 300ms ease 0ms 1 forwards;
              animation: out-bottom 300ms ease 0ms 1 forwards;
    }
    
    .out-left .info {
      -webkit-transform-origin: 0% 0%;
              transform-origin: 0% 0%;
      -webkit-animation: out-left 300ms ease 0ms 1 forwards;
              animation: out-left 300ms ease 0ms 1 forwards;
    }
    
    @-webkit-keyframes in-top {
      from {
        -webkit-transform: rotate3d(-1, 0, 0, 90deg);
                transform: rotate3d(-1, 0, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    
    @keyframes in-top {
      from {
        -webkit-transform: rotate3d(-1, 0, 0, 90deg);
                transform: rotate3d(-1, 0, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @-webkit-keyframes in-right {
      from {
        -webkit-transform: rotate3d(0, -1, 0, 90deg);
                transform: rotate3d(0, -1, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @keyframes in-right {
      from {
        -webkit-transform: rotate3d(0, -1, 0, 90deg);
                transform: rotate3d(0, -1, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @-webkit-keyframes in-bottom {
      from {
        -webkit-transform: rotate3d(1, 0, 0, 90deg);
                transform: rotate3d(1, 0, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @keyframes in-bottom {
      from {
        -webkit-transform: rotate3d(1, 0, 0, 90deg);
                transform: rotate3d(1, 0, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @-webkit-keyframes in-left {
      from {
        -webkit-transform: rotate3d(0, 1, 0, 90deg);
                transform: rotate3d(0, 1, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @keyframes in-left {
      from {
        -webkit-transform: rotate3d(0, 1, 0, 90deg);
                transform: rotate3d(0, 1, 0, 90deg);
      }
      to {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
    }
    @-webkit-keyframes out-top {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(-1, 0, 0, 104deg);
                transform: rotate3d(-1, 0, 0, 104deg);
      }
    }
    @keyframes out-top {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(-1, 0, 0, 104deg);
                transform: rotate3d(-1, 0, 0, 104deg);
      }
    }
    @-webkit-keyframes out-right {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(0, -1, 0, 104deg);
                transform: rotate3d(0, -1, 0, 104deg);
      }
    }
    @keyframes out-right {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(0, -1, 0, 104deg);
                transform: rotate3d(0, -1, 0, 104deg);
      }
    }
    @-webkit-keyframes out-bottom {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(1, 0, 0, 104deg);
                transform: rotate3d(1, 0, 0, 104deg);
      }
    }
    @keyframes out-bottom {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(1, 0, 0, 104deg);
                transform: rotate3d(1, 0, 0, 104deg);
      }
    }
    @-webkit-keyframes out-left {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(0, 1, 0, 104deg);
                transform: rotate3d(0, 1, 0, 104deg);
      }
    }
    @keyframes out-left {
      from {
        -webkit-transform: rotate3d(0, 0, 0, 0deg);
                transform: rotate3d(0, 0, 0, 0deg);
      }
      to {
        -webkit-transform: rotate3d(0, 1, 0, 104deg);
                transform: rotate3d(0, 1, 0, 104deg);
      }
    }
    /* you can ignore this ones */
    ul {
      padding: 0;
      margin: 0 0 50px;
    }
    ul:after {
      content: "";
      display: table;
      clear: both;
    }
    
    li {
      position: relative;
      float: left;
       200px;
      height: 200px;
      margin: 5px;
      padding: 0;
      list-style: none;
    }
    li a {
      display: inline-block;
      vertical-align: top;
      text-decoration: none;
      border-radius: 4px;
    }
    li h3 {
      margin: 0;
      font-size: 16px;
      color: rgba(255, 255, 255, 0.9);
    }
    li p {
      font-size: 12px;
      line-height: 1.5;
      color: rgba(255, 255, 255, 0.8);
    }
    li .normal {
       100%;
      height: 100%;
      background-color: #ECF0F1;
      color: rgba(52, 73, 94, 0.6);
      box-shadow: inset 0 2px 20px #e6ebed;
      text-align: center;
      font-size: 50px;
      line-height: 200px;
    }
    li .normal svg {
      pointer-events: none;
       50px;
    }
    li .normal svg path {
      fill: rgba(52, 73, 94, 0.2);
    }
    
    * {
      box-sizing: border-box;
    }
    
    body {
      background-color: #fff;
    }
    
    h1 {
      margin: 0 auto 5px;
      text-align: center;
    }
    
    h3 {
      font-family: 'Bree Serif', serif;
    }
    
    .container {
       840px;
      margin: 0 auto;
    }
    
    header {
      font-family: 'Bree Serif', serif;
      text-align: center;
      margin: 50px 0 25px;
      color: #34495E;
    }
    header p {
      margin: 0;
      color: rgba(52, 73, 94, 0.4);
    }
    
    </style>
    </head>
    <body>
    <div class='container'>
      <ul>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
        <li> <a class='normal' href='#'>
          </a>
          <div class='info'>
            <h3>我才是最帅的</h3>
          </div>
        </li>
      </ul>
    </div>
    
    <script>
    var nodes  = document.querySelectorAll('li'),
        _nodes = [].slice.call(nodes, 0);
    
    var getDirection = function (ev, obj) {
        var w = obj.offsetWidth,
            h = obj.offsetHeight,
            x = (ev.pageX - obj.offsetLeft - (w / 2) * (w > h ? (h / w) : 1)),
            y = (ev.pageY - obj.offsetTop - (h / 2) * (h > w ? (w / h) : 1)),
            d = Math.round( Math.atan2(y, x) / 1.57079633 + 5 ) % 4;
      
        return d;
    };
    
    var addClass = function ( ev, obj, state ) {
        var direction = getDirection( ev, obj ),
            class_suffix = "";
        
        obj.className = "";
        
        switch ( direction ) {
            case 0 : class_suffix = '-top';    break;
            case 1 : class_suffix = '-right';  break;
            case 2 : class_suffix = '-bottom'; break;
            case 3 : class_suffix = '-left';   break;
        }
        
        obj.classList.add( state + class_suffix );
    };
    
    // bind events
    _nodes.forEach(function (el) {
        el.addEventListener('mouseover', function (ev) {
            addClass( ev, this, 'in' );
        }, false);
    
        el.addEventListener('mouseout', function (ev) {
            addClass( ev, this, 'out' );
        }, false);
    });
    </script>
    </body>
    </html>

    转载自http://www.qdfuns.com/notes/35646/42e621e4b62a0fab0d005591d062fcb6.html

  • 相关阅读:
    UVA 10970-Big Chocolate
    HUAS Summer Trainning #3 L
    HUAS Summer Trainning #3 K
    HUAS Summer Trainning #3 E
    HUAS Summer Trainning #3 C
    HUAS Summer Trainning #3 B
    HUAS Summer Trainning #3 A
    2015 HUAS Summer Training#2 G
    2015 HUAS Summer Training#2 F
    2015 HUAS Summer Training#2 E
  • 原文地址:https://www.cnblogs.com/youzhuxiaoyao/p/6857172.html
Copyright © 2020-2023  润新知