CSS动效集锦,视觉魔法的碰撞与融合(三)

本文讲述的原理和相关demo

  • 扇形DIV的使用——实现雷达扫描图
  • DIV环形布局—实现loading圈
  • 动画的向量合成—实现抛物线动画
  • 无限滚动动画—实现跑马灯效果
  • perspective和transform的运用——实现卡片翻转

话不多说,请看。

扇形DIV的使用——实现雷达扫描图

在一些杀毒或文件扫描类的软件上,我们可能会看到一些雷达扫描的UI样式,例如下图所示

如果我们要通过CSS该如何去实现话,我们的想法一般是先画个扇形,然后给它加上渐变。

实现渐变的方式很简单,但我们该如何实现一个扇形呢?

我们可以通过一些技巧实现这一点,请看:

没错,我们可以通过skew函数,将黄色的div倾斜,然后溢出部分通过overflow:hidden遮住就可以了。

  • 锐角扇形:deg<0,向右边倾斜,即可得到锐角扇形
  • 钝角扇形:deg>0, 向左边倾斜,即可得到钝角扇形

代码如下

// CSS代码
@keyframes rotateAnimate {
  from {
    transform: rotate(0deg) skew(-30deg)
  }

  to {
    transform: rotate(360deg) skew(-30deg)
  }
}

.fan-wrapper {
  overflow: hidden;
  position: relative;
  margin: 100px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: red;
}

.fan {
  position: absolute;
  right: 0;
  animation: rotateAnimate 2s linear infinite;
  /* 这一行很重要,设置左下角为旋转点 */
  transform-origin: 0% 100%;
  width: 100px;
  height: 100px;
  background: blue;
}
 // HTML代码
 <div class="fan-wrapper">
  <div class="fan"></div>
</div>

实现效果如下图所示

(因为篇幅有限,渐变就不加了2333)

DIV环形布局—实现loading圈

loading加载条是常见的一种UI组件,如下图所示

而要实现它,就需要考虑怎么把一堆小圆等距地布局在一个“大圆”的边框上,也就是DIV的环形布局的问题。

当然我们可以通过暴力测量解决,但很麻烦且不优雅,而且如果小圆的数量变化的话要重新测一遍。

我的解决办法如下:

第一步:根据圆的数量计算相邻圆和圆心形成的夹角

例如假设我们需要排列8个圆,那么夹角为360度 / 8 = 45度。图示如下,每个数字代表以该位置为圆心放一个小圆

第二步:以外部DIV左下角为原点,批量计算小圆圆心的横纵坐标

批量算出所有圆的相对坐标,我们以编号8的圆为例,假设半径R和X轴的逆时针夹角为θ,则有以下等式

(cos/sin可能有正负,而等式同样成立)

第三步,外部div相对定位,内部小圆绝对定位,并且将步骤二中计算的X/Y作为小圆的bottom和left去设置

这一步也是批量完成,下图以编号8的圆为例

代码

CSS/HTML代码如下:

我们在一个父div内部放8个子div。父div相对定位,而子div绝对定位

// CSS代码
.circles {
  position: relative;
  margin: 50px;
  width: 200px;
  height: 200px;
}

.circle {
  position: absolute;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: black;
}
 // HTML
<div class="circles">
  <div class="circle circle1"></div>
  <div class="circle circle2"></div>
  <div class="circle circle3"></div>
  <div class="circle circle4"></div>
  <div class="circle circle5"></div>
  <div class="circle circle6"></div>
  <div class="circle circle7"></div>
  <div class="circle circle8"></div>
</div>

JS代码如下

第一步:编写calcXYs方法: 以外部DIV左下角为原点,批量计算小圆圆心的横纵坐标

/**
 * R:大圆半径,2*R = 外部正方形的边长
 * r:在大圆边上等距排列的小圆的半径
 * counts: 圆的数量
 * 返回值:
 *  [
 *    [x1,y1],
 *    [x2,y2],
 *    ...
 *  ]
 */
function calcXYs(R, r, counts) {
  // 当前度数
  let deg = 0;
  // 单位度数,两小圆和圆心的夹角
  const pDeg = 360 / counts;
  // 存放返回结果
  const arr = [];
  for (let i = 0; i < counts; i++) {
    // 度数以单位度数递增
    deg = pDeg * i;
    // Math.sin接收的参数以 π 为单位,需要根据360度 = 2π进行转化
    const proportion = Math.PI / 180;
    // 以外部DIV左下角为原点,计算小圆圆心的横纵坐标
    let Y = R + R * Math.sin(proportion * deg);
    let X = R + R * Math.cos(proportion * deg);
    // 存放结果
    arr.push([X, Y, deg]);
  }
  return arr;
}
 

第二步:编写resizeCircles方法: 根据上一步的结果:调整绝对定位的小圆的位置

/**
 * R,r,counts:含义同上
 * selector: 获取所有小圆的标志符
 * 作用:根据上一步的坐标计算结果,调整绝对定位的小圆的位置
 */
function resizeCircles(selector, R, r, counts) {
  // 获取所有小圆NodeList的选择器
  let list = document.querySelectorAll(selector);
  //调用calcXYs方法
  const XYs = calcXYs(R, r, counts);
  // 遍历每个小圆的XY坐标
  for (let i = 0; i < list.length; i++) {
    const [X, Y] = XYs[i];
    const e = list[i];
    // 修改小圆距离外部DIV底部和左边的距离
    e.style.left = X + "px";
    e.style.bottom = Y + "px";
  }
}
 

最后我们只需要调用resizeCircles方法就可以啦

resizeCircles(".circle", 60, 20, 8);

实现效果如下

让loading图标动起来

好,现在布局完成了,那我们该怎么去让这个loading图标“动起来”呢?

  1. 给每个圆设置animation实现明暗变化,例如可以设置黑色的背景色然后动态变化opacity
  2. animation属性可以设置delay实现动画延迟播放,我们依次给圆设置等距的delay,例如1s,2s,3s...
  3. 给animation属性设置alternate,表示往复播放,设置infinite,表示无限循环播放
@keyframes k {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}
.circle1 {
  animation: k 1s ease 0s alternate infinite;
}

.circle2 {
  animation: k 1s ease 0.2s alternate infinite;
}

.circle3 {
  animation: k 1s ease 0.4s alternate infinite;
}
// circle4 ~ circle8同理,delay以0.2s递增

Demo

动画的向量合成—实现抛物线动画

在饿了么,或者淘宝天猫之类的购物外卖相关的APP里,我们可能会看到类似于下面这种的抛物线的动画。

如果要实现这种平抛效果,需要一点基础的高中物理知识。

平抛运动由水平方向的两种运动合成而得到

  • 水平方向: 匀速直线运动
  • 垂直方向:初速度为0的匀加速直线运动

如下所示

如果我们通过图像捕捉的方式就可理解的更清楚了,从下面的图可以看到:

水平方向的速度是不变的,而垂直方向的速度是不断加快的

好,下面终于可以讲下CSS的实现思路了

CSS实现原理

  1. 设置两个div:外层div和内层div
  2. 外层div设置横向匀速运动的动画
  3. 内层div设置纵向的匀加速直线运动的动画,加速过程可以用cubic-bezier设置

cubic-bezier又叫做贝塞尔曲线,它可接收四个参数,来规定动画的速度变化过程,使用方法如下

transition-timing-function: cubic-bezier(0.1, 0.7, 1.0, 0.1);

我们可以通过下面这个官方网站去设置速度变化曲线,然后获取生成的四个参数

https://cubic-bezier.com/

具体代码如下:

 // HTML
<div id="outer">
  <div id="inner"></div>
</div>
<button id=‘btn‘>抛物线效果</button>
// CSS
#outer {
  transition: all 1.5s linear;
}

#inner {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: red;
  transition: all 1.5s cubic-bezier(.54, .11, .95, .68);
}

.outer-active {
  transform: translateX(300px);
}

.inner-active {
  transform: translateY(300px) scale(0.3);
}
JS
document.getElementById("btn").onclick = function() {
  document.getElementById("outer").classList.add("outer-active");
  document.getElementById("inner").classList.add("inner-active");
};

效果如下

无限滚动动画—实现跑马灯效果

当文本过长时候,我们可能需要做成跑马灯效果,然后无限滚动播放。

因为marquee这个HTML元素被废弃了,所以一般情况下我们需要手动通过动画去实现跑马灯

实现图示如下,注意开始位置和结束位置是不可见的

// HTML
<div class="marquee">
  <p>ABCDEFGHIJKLMN</p>
</div>
// CSS
@keyframes marquee {
  from {
    transform: translateX(-200px)
  }

  to {
    transform: translateX(200px)
  }
}

.marquee {
  overflow: hidden;
  margin: 100px;
  width: 200px;
}

.marquee p {
  animation: marquee 3s linear infinite;
}

结果

perspective和transform的运用——实现卡片翻转

卡片翻转三要素

  • transform: rotateY(x deg) 翻转卡片
  • backface-visibility:hidden 翻转后隐藏背面,重要!必须要加
  • perspective:增加透视和立体效果
// HTML
<div id="img-wrapper">
  <img src=‘./timg.jpg‘ id=‘img1‘ class="img disable-img1" />
  <img src=‘./timg2.jpg‘ id=‘img2‘ class="img" />
</div>

// CSS
#img-wrapper {
  perspective: 1200px;
  position: relative;
  height: 479px;
}

#img1,
#img2 {
  position: absolute;
  transition: all 1s linear;
  backface-visibility: hidden;
}

#img1 {
  transform: rotateY(-180deg);
}

#img-wrapper:hover #img1 {
  transform: rotateY(-360deg);
}

#img-wrapper:hover #img2 {
  transform: rotateY(-180deg);
}
 

结果

原文地址:https://www.cnblogs.com/penghuwan/p/12239817.html

时间: 2024-07-29 21:45:00

CSS动效集锦,视觉魔法的碰撞与融合(三)的相关文章

CSS动效集锦,视觉魔法的碰撞与融合(二) - 知乎

原文:CSS动效集锦,视觉魔法的碰撞与融合(二) - 知乎 引言 长久以来,我认识到.CSS,是存在极限的.正如曾经替你扛下一切的那个男人,也总有他眼含热泪地拼上一切,却也无法帮你做到的事情,他只能困窘地让你看到他的无能为力,怅然若失. 然后和曾经他成长的时代,做一一告别. CSS有他难以做到的事情,我们帮他用lottie解决 CSS有他可以做到的事情,我们用我们的头脑帮他解决 本文实现的CSS效果一览 标题吸顶 手写箭头 文字背景 圆形天坑 按钮波澜 动态方形 加载骨架 多行省略 标题吸顶 s

【CSS】CSS特效集锦,视觉魔法的碰撞与融合(一)

原文:[CSS]CSS特效集锦,视觉魔法的碰撞与融合(一) 目录 前言 一.浮光掠影 二.发光球体 三.圆环进度条 四.三角形 五.有色到透明的渐变 六.模糊效果和毛玻璃效果 七.斜角标签 技术总结 知乎主页和专栏 正文 回到顶部 前言 在本文中我讲述了7种CSS的特效,它们也许看起来并不惊艳,但是我认为却足够传达本文的理念:编写一些特殊的CSS样式的时候需要不拘于常理,要用特殊的认识角度看待标签和样式属性,从而用「绕个弯」的方式达到效果. 回到顶部 一.浮光掠影 首先我们看第一个实现效果:在鼠

CSS实现一个粒子动效的按钮

原文链接 github.com/XboxYan/not… 按钮(button)可能是网页中最常见的组件之一了,大部分都平淡无奇,如果你碰到的是一个这样的按钮,会不会忍不住多点几次呢? 通常这类效果第一反应可能就是借助canvas了,比如下面这个案例 效果就更加震撼了,当然canvas实现也有一定的门槛,而且实际使用起来也略微麻烦(所有js实现的通病),这里尝试一下CSS的实现方式. 生成粒子 抛开js方案,还有HTML和CSS实现方式.HTML就不用说了,直接写上大量的标签 <button>

iOS 停止不必要的UI动效设计

http://www.cocoachina.com/design/20151124/14400.html 前言:这篇短文将会探讨UI设计中动画的过度使用,并将其与早期的视觉设计进行对比,提出一些对于有效的GUI动效设计的建议. 我们将在下文中,简单探讨如何改善下面的这个交互. UI动效设计的反面案例(线上Demo) 注:这个反面案例并非假设,而是来自近期的真实客户案例. 概述 自从 70.80 年代首个光栅图像在CRT屏幕出现以来,人们对于(数字)视觉设计的态度一直在不断进化.与其他艺术领域不同

box-shadow的动效制作

突然发现原来box-shadow的功能很强大,还能做动效,下面整理下box-shadow几个效果 案例1:hover效果 <a href="/app/list">WEB小应用</a> css: #list_nav li a { height: 38px; display: block; width: 150px; background: #FFF; margin: 10px; text-decoration: none; border: 1px solid #2

css动画库

转载自:http://www.cnblogs.com/starof/p/4968769.html 本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4968769.html有问题欢迎与我讨论,共同进步. 一.animates.css animate.css是来自dropbox的工程师Daniel Eden开发的一款CSS3的动画效果小类库.包含了60

转:玩转HTML5移动页面(动效篇)

作为一名前端,在拿到设计稿时你有两种选择: 1.快速输出静态页面 2.加上高级大气上档次狂拽炫酷屌炸天的动画让页面动起来 作为一个有志向的前端,当然是选2啦!可是需求时间又很短很短,怎么办呢? 这次就来谈谈一些动画设计的小技巧,能在你时间不多又没有动画想法的时候瞬间让页面增色不少. 同时也会谈及移动端H5页面的优化细节与关键点,因此本文章将分为动效篇和优化篇. ====前方高能==== (1)  CSS3时序错开渐显动画 这是一种比较常用的动画,它的优点是节奏感强,做法就是先让每个元素隐藏,然后

玩转HTML5移动页面(动效篇)(转载)

作为一名前端,在拿到设计稿时你有两种选择: 1.快速输出静态页面 2.加上高级大气上档次狂拽炫酷屌炸天的动画让页面动起来 作为一个有志向的前端,当然是选2啦!可是需求时间又很短很短,怎么办呢? 这次就来谈谈一些动画设计的小技巧,能在你时间不多又没有动画想法的时候瞬间让页面增色不少. 同时也会谈及移动端H5页面的优化细节与关键点,因此本文章将分为动效篇和优化篇. ====前方高能==== (1)  CSS3时序错开渐显动画 这是一种比较常用的动画,它的优点是节奏感强,做法就是先让每个元素隐藏,然后

基于clip-path的任意元素的碎片拼接动效(源自鑫空间)

一.实现原理. 效果本质上是CSS3动画,就是旋转transform:rotate和位移:transform:translate,只是旋转和位移的部件是三角碎片而已.三角是使用CSS3 clip-path剪裁出来的. JS把元素剪裁成一个个等腰直角三角形,然后随机分布在四周,然后通过CSS3 animation动画,让所有的在四周的元素归位就可以了. 于是,核心CSS如下: .clip[style] { opacity: 0; } .active .clip[style]{ will-chang