这篇文章主要介绍了如何使用CSS制作文字实现逐帧动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
方法步骤
HTML部分
1、创建html定义一个包含文本的div
大标题同时使用class
属性向样式。
Html编辑代码示例
<div>
<div>昵 称 过 于 强 大</div>
<!--<div>五 四 三 二 一 零</div>-->
</div>
代码效果
Html编辑写好了,然后使用css样式来进行修饰。
CSS部分
1、给网页添加背景颜色
body{
background:#333;
}
2、cell
标题文本样式,利用dashed
属性添加元素边框的样式和颜色,又利用position:absolute
属性是绝对定位放在中间。
代码示例
.cell{
width: 1em;
height: 1em;
border:1px dashed rgba(255,255,255,0.1);
font-size:120px;
font-family:Frijole;
overflow: hidden;
position:absolute;
top:50%;
left:50%;
margin:-0.5em 0 0 -0.5em;
opacity:0;
animation:go 6s;
transform-origin:left bottom;}
3、num
标题文本样式利用animation
属性steps()
逐帧动画,又利用text-shadow
属性添加文字阴影和颜色,又利用position:absolute
属性是绝对定位放在中间。
.num{
position:absolute;
width: 1em;
color:#E53F39;
line-height: 1em;
text-align: center;
text-shadow:1px 1px 2px rgba(255,255,255,.3);
animation:run 6s steps(6);
}
接下来,我们给添加动画效果,让文字态动起来实现逐帧动画效果。
给num标签绑定animation动画。
使用两个@keyframes规则,给两个动画设置每一帧的动作即可。
@keyframes run{
0%{top:0;}
100%{top:-6em;}
}
@keyframes go{
0% {opacity:1;}
84% {opacity:1;transform:rotate(0deg) scale(1);}
100% {opacity:0;transform:rotate(360deg) scale(.01);}
}
最终效果
下面给出完整代码
<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
body{
background:#333;
}
.cell{
width: 1em;
height: 1em;
border:1px dashed rgba(255,255,255,0.1);
font-size:120px;
font-family:Frijole;
overflow: hidden;
position:absolute;
top:50%;
left:50%;
margin:-0.5em 0 0 -0.5em;
opacity:0;
animation:go 6s;
transform-origin:left bottom;
}
.num{
position:absolute;
width: 1em;
color:#E53F39;
line-height: 1em;
text-align: center;
text-shadow:1px 1px 2px rgba(255,255,255,.3);
animation: blue 6s steps(1);
}
@keyframes run{
0%{top:0;}
100%{top:-6em;}
}
@keyframes go{
0% {opacity:1;}
85% {opacity:1;transform:rotate(0deg) scale(1);}
100% {opacity:0;transform:rotate(360deg) scale(.01);}
}
</style>
</head>
<body>
<div>
<div>昵 称 过 于 强 大</div>
<!--<div>五 四 三 二 一 零</div>-->
</div>
</body>
</html>
感谢你能够认真阅读完这篇文章,希望小编分享的“如何使用CSS制作文字实现逐帧动画”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!