gsap+svg实现可爱零正数负数拖动效果代码
代码语言:html
所属分类:拖放
代码描述:gsap+svg实现可爱零正数负数拖动效果代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<link rel='stylesheet' href='https://fonts.googleapis.com/css2?family=Quicksand:wght@700&display=swap'>
<style>
body {
height: 100vh;
margin: 0;
padding: 0;
background: #bdc5ff;
}
.grid {
position: relative;
display: grid;
width: 100%;
height: 100%;
overflow: hidden;
place-items: center;
}
.runner {
position: absolute;
display: grid;
grid-template-columns: repeat(3, 1fr);
width: 300vw;
background: linear-gradient(to bottom, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
}
.number {
position: relative;
display: inline-flex;
justify-content: center;
width: 100vw;
height: 100vh;
}
input[type=range] {
-webkit-appearance: none;
appearance: none;
background: transparent;
cursor: pointer;
width: 200px;
position: fixed;
bottom: 2rem;
left: calc(50% - 100px);
}
input[type=range]::-webkit-slider-runnable-track {
background: #fcfcfc;
height: 1rem;
border-radius: 0.25rem;
border: 3px solid black;
}
input[type=range]::-moz-range-track {
background: #fcfcfc;
height: 1rem;
border-radius: 0.25rem;
border: 3px solid black;
}
input[type=range]::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
margin-top: -0.75rem;
background-color: #ffd433;
width: 2rem;
height: 2rem;
border-radius: 6px;
border: 3px solid black;
box-shadow: 2px 2px 0 0 black;
}
input[type=range]::-moz-range-thumb {
margin-top: -0.75rem;
background-color: #ffd433;
width: 2rem;
height: 2rem;
border-radius: 6px;
border: 3px solid black;
box-shadow: 2px 2px 0 0 black;
}
svg {
overflow: visible;
}
.shadow {
fill: rgba(0, 0, 0, 0.1);
}
.leg, .foot, .mouth, .body, .eyebrows {
fill: none;
stroke: #000;
stroke-linecap: round;
stroke-width: 6px;
}
.foot, .mouth {
stroke-width: 8px;
}
.neutral {
fill: #99a1ff;
}
.neutral.dark {
fill: #808aff;
}
.neutral.shadow {
fill: #6672ff;
fill-opacity: 0.2;
}
.negative {
fill: #ff4d6f;
}
.negative.dark {
fill: #ff345a;
}
.negative.shadow {
fill: #ff1a46;
fill-opacity: 0.2;
}
.positive {
fill: #2fda98;
}
.positive.dark {
fill: #24cb8b;
}
.positive.shadow {
fill: #20b67c;
fill-opacity: 0.2;
}
</style>
</head>
<body >
<div class="grid">
<div class="runner">
<!--
Negative
-->
<div class="number">
<svg id="Negative" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 400 400">
<defs>
<clipPath id="neg-eye-clip">
<path d="M216.15,172c0,8.28-5.6,15-12.5,15-6.9,0-12.5-6.72-12.5-15,0-8.28,5.6-15,12.5-15s12.5,6.72,12.5,15Z" style="fill: none;"/>
</clipPath>
<g id="neg-eye" clip-path="url(#neg-eye-clip)">
<path d="M216.5,172c0,8.28-5.6,15-12.5,15-6.9,0-12.5-6.72-12.5-15,0-8.28,5.6-15,12.5-15s12.5,6.72,12.5,15Z" style="fill: #fff;"/>
<circle cx="204" cy="149" r="15" class="negative eyelids" />
<ellipse cx="204" cy="174" rx="6" ry="6.5" class="pupils" />
</g>
</defs>
<ellipse class="negative shadow" cx="198.18" cy="343.08" rx="83.88" ry="11.71"/>
<g id="left-leg">
<path class="leg" d="M210.13,286.96c-7.94,13.61-6.8,30.45-5.43,46.14"/>
<path class="foot" d="M204.46,334.01c-5.37,.21-10.67,2.13-14.92,5.43"/>
</g>
<g id="right-leg">
<path class="leg" d="M230.03,286.96c7.94,13.61,6.8,30.45,5.43,46.14"/>
<path class="foot" d="M235.7,334.01c5.37,.21,10.67,2.13,14.92,5.43"/>
</g>
<g id="minus">
<path class="body negative" d="M96.61,194.7h56.32c4.75,0,8.61,3.86,8.61,8.61v7.18c0,3.44-2.79,6.23-6.23,6.23h-57.84c-4.75,0-8.61-3.86-8.61-8.61v-5.66c0-4.28,3.47-7.76,7.76-7.76Z"/>
<path class="negative dark" d="M153.76,209.77h-54.7c-4.5,0-8.15-3.34-8.15-7.47v5.01c0,4.58,2.36,7.47,8.15,7.47h55.71c3.17,0,4.89-1.84,4.89-4.4v-6.01c0,2.98-2.64,5.4-5.9,5.4Z" />
</g>
<g id="body">
<path class="body negative" d="M151.94,81.15l41.88-11.27c3.48-.69,19.99-1.03,23.53-1.03h16.99c11.38,0,20.65,9.13,20.83,20.51l3.12,195.78c.19,11.74-9.28,21.36-21.02,21.36h-34.94c-11.78,0-21.26-9.68-21.02-21.46l3.18-153.2c.15-7.23-5.68-13.17-12.91-13.16l-16.42,3.03c-9.12,.02-16.52-7.37-16.52-16.49v-7.89c0-7.87,5.57-14.65,13.29-16.17Z"/>
<g class="negative dark">
<path d="M184.73,123.55c.15-7.23-5.68-13.17-12.91-13.16l-16.42,3.03c-9.06,.02-16.41-7.27-16.51-16.31,0,.07,0,.14,0,.21v7.89c0,9.12,7.4,16.51,16.52,16.49l16.42-3.03c6.55-.01,11.93,4.86,12.78,11.15l.13-6.26Z" />
<path d="M237.52,298.21h-34.94c-10.88,0-19.8-8.26-20.9-18.81l-.12,5.62c-.24,11.78,9.24,21.46,21.02,21.46h34.94c11.74,0,21.21-9.62,21.02-21.36l-.09-5.96c-.99,10.66-9.96,19.05-20.92,19.05Z"/>
</g>
<path class="mouth" id="mouth" d="M198.05,272.45c8.02-6.72,17.43-11.76,27.46-14.72,5.47-1.61,11.23-2.62,16.89-1.83" />
<use xlink:href="#neg-eye" />
<use xlink:href="#neg-eye" x="32"/>
<path class="body" d="M151.94,81.15l41.88-11.27c3.48-.69,19.99-1.03,23.53-1.03h16.99c11.38,0,20.65,9.13,20.83,20.51l3.12,195.78c.19,11.74-9.28,21.36-21.02,21.36h-34.94c-11.78,0-21.26-9.68-21.02-21.46l3.18-153.2c.15-7.23-5.68-13.17-12.91-13.16l-16.42,3.03c-9.12,.02-16.52-7.37-16.52-16.49v-7.89c0-7.87,5.57-14.65,13.29-16.17Z" />
</g>
</.........完整代码请登录后点击上方下载按钮下载查看
网友评论0