js实现一只小猫咪跟随鼠标交互行走跳跃动画效果代码
代码语言:html
所属分类:其他
代码描述:js结合svg及css实现一只小猫咪跟随鼠标进行交互行走并时不时跳跃动画效果代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
* {
box-sizing: border-box;
}
body {
padding: 0;
margin: 0;
font-family: sans-serif;
background-color: #63ec85;
}
.outer_wrapper {
position: absolute;
width: 100%;
height: 100vh;
overflow: hidden;
}
.wrapper {
position: absolute;
height: calc(100vh - 100px);
width: 100%;
top: 0;
}
.ground {
position: absolute;
bottom: 0;
width: 100%;
height: 150px;
background-color: rgb(1, 143, 96);
}
.cat {
position: absolute;
bottom: 65px;
left: 100px;
height: 30px;
width: 60px;
transition: 1.5s;
transform-origin: center;
background-color: transparent;
}
/* body */
.body {
position: absolute;
height: 30px;
width: 60px;
}
.face_left .body {
animation: turn_body_left forwards 0.5s;
}
@keyframes turn_body_left {
0%,100% { transform: scale(1); }
50% { transform: scale(0.5, 1); }
}
.face_right .body {
animation: turn_body_right forwards 0.5s;
}
@keyframes turn_body_right {
0%,100% { transform: scale(1); }
50% { transform: scale(0.5, 1); }
}
/* head */
.cat_head {
position: absolute;
height: 40px;
width: 48px;
right: -10px;
top: -30px;
transition: 0.5s;
z-index: 50;
}
.first_pose .cat_head,
.face_left .cat_head{
right: 22px;
}
/* tail */
.tail {
position: absolute;
top: -25px;
height: 36px;
width: 15px;
animation: tail_motion forwards 2s;
transform-origin: bottom right;
}
@keyframes tail_motion {
0%,100% {
left: -5px;
transform: rotate(0deg) scale(1);
}
50% {
left: -10px;
transform: rotate(-50deg) scale(-1,1);
}
}
.first_pose .tail ,
.face_left .tail {
left: 45px;
animation: tail_motion_alt forwards 2s;
}
@keyframes tail_motion_alt {
0%,100% {
left: 45px;
transform: rotate(0deg) scale(1);
}
50% {
left: 40px;
transform: rotate(50deg) scale(-1,1);
}
}
/* legs */
.leg {
position: absolute;
height: 20px;
width: 10px;
transform-origin: top center;
}
.front_legs,
.back_legs {
position: absolute;
height: 30px;
transition: 0.7s;
}
.front_legs {
width: 30px;
right: 0;
}
.back_legs {
width: 25px;
left: 0;
}
.face_left .leg svg {
transform: scale(-1,1);
}
.face_right .front_legs{ right: 0; }
.first_pose .front_legs,
.face_left .front_legs{ right: 30px; }
.face_right .back_legs{ left: 0; }
.first_pose .back_legs,
.face_left .back_legs{ left: 35px; }
.one,
.three {
bottom: -15px;
right: 0;
}
.two,
.four {
bottom: -15px;
left: 0px;
}
.one.walk,
.three.walk {
animation: infinite 0.3s walk;
}
.two.walk,
.four.walk {
animation: infinite 0.3s walk_alt;
}
@keyframes walk {
0%,100% {transform: rotate(-10deg);}
50% {transform: rotate(10deg);}
}
@keyframes walk_alt {
0%,100% {transform: rotate(10deg);}
50% {transform: rotate(-10deg);}
}
/* jump */
.cat_wrapper {
position: absolute;
bottom: 0;
}
.cat_wrapper.jump .one {
animation: infinite 0.3s walk;
}
.cat_wrapper.jump .two {
animation: infinite 0.3s walk_alt;
}
.cat_wrapper.jump .three,
.cat_wrapper.jump .four {
animation: none;
}
.cat_wrapper.jump .cat.face_right .back_legs {
transform-origin: center;
transform: rotate(50deg);
}
.cat_wrapper.jump .cat.face_left .back_legs {
transform-origin: center;
transform: rotate(-50deg);
}
.cat_wrapper.jump .cat.face_right .........完整代码请登录后点击上方下载按钮下载查看
网友评论0