文章目录
- 一、CSS3 动画属性
- 1、CSS3 常见动画属性简介
- 2、代码示例 - CSS3 常见动画属性使用
- 二、CSS3 动画属性简写方式
- 1、CSS3 动画属性简写语法
- 2、animation 简写动画属性提示
- 3、动画属性简写形式与原形式对比
- 4、代码示例 - CSS3 动画属性简写示例
- 三、使用动画制作热点地图
- 1、地图背景设置
- 2、热点动画位置测量
- 3、热点动画布局分析
- 4、动画定义
- 5、小圆点实现
- 6、波纹效果盒子实现
- 7、延迟动画设置
- 8、代码示例
一、CSS3 动画属性
1、CSS3 常见动画属性简介
CSS3 中动画使用 @keyframes 关键字 定义 动画 ;
@keyframes element-move { 0% { transform: translateX(500px); } 100% { transform: translateX(0); }
}
在 @keyframes 定义的动画中 , 可以设置一系列的 CSS 属性 , 用于控制动画的运行 , 常见的属性如下 : ( 下面的动画属性是设置在 执行动画 的 标签元素 样式中的 )
- animation-name 属性 : 设置在 @keyframes 定义动画时的 动画名称 , 一般在调用动画的 标签元素 中使用 , 用于定义动画执行哪些关键帧 , 该属性是调用动画必须要设置的 ;
div {/* 设置动画名称 之前使用 @keyframes 定义的 element-move 动画 */animation-name: element-move;}
- animation-duration 属性 : 设置 CSS3 动画的持续时间 , 默认为 0 ;
- 单位可以是 秒 s ;
- 单位也可以是 毫秒 ms ;
div {/* 设置动画执行时间 2 秒 */animation-duration: 2s;}
- animation-timing-function 属性 : 设置动画的 " 时间函数 " , 该函数体现了动画的速度变化曲线 ; 常见的值有
- linear 线性
- ease 缓入缓出
- ease-in 缓入
- ease-out 缓出
div {/* 设置动画运动曲线 ease 缓入缓出 */animation-timing-function: ease;}
- animation-delay 属性 : 设置动画的延迟时间 , 延迟指定的时间后 , 再执行动画 ;
- 单位可以是 秒 s ;
- 单位也可以是 毫秒 ms ;
div {/* 设置动画开始时间 1 秒后开始 */animation-delay: 1s;}
- animation-iteration-count 属性 : 设置 CSS3 动画 执行的 重复次数 ;
- 可设置具体的次数 , 如 : 2 , 100 ;
- 如果设置 无限次 , 可设置 infinite 属性值 ;
div {/* 设置动画执行次数 无限循环播放 */animation-iteration-count: infinite;}
- animation-direction 属性 : 设置 动画的 播放方向 ; 常见的值如下 :
- normal 正常播放
- reverse 反向播放
- alternate 交替播放
div {/* 设置动画播放方向 交替播放 一次正向一次反向 */animation-direction: alternate;}
- animation-fill-mode 属性 : 设置 动画 播放后 的状态 ; 常见的值如下 :
- none 不改变元素样式
- forwards 保持动画结束时的样式
- backwards 保持动画开始时的样式 , 回到起始点 ;
div {/* 设置动画执行完毕后的状态 回到起始状态 */animation-fill-mode: backwards;}
- animation-play-state 属性 : 设置 动画 播放状态 , 常见的值如下 :
- running 运行中
- paused 暂停
div {/* 设置动画当前的播放状态 运行状态 */animation-play-state: running;}
2、代码示例 - CSS3 常见动画属性使用
代码示例 :
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><!-- 设置 meta 视口标签 --><meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>CSS3 动画属性</title><style>@keyframes element-move {0% {transform: translateX(500px);}100% {transform: translateX(0);}}div {width: 100px;height: 100px;background-color: pink;/* 设置动画名称 之前使用 @keyframes 定义的 element-move 动画 */animation-name: element-move;/* 设置动画执行时间 2 秒 */animation-duration: 2s;/* 设置动画运动曲线 ease 缓入缓出 */animation-timing-function: ease;/* 设置动画开始时间 1 秒后开始 */animation-delay: 1s;/* 设置动画执行次数 无限循环播放 */animation-iteration-count: infinite;/* 设置动画播放方向 交替播放 一次正向一次反向 */animation-direction: alternate;/* 设置动画执行完毕后的状态 回到起始状态 */animation-fill-mode: backwards;/* 设置动画当前的播放状态 运行状态 */animation-play-state: running;}</style>
</head><body><div></div>
</body></html>
执行效果 : 网页运行后 , 下面的小方块 无限循环 左右 往复运动 ;
二、CSS3 动画属性简写方式
1、CSS3 动画属性简写语法
CSS3 动画属性简写 语法 :
animation: 动画名称 持续时间 运动曲线 开始时间 播放次数 播放方向 结束状态;
animation: name duration timing-function delay iteration-count direction fill-mode;
上述简写的各个属性之间 , 使用空格隔开 ;
动画属性中 , 除了 animation-play-state 属性之外 , 其它动画属性都可以简写到 animation 属性中 ;
animation-play-state 属性 控制 动画开始暂停 , 一般需要根据代码逻辑单独控制 ;
animation 简写属性 中各属性对应关系 :
- 动画名称 : animation-name , @keyframes 动画的名称 ;
- 持续时间 : animation-duration , 动画运行一个周期所花费的时间 , 单位 秒 / 毫秒 ;
- 运动曲线 : animation-timing-function , 动画运行曲线 , 默认 ease 缓入缓出 ;
- 开始时间 : animation-delay , 动画开始运行的时间 , 单位 秒 / 毫秒 ;
- 播放次数 : animation-iteration-count , 动画播放次数 , 默认 1 , 无限循环播放 infinite ;
- 播放方向 : animation-direction , 动画播放方向 , 正 / 反 / 交替 ;
- 结束状态 : animation-fill-mode , 动画运行开始结束后的状态 ;
2、animation 简写动画属性提示
在编写 animation 简写动画属性时 , 如果没有记住顺序 , 可以在 输入 anim 之后 , 发现下面的提示 ,
然后在第一个提示位置 , 敲回车 , 即可生成如下代码 :
animation: name duration timing-function delay iteration-count direction fill-mode;
然后根据上述代码提示 , 填充每个 动画属性值 ;
3、动画属性简写形式与原形式对比
原来设置动画属性需要的代码 :
/* 设置动画名称 之前使用 @keyframes 定义的 element-move 动画 */animation-name: element-move;/* 设置动画执行时间 2 秒 */animation-duration: 2s;/* 设置动画运动曲线 ease 缓入缓出 */animation-timing-function: ease;/* 设置动画开始时间 1 秒后开始 */animation-delay: 1s;/* 设置动画执行次数 无限循环播放 */animation-iteration-count: infinite;/* 设置动画播放方向 交替播放 一次正向一次反向 */animation-direction: alternate;/* 设置动画执行完毕后的状态 回到起始状态 */animation-fill-mode: backwards;
使用动画的简写形式 , 只需一行代码即可实现 :
/* 使用简写形式设置动画属性 */animation: element-move 2s ease 1s infinite alternate backwards;
4、代码示例 - CSS3 动画属性简写示例
代码示例 :
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><!-- 设置 meta 视口标签 --><meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>CSS3 动画属性</title><style>@keyframes element-move {0% {transform: translateX(500px);}100% {transform: translateX(0);}}div {width: 100px;height: 100px;background-color: pink;/* 使用简写形式设置动画属性 */animation: element-move 2s ease 1s infinite alternate backwards;/* 设置动画当前的播放状态 运行状态 */animation-play-state: running;}</style>
</head><body><div></div>
</body></html>
执行结果 : 在网页中的小方块左右往复运动 ;
三、使用动画制作热点地图
实现如下效果 , 在一张地图上 , 以某个位置为中心点 , 向四周发散 ;
核心 是实现 向四周 发散 的 波纹动画 ;
1、地图背景设置
地图背景设置 :
地图 是 一张 png 格式的 半透明 背景图片 , 图片大小为 747 x 617 像素 ;
使用 地图 图片 作为 div 盒子模型 的 背景图片 ;
<!-- 为 该 div 盒子模型 设置 类名为 map --><div class="map"></div>
上述 .map 类对应的 div 盒子模型的大小 , 也要设置为 747 x 617 像素 ; 同时设置 地图 背景图片 , 并设置 水平居中 ;
.map {/* 盒子模型的宽高 就是 背景图片的宽高 */width: 747px;height: 617px;/* 设置背景图片 */background: url(images/map.png);/* 上下外边距设置为 0 , 左右外边距设置为 auto 居中 */margin: 0 auto;}
该地图是 半透明 白色背景 , 需要设置一个 暗色 的整体背景 , 才能看出来 , 这里将页面设置成 #333 颜色的 纯色背景 ;
body {background-color: #333;}
设置完毕后 , 可以在网页中查看该背景图 ;
2、热点动画位置测量
在 map 父容器中 , 定义 city 子元素 , 该子元素使用 绝对定位 放置位置 ;
<body><!-- 为 该 div 盒子模型 设置 类名为 map --><div class="map"><!-- 为 该 div 盒子模型 设置 类名为 city --><div class="city">田</div></div>
</body>
为上述 city 标签元素设置 CSS 样式 , 设置其定位方式为 绝对定位 , 根据 " 子绝父相 " 原则 , 该子元素 所在的 父容器 必须要使用 相对定位 ;
使用 left 和 top 设置 该 子元素 在 父容器内 距离左侧的位移 和 距离顶部的位移 ;
.city {/* 使用绝对定位进行定位 , 子绝父相 , 父容器 相对定位 */position: absolute;/* 绝对定位位置 : 距离顶部的位移 */top: 100px;/* 绝对定位位置 : 距离左侧的位移 */left: 100px;/* 设置白色 , 容易分辨 */color: white;}
下面通过 F12 调试的方式 , 将 city 盒子 , 使用 绝对定位 定位到 地图图片 中的 北京 位置 ;
调试 界面中 , 找到 city 盒子模型位置 , 双击其 top 和 left 尺寸 , 使用鼠标滚轮修改该 盒子模型 绝对定位的位置 ;
- Ctrl + 鼠标滚轮 一次可以增减 100 像素 ;
- Shift + 鼠标滚轮 一次可以增减 10 像素 ;
- 鼠标滚轮 一次可以增减 1 像素 ;
- Alt+ 鼠标滚轮 一次可以增减 0.1 像素 ;
最终得到 , 将 city 布局设置到 北京 位置 , top 属性值为 220 像素 , left 属性值为 562 像素 ;
3、热点动画布局分析
分析 热点动画 , 发现内层的 蓝色实心 小圆圈 是不变的 , 始终都存在 ;
然后放置 2 ~ 3 个 可缩放的原型图片 作为 热点动画的 波纹 ;
页面的布局如下 : 其中的 dot 盒子是 中心小圆点 盒子 , bowen1 ~ bowen3 是三个波纹效果动画盒子 ;
<body><!-- 为 该 div 盒子模型 设置 类名为 map --><div class="map"><!-- 为 该 div 盒子模型 设置 类名为 city --><div class="city"><!-- 该 div 盒子模型 是 中心的 小圆点 --><div class="dot"></div><!-- 该 div 盒子模型 是 波纹 --><div class="bowen1"></div><div class="bowen2"></div><div class="bowen3"></div></div></div>
</body>
4、动画定义
动画实现如下 : 波纹效果动画 , 就是将 盒子模型 的大小 , 逐渐设置到 100 像素 , 中间可以设置若干动画节点 ;
@keyframes bowen {0% {}70% {/* 执行到 70% 时 盒子变为 70 像素宽高 透明度为 0 不可见 */width: 70px;height: 70px;opacity: 1;}100% {/* 放到最大时 盒子变为 100 像素宽高 透明度为 0 不可见 */width: 100px;height: 100px;opacity: 0;}}
5、小圆点实现
小圆点实现 : 小圆点直接通过盒子模型实现 , 该盒子模型 宽高 8 像素 , 设置 50% 圆角 , 将外形设置为圆形 ;
.dot {/* 设置小圆点宽高 */width: 8px;height: 8px;/* 设置小圆点背景颜色 */background-color: #09f;/* 将标签设置为圆形 */border-radius: 50%;}
6、波纹效果盒子实现
波纹效果 盒子 实现 :
- 该盒子始终要放置在 city 盒子中心位置 , 因此使用绝对定位
position: absolute;
设置了top: 50%;
,left: 50%;
, 以及transform: translate(-50%, -50%);
样式 ; - 该盒子模型设置一个 阴影 ,
box-shadow: 0 0 12px #009dfd;
, x , y 轴偏移为 0 , 阴影半径 12 像素 ; - 动画属性设置为
animation: bowen 1.5s linear infinite;
, 使用 bowen 动画 , 持续时间 1.5 秒 , 使用线性函数 , 无限循环播放 ;
.city div[class^="bowen"] {/* city 类下的 div 类型标签 , 类型是以 bowen 开头的标签 *//* 使用绝对定位进行定位 , 子绝父相 , 父容器 相对定位 */position: absolute;/* 绝对定位位置 : 距离顶部的位移 */top: 50%;/* 绝对定位位置 : 距离左侧的位移 */left: 50%;/* 保证 波纹 在 父容器中 垂直 / 水平 居中对齐放大后 , 以中心为终点 向四周发散 */transform: translate(-50%, -50%);/* 设置波纹宽高 , 之后设置其放大 */width: 8px;height: 8px;/* 设置阴影 x , y 轴偏移为 0 , 阴影半径 12 像素 */box-shadow: 0 0 12px #009dfd;/* 设置布局为圆形 , 不要是四方的 */border-radius: 50%;/* 设置动画属性 */animation: bowen 1.5s linear infinite;}
7、延迟动画设置
第二个波纹 和 第三个波纹 的 动画 , 需要延迟 0.5 秒 和 1 秒 执行 ;
注意 选择器 的提权使用 , 之前使用了 .city div[class^="bowen"]
选择器 设置了动画属性 , 如果设置动画延迟属性的选择器优先级低于前者选择器 , 那么设置是无效的 , 因此这里使用了 .city div.bowen2
选择器 进行了提权 ;
.city div.bowen2 {/* 选择器这么写是为了使该选择器 与 .city div[class^="bowen"] 选择器 权限相同否则 该设置 不生效 */animation-delay: 0.5s;}.city div.bowen3 {/* 选择器这么写是为了使该选择器 与 .city div[class^="bowen"] 选择器 权限相同否则 该设置 不生效 */animation-delay: 1s;}
8、代码示例
代码示例 :
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><!-- 设置 meta 视口标签 --><meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>CSS3 动画属性示例 - 地图热点</title><style>body {background-color: #333;}.map {/* 子绝父相 , 子元素使用绝对定位 , 该父容器需要使用相对定位 */position: relative;/* 盒子模型的宽高 就是 背景图片的宽高 */width: 747px;height: 617px;/* 设置背景图片 */background: url(images/map.png);/* 上下外边距设置为 0 , 左右外边距设置为 auto 居中 */margin: 0 auto;}.city {/* 使用绝对定位进行定位 , 子绝父相 , 父容器 相对定位 */position: absolute;/* 绝对定位位置 : 距离顶部的位移 */top: 228px;/* 绝对定位位置 : 距离左侧的位移 */left: 548px;/* 设置白色 , 容易分辨 */color: white;}.dot {/* 设置小圆点宽高 */width: 8px;height: 8px;/* 设置小圆点背景颜色 */background-color: #09f;/* 将标签设置为圆形 */border-radius: 50%;}.city div[class^="bowen"] {/* city 类下的 div 类型标签 , 类型是以 bowen 开头的标签 *//* 使用绝对定位进行定位 , 子绝父相 , 父容器 相对定位 */position: absolute;/* 绝对定位位置 : 距离顶部的位移 */top: 50%;/* 绝对定位位置 : 距离左侧的位移 */left: 50%;/* 保证 波纹 在 父容器中 垂直 / 水平 居中对齐放大后 , 以中心为终点 向四周发散 */transform: translate(-50%, -50%);/* 设置波纹宽高 , 之后设置其放大 */width: 8px;height: 8px;/* 设置阴影 x , y 轴偏移为 0 , 阴影半径 12 像素 */box-shadow: 0 0 12px #009dfd;/* 设置布局为圆形 , 不要是四方的 */border-radius: 50%;/* 设置动画属性 */animation: bowen 1.5s linear infinite;}.city div.bowen2 {/* 选择器这么写是为了使该选择器 与 .city div[class^="bowen"] 选择器 权限相同否则 该设置 不生效 */animation-delay: 0.5s;}.city div.bowen3 {/* 选择器这么写是为了使该选择器 与 .city div[class^="bowen"] 选择器 权限相同否则 该设置 不生效 */animation-delay: 1s;}@keyframes bowen {0% {}70% {/* 执行到 70% 时 盒子变为 70 像素宽高 透明度为 0 不可见 */width: 70px;height: 70px;opacity: 1;}100% {/* 放到最大时 盒子变为 100 像素宽高 透明度为 0 不可见 */width: 100px;height: 100px;opacity: 0;}}</style>
</head><body><!-- 为 该 div 盒子模型 设置 类名为 map --><div class="map"><!-- 为 该 div 盒子模型 设置 类名为 city --><div class="city"><!-- 该 div 盒子模型 是 中心的 小圆点 --><div class="dot"></div><!-- 该 div 盒子模型 是 波纹 --><div class="bowen1"></div><div class="bowen2"></div><div class="bowen3"></div></div></div>
</body></html>
执行效果 :