纯CSS3实现地球⾃转实现代码(图⽂教程附送源码)最终成果:
素材:两张图⽚,
espaco.jpg(1600*1000)
terra.jpg(900*450)
第⼀步,形成静态图(地球背景全屏,地球⼤⼩为450px*450px,地球位置为上下左右居中):
复制代码
代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Planet Earth</title>
<style type="text/css">
body{
background: url(espaco.jpg) no-repeat 0 0;
background-size: 100%; /* 背景图⽚被拉伸为全屏 */
}
.earth{
background: url(terra.jpg) repeat-x 0 0; /* 背景图⽚在⽔平⽅向复制*/
/*下⾯的属性可使地球位于浏览器窗⼝垂直⽔平居中国*/
height: 450px;
left: 50%;
margin: -225px 0 0 -225px;
position: absolute;
top: 50%;html滚动效果代码
width: 450px;
}
</style>
</head>
<body>
<div class="earth"></div>
</body>
</html>
效果图:
第⼆步,形成圆形地球效果,同时添加⽉晕效果:
复制代码
代码如下:
/*在earth中添加以下属性样式*/
border: 1px solid rgba(26,18,101,0.3); /*形成圆边效果,视觉效果更好,不⽤也⾏*/
border-radius: 225px; /*使地球形成圆形效果*/
box-shadow: -8px 0 25px rgba(256,256,256,0.3), -1px -2px 14px rgba(256,256,256,0.5) inset; /*形成圆形外⾯的模糊⽉晕效果*/
效果图:
第三步,形成⽩天⿊夜效果:
复制代码
代码如下:
.earth:before{
content: "";
border-radius: 225px;
box-shadow: -150px -6px 25px rgba(0,0,0,0.7) inset;/*弧形阴影,形成⽩天⿊夜效果*/ left: 0;
position:absolute;
top: 0;
height: 450px;
width: 450px;
}
效果图:
最后⼀步,形成地球⾃转效果:
复制代码
代码如下:
@-webkit-keyframes loop {
% { background-position: 0 0; }
%{ background-position: -900px 0;} /* 世界地图的⼤⼩为900*450,所以background-position-x: -900px */ }
/*在earth中添加如下样式*/
-webkit-animation: loop 20s linear infinite; /* 这的时间是可以设置的,如果你想地球转快⼀点的话,时间改⼩点就⾏了,⽐如10s */
相关⽂件下载地址: planetEarth.rar
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论