Skip to content

Instantly share code, notes, and snippets.

@f8lrebel
Created March 28, 2015 20:20
Show Gist options
  • Save f8lrebel/63919f9820a566b4dbb1 to your computer and use it in GitHub Desktop.
Save f8lrebel/63919f9820a566b4dbb1 to your computer and use it in GitHub Desktop.
Sit 'n Spin
<div class="spinner"></div>

Sit 'n Spin

A pure CSS spinner mixin for LESS that utilizes an inlined SVG for its source.

A Pen by esjay on CodePen.

License.

/* Normal Usage */
// @import 'sitNSpin.less';
.spinner {
.sitNSpin(750ms);
}
/* sitNSpin.less */
.sitNSpin(@animationSpeed: 1000ms) {
@sitNSpinSize: 10em;
&:before {
.transformBefore(45);
animation: @animationSpeed rotateBefore infinite linear reverse;
}
&:after {
.transformAfter(45);
animation: @animationSpeed rotateAfter infinite linear;
}
&:before, &:after {
box-sizing: border-box;
content: '';
display: block;
position: fixed;
top: 50%;
left: 50%;
margin-top: (@sitNSpinSize * -.5);
margin-left: (@sitNSpinSize * -.5);
width: @sitNSpinSize;
height: @sitNSpinSize;
transform-style: preserve-3d;
transform-origin: 50%;
transform: rotateY(50%);
perspective-origin: 50% 50%;
perspective: 340px;
background-size: @sitNSpinSize @sitNSpinSize;
background-image: url();
}
}
.transformThis(@X: 0, @Y: 0, @Z: 0) {
transform: rotateX(unit(@X, deg)) rotateY(unit(@Y, deg)) rotateZ(unit(@Z, deg));
}
.transformBefore(@Z) {
.transformThis(60, 45, @Z);
}
.transformAfter(@Z) {
.transformThis(240, 45, @Z);
}
@keyframes rotateBefore {
from {
.transformBefore(0);
}
to {
.transformBefore(-360);
}
}
@keyframes rotateAfter {
from {
.transformAfter(0);
}
to {
.transformAfter(360);
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment