svg+css实现铅笔转圈loading加载动画效果代码

代码语言:html

所属分类:加载滚动

代码描述:svg+css实现铅笔转圈loading加载动画效果代码

代码标签: svg css 铅笔 转圈 loading 加载 动画

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开


<!DOCTYPE html>
<html lang="en" >

<head>

 
<meta charset="UTF-8">

 
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover">
 
 
 
<style>
* {
        border: 0;
        box-sizing: border-box;
        margin: 0;
        padding: 0;
}
:root {
        --hue: 223;
        --bg: hsl(var(--hue),90%,90%);
        --fg: hsl(var(--hue),90%,10%);
        --trans-dur: 0.3s;
        font-size: calc(20px + (30 - 20) * (100vw - 320px) / (1280 - 320));
}
body {
        background: var(--bg);
        color: var(--fg);
        font: 1em/1.5 sans-serif;
        height: 100vh;
        display: grid;
        place-items: center;
}
.pencil {
        display: block;
        width: 10em;
        height: 10em;
}
.pencil__body1,
.pencil__body2,
.pencil__body3,
.pencil__eraser,
.pencil__eraser-skew,
.pencil__point,
.pencil__rotate,
.pencil__stroke {
        animation-duration: 3s;
        animation-timing-function: linear;
        animation-iteration-count: infinite;
}
.pencil__body1,
.pencil__body2,
.pencil__body3 {
        transform: rotate(-90deg);
}
.pencil__body1 {
        animation-name: pencilBody1;
}
.pencil__body2 {
        animation-name: pencilBody2;
}
.pencil__body3 {
        animation-name: pencilBody3;
}
.pencil__eraser {
        animation-name: pencilEraser;
        transform: rotate(-90deg) translate(49px,0);
}
.pencil__eraser-skew {
        animation-name: pencilEraserSkew;
        animation-timing-function: ease-in-out;
}
.pencil__point {
        animation-name: pencilPoint;
        transform: rotate(-90deg) translate(49px,-30px);
}
.pencil__rotate {
        animation-name: pencilRotate;
}
.pencil__stroke {
        animation-name: pencilStroke;
        transform: translate(100px,100px) rotate(-113deg);
}

/* Animations */
@keyframes pencilBody1 {
        from,
        to {
                stroke-dashoffset: 351.86;
                transform: rotate(-90deg);
        }
        50% {
                stroke-dashoffset: 150.8; /* 3/8 of diameter */
                transform: rotate(-225deg);
        }
}
@keyframes pencilBody2 {
        from,
        to {
                stroke-dashoffset: 406.84;
                transform: rotate(-90deg);
        }
        50% {
                stroke-dashoffset: 174.36;
                transform: rotate(-225deg);
        }
}
@keyframes pencilBody3 {
        from,
        to {
                stroke-da.........完整代码请登录后点击上方下载按钮下载查看

网友评论0