html画布画出圆圈向外扩散,利用CSS3动画实现圆圈由小变大向外扩散的效果实例...

本文介绍了如何利用CSS3的动画和2D转换属性创建一个圆圈从小变大并向外扩散的视觉效果。通过@keyframes定义动画关键帧,结合transform:scale改变元素缩放比例和opacity调整透明度,实现了圆圈动态变化的动画。同时,文章提供了详细的代码示例和动画效果的静态展示。
摘要由CSDN通过智能技术生成

前言

本文主要给大家分享的是关于利用CSS3动画实现圆圈由小变大向外扩散的效果实例,文中涉及到 CSS3 的动画(animation)、2D 转换(transform: scale)

css3中新增了一个animation的属性,该属性类似于创建一个animation对象

如:animation: bounce 2.0s infinite ease-in-out;

animation有以下几个参数:

属性

描述

CSS

animation

所有动画属性的简写属性,除了 animation-play-state 属性。

3

animation-name

规定 @keyframes 动画的名称。

3

animation-duration

规定动画完成一个周期所花费的秒或毫秒。默认是 0。

3

animation-timing-function

规定动画的速度曲线。默认是 "ease"。

3

animation-delay

规定动画何时开始。默认是 0。

3

animation-iteration-count

规定动画被播放的次数。默认是 1。

3

animation-direction

规定动画是否在下一周期逆向地播放。默认是 "normal"。

3

animation-play-state

规定动画是否正在运行或暂停。默认是 "running"。

3

animation-fill-mode

规定对象动画时间之外的状态。

3

CSS 3 中2D转换的实现用到两个属性:

属性

描述

CSS

transform

向元素应用 2D 或 3D 转换。

3

transform-origin

指定变换的基点的位置。

3

静态效果图:

dd6516ec3c440768d307a4c2caf3951a.png

具体如代码所示:

无标题文档

@keyframes warn {

0% {

transform: scale(0);

opacity: 0.0;

}

25% {

transform: scale(0);

opacity: 0.1;

}

50% {

transform: scale(0.1);

opacity: 0.3;

}

75% {

transform: scale(0.5);

opacity: 0.5;

}

100% {

transform: scale(1);

opacity: 0.0;

}

}

@-webkit-keyframes "warn" {

0% {

-webkit-transform: scale(0);

opacity: 0.0;

}

25% {

-webkit-transform: scale(0);

opacity: 0.1;

}

50% {

-webkit-transform: scale(0.1);

opacity: 0.3;

}

75% {

-webkit-transform: scale(0.5);

opacity: 0.5;

}

100% {

-webkit-transform: scale(1);

opacity: 0.0;

}

}

.container {

position: relative;

width: 40px;

height: 40px;

border: 1px solid #000;

}

/* 保持大小不变的小圆圈 */

.dot {

position: absolute;

width: 6px;

height: 6px;

left: 15px;

top: 15px;

-webkit-border-radius: 20px;

-moz-border-radius: 20px;

border: 2px solid red;

border-radius: 20px;

z-index: 2;

}

/* 产生动画(向外扩散变大)的圆圈 */

.pulse {

position: absolute;

width: 24px;

height: 24px;

left: 2px;

top: 2px;

border: 6px solid red;

-webkit-border-radius: 30px;

-moz-border-radius: 30px;

border-radius: 30px;

z-index: 1;

opacity: 0;

-webkit-animation: warn 3s ease-out;

-moz-animation: warn 3s ease-out;

animation: warn 3s ease-out;

-webkit-animation-iteration-count: infinite;

-moz-animation-iteration-count: infinite;

animation-iteration-count: infinite;

}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值