Smooth CSS Transition Animation Rotation

前端 未结 2 823
南笙
南笙 2021-01-12 11:09

I have created this fiddle to demonstrate the problem:

http://jsfiddle.net/NfX56/

Animation ROTATION and HOVER seems to work fine for changing direction but

相关标签:
2条回答
  • 2021-01-12 11:40

    well, this out:

    css:

    #test {
        margin: 100px;
        height: 200px; width: 200px;
        background: black;
        -webkit-transition: all 1s ease;
        -moz-transition: all 1s ease;
        -o-transition: all 1s ease;
        -ms-transition: all 1s ease;
        transition: all 1s ease;
    }
    
    #test:hover {
        background: gray;
        -webkit-transform: rotate(1080deg);
        -moz-transform: rotate(1080deg);
        -o-transform: rotate(1080deg);
        -ms-transform: rotate(1080deg);
        transform: rotate(1080deg);
    
        -webkit-border-radius: 100px;
        -moz-border-radius: 100px;
        border-radius: 100px;
    }
    

    html:

    <div id="test"></div>
    

    DEMO

    The problem that you are having is due to the slowness of the transition. Since css can have any logic, when you hover the elm will start again from "0" or "360" or whatever your setup was. So will never be smooth because css can't know what was the last "deg num" before the hover happened...

    However! you can try stylus

    "Stylus features powerful in-language function definitions."

    Hope this help :/

    0 讨论(0)
  • 2021-01-12 11:44

    I needed to think a lot to solve your request; but I have finally find the solution

    demo

    The relevant CSS code :

    .spin {
        animation: spin 2s linear 0s infinite reverse;
        -moz-animation: 2s linear 0s reverse none infinite spin;
        -webkit-animation: spin 2s linear 0s infinite reverse;
        -0-animation: spin 2s linear 0s infinite reverse;
        -webkit-animation-play-state: paused;
        -o-animation-play-state: paused;
        -moz-animation-play-state: paused;
        animation-play-state: paused;
    }
    .spin:hover {
        -webkit-animation-play-state: running;
        -o-animation-play-state: running;
        -moz-animation-play-state: running;
        -webkit-animation-play-state: running;
    }
    .yin-yang {
        animation: spin 4s linear 0s infinite normal;
        -moz-animation: 4s linear 0s normal none infinite spin;
        -webkit-animation: spin 4s linear 0s infinite normal;
        -0-animation: spin 4s linear 0s infinite normal;
    }
    

    The trick: since you already had 2 elements (spin and yin-yang) I set one of them to rotate in one direction, and the other one to rotate in reverse, and more fast. When both are running, the net effect is to rotate in one direction; when only one is rotating, the net effect is the opposite.

    Now, the only thing that is left is to pause and restart the fast rotation (not setting reseting it !)

    Detected one mistake on the above, the fourth line of .spin:hover should be the un-prefixed:

    .spin:hover {
        -webkit-animation-play-state: running;
        -o-animation-play-state: running;
        -moz-animation-play-state: running;
        animation-play-state: running;
    }
    

    corrected demo

    Adding an extra element in the HTML I have been able to make the rotation change smooth.

    smooth transition demo

    The extra CSS is:

    .acc {
        transition: all 4s ease-out;
    }
    .spin:hover .acc {
        -webkit-transform: rotate(-360deg);
        transform: rotate(-360deg);
    }
    
    0 讨论(0)
提交回复
热议问题