书签 分享 收藏 举报 版权申诉 / 9

类型CSS3skew倾斜rotate旋转动画.docx

  • 文档编号:8833524
  • 上传时间:2023-05-15
  • 格式:DOCX
  • 页数:9
  • 大小:74.06KB

CSS代码(设置容器及动画元素默认样式):

#warp {

width:

 320px;

height:

 320px;

background:

 #6FDE82;

margin:

 20px auto;

}

#box {

height:

 40px;

width:

 40px;

background:

 yellow;

position:

 relative;

top:

 280px;

left:

 0;

}

注意:

#box{position:

relative;}是为该元素接下来做动画做准备,因为动画过程中需要改变其位置,故这里使用相对定位

上述代码为基本的htmlcss,大家应该没问题吧

此时效果如下:

2、使用CSS3@keyframes自定义动画

CSS代码:

@keyframes move {

0% {

top:

 280px;

left:

 0;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

}

20% {

top:

 0;

left:

 0;

transform:

 skewX(50deg);

width:

 60px;

height:

 20px;

background:

 red;

}

22% {

top:

 0;

left:

 0;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

}

30% {

top:

 0;

left:

 0;

transform:

 skewX(0deg);

width:

 320px;

height:

 40px;

}

40% {

top:

 0;

left:

 280px;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

background:

 green;

}

50% {

top:

 0;

left:

 280px;

transform:

 skewX(0deg);

width:

 20px;

height:

 320px;

}

55% {

top:

 280px;

left:

 280px;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

background:

 blue;

}

60% {

transform:

 rotate(-90deg);

transform-origin:

 left bottom;

}

65% {

transform:

 rotate(-180deg);

transform-origin:

 left top;

}

}

代码解析:

1.css3自定义动画需要使用@keyframes规则,具体请看CSS3@keyframes规则

2.设置动画执行进度

本示例中定义了0%20% 22%30%40%50%55%60%65%几个动画进度,

百分比到底代表什么意思?

举例说明:

如果整个动画执行10秒,那么20%就代表当动画执行到2秒时的效果。

所以整个自定义动画翻译过来就是在每个执行进度中定义css样式(比如width,height,color等),这样就形成了连贯的动画效果。

执行进度百分比根据实际情况可自行调整。

注意:

该执行进度并非一定要设置100%,如本示例中仅设置到65%,这就意味着剩下的35%就由css3自行完成动画回归到原始状态(大家可以试试)

3.元素倾斜(元素变形)、旋转(元素不变形)

本示例中用到倾斜及旋转动画,倾斜使用skew(),参数为倾斜度数;旋转使用rotate(),参数为旋转度数;

倾斜原理示意图如下:

X轴逆时针转为正;Y轴顺时针转为正;

举例:

skew(30deg),在本示例中效果将成这样

skew(-30deg),在本示例中效果将成这样

Y轴的这里就不举例了,根据上述提示大家可自行测试效果

4.transform-origin,元素倾斜或转动中心点,具体属性值可看CSS3transform-origin属性

这里的中心点,指的是动画元素的中心点,元素围绕该点转动或倾斜,该点坐标是不会改变的;个人觉得这里需要头脑中产生一些几何图形以便于理解,或者用一张纸(手机之类的物品)放在桌子上,用手固定该物品的某个点演示一下转动效果,就明白了

3、执行自定义动画

CSS代码:

#box {

height:

 40px;

width:

 40px;

background:

 yellow;

position:

 relative;

top:

 280px;

left:

 0;

animation:

 move 5s infinite;

}

代码解析:

animation:

 move 5s infinite;

代表该自定义动画完成耗时5秒,并且无限循环执行

animation属性的详细说明请看这里CSS3animation(动画)属性

OK,上述步骤及原理大家都清楚了吧。

本示例完整代码如下,各位可以直接复制去执行看看效果

DOCTYPE html>

HTML5+CSS3 skew倾斜、rotate旋转动画

#warp {

width:

 320px;

height:

 320px;

background:

 #6FDE82;

margin:

 20px auto;

}

#box {

height:

 40px;

width:

 40px;

background:

 yellow;

position:

 relative;

top:

 280px;

left:

 0;

animation:

 move 5s infinite;

}

@keyframes move {

0% {

top:

 280px;

left:

 0;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

}

20% {

top:

 0;

left:

 0;

transform:

 skewX(50deg);

width:

 60px;

height:

 20px;

background:

 red;

}

22% {

top:

 0;

left:

 0;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

}

30% {

top:

 0;

left:

 0;

transform:

 skewX(0deg);

width:

 320px;

height:

 40px;

}

40% {

top:

 0;

left:

 280px;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

background:

 green;

}

50% {

top:

 0;

left:

 280px;

transform:

 skewX(0deg);

width:

 20px;

height:

 320px;

}

55% {

top:

 280px;

left:

 280px;

transform:

 skewX(0deg);

width:

 40px;

height:

 40px;

background:

 blue;

}

60% {

transform:

 rotate(-90deg);

transform-origin:

 left bottom;

}

65% {

transform:

 rotate(-180deg);

transform-origin:

 left top;

}

}

WEB

好了,今天分享就到这里,以后还有更多哟,请大家一起来交流下,有兴趣的朋友给我的文章评论下嘛

(注:

可编辑下载,若有不当之处,请指正,谢谢!

配套讲稿:

如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

特殊限制:

部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

关 键  词:
CSS3skew 倾斜 rotate 旋转 动画
提示  冰点文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
关于本文
本文标题:CSS3skew倾斜rotate旋转动画.docx
链接地址:https://www.bingdoc.com/p-8833524.html
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2


收起
展开