适合初学者学习的CSS3实现可爱的动物

适合初学者学习的CSS3实现可爱的动物

适合初学者学习的CSS3实现可爱的动物

今天,我想向大家展示如何巧妙地使用HTML、CSS排序动画和SVG滤镜把生活中可能最可爱的东西之一——动物画到网页上。我们将探讨绘制动物的两种技术:一种使用纯HTML和CSS,另一种使用内联SVG背景图像。

此演示高度实验性质——动画SVG滤镜目前仅在Chrome中可用。

所涉及的动画也很复杂,因此本教程将重点介绍创建这些动物以及栩栩如生的动作所涉及的不同技术。放飞你的创意,自行创作独特和俏皮的动物动画吧。

话不多说,开始咯!

立即学习“前端免费学习笔记(深入)”;

适合初学者学习的CSS3实现可爱的动物

塑造动物外形

演示使用两种不同的技术来创建动物不同身体部位的形状。哈士奇使用CSS border-radius属性,狐狸使用内联背景SVG图像,因为后者的形状更复杂。

HTML标记

两只动物都使用嵌套的HTML部分对身体部位进行分组。分组的概念对于创造逼真的动画效果非常重要——当头部移动时,眼睛和耳朵也应该保持一起移动,因为它们是长在头上的。

  

                

      

      

        

    

    

    

  

  

  

  

    

    

    

    

      

      

      

登录后复制

每个部分均可以独立移动,并随着其父元素的移动而移动,这样会产生更逼真的效果。不知道你发现没有,尾巴是深深嵌套到其他尾部组件中的。当每个尾巴部分相对于其母体定位,然后旋转相同的量时,就会产生均匀曲线的视觉感。

适合初学者学习的CSS3实现可爱的动物

用CSS塑造图形

CSS的border-radius属性大量用来塑造哈士奇的形象。对于许多元素要素,需要对每个边界半径进行逐个控制。例如,下面是如何构造哈士奇后腿的代码:

.husky-hind-leg {  // ...  border-top-left-radius: 35% 100%;  border-top-right-radius: 40% 100%;}

登录后复制

第一个数字表示曲线从顶部/底部边缘开始的深度,第二个数字表示曲线从左/右边缘开始的深度。

其他形状,如前腿,不能单独用border-radius成形,需要使用transform成形:

.husky-front-legs > .husky-leg:before {  transform: skewY(-30deg) skewX(10deg);  transform-origin: top right;}

登录后复制

一旦图形就位,那么每个元素就能在其父元素中被赋予绝对的基于百分比的位置。这确保每个身体部位的精确放置以及响应性。

用SVG塑造图形

至于狐狸,Sass-SVG被用来为每个身体部位创建复杂的SVG形状。SVG图像可以用作背景图像,更好的是,只要它们是基于64或UTF-8编码的,就可以被内联编写(为了最大限度的浏览器支持)。

不过,SVG代码手写起来非常棘手。我使用Adobe Illustrator来创建初始形状:

适合初学者学习的CSS3实现可爱的动物

然后我将每个身体部分保存为SVG图像。SVG代码通过Sass-SVG传输到SCSS样式表。例如,这是狐狸的鼻子:

.fox-nose:before {  @include svg((viewBox: (0 0 168 168))) {    // the nose    @include svg('path', (      fill: $color-nose,      d: 'M83.7,86.7c3.3,0,11.6-3.9,11.6-7.1c0-3.2-9.4-3.2-11.6-3.2c-2.2,0-11.6,0-11.6,3.2   C72.1,82.8,80.4,86.7,83.7,86.7z'    ));    // the line connecting the nose to the mouth    @include svg('path', (      stroke: $color-nose,      fill: none,      d: 'M83.7,102.3V86.7'    ));    // the mouth    @include svg('path', (      stroke: $color-nose,      fill: none,      d: 'M94.5,104.9c0,0-5.2-2.7-10.8-2.7c-5.6,0-10.8,2.7-10.8,2.7'    ));  }}

登录后复制

这将在`url()`中生成一个编码的内联SVG字符串,看起来像这样:

.fox-nose:before {  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg...");}

登录后复制

由于SVG是一个背景图像,因此它可以被转换和动画化,就像一个HTML元素一样。使用Sass-SVG,Sass $variables可用于完全控制SVG填充和笔触颜色。

通过内联SVG使狐狸响应起来很简单。viewbox属性值((viewBox:(0 0 168 168)))直接来自SVG文件,但只要保持高/宽比率,那么包含SVG背景图像的元素可以是任意大小。狐狸头部的所有部分都是绝对定位的,具有与.fox-head相同的高度和宽度。

“Squigglevision”和SVG滤镜

Squigglevision是一种通过摆动形状轮廓来模拟手绘动画的动画技术。这使得像狐狸和哈士奇这样的场景看上去更加动态化和手绘化,即使动物在不动的时候也是如此。

SVG有一个称为的滤镜,可以给任何应用了此滤镜的地方“噪声”。结合滤镜以指定像素在每个过滤器中移动的距离。

                                                                                 

登录后复制

属性的任何元素。要创建“squigglevision”效果,关键帧动画快速地一次设置一个滤镜

@keyframes squigglevision {  0% {    -webkit-filter: url('#squiggly-0');    filter: url('#squiggly-0');  }  25% {    -webkit-filter: url('#squiggly-1');    filter: url('#squiggly-1');  }  50% {    -webkit-filter: url('#squiggly-2');    filter: url('#squiggly-2');  }  75% {    -webkit-filter: url('#squiggly-3');    filter: url('#squiggly-3');  }  100% {    -webkit-filter: url('#squiggly-4');    filter: url('#squiggly-4');  }}

登录后复制

注意:这些SVG滤镜目前在Firefox中似乎不起作用,因此可以将这样的滤镜动画视为一种渐进增强处理。

给动物添加动画特效

CSS关键帧不能为我们提供一种方便的排序和组合动画的方法。解决这个问题的最好方法是将动画计划(故事板)作为时间轴,并使用预处理器,如Sass,生成关键帧。

例如狐狸,在概述每个动画应发生的故事板之后,转换和绝对时间偏移(秒)被用于对每个身体部分进行动画处理。以下是SCSS中对狐狸鼻子进行概述的一个例子:

$animations: (  // ...  'nose': (    // resting position    (4s, 5s, 7s): rotateY(-4deg),    // nose down    4.5s: rotateY(-4deg) rotateX(-3deg),    // fox looks left    (7.5s, 9s): rotateX(-3deg) rotateY(-28deg) rotateZ(-11deg),    // fox looks right    (9.5s, 12s): rotateY(7deg),    // fox looks straight ahead    13s: rotateY(0),  ),  // ...);

登录后复制

在这里,$animations是一类Sass map,其中键是动画的名称(例如“nose”)。每个动画名称的值是另一个map,其中键是以秒为单位的偏移或偏移列表(例如(7.5s,9s)),并且值是每个偏移键的transform属性。

那么,我们怎么把这个map变成@keyframe动画呢?首先,设置全局的$duration: 17s变量——这将是每个动画的总持续时间。然后,使用嵌套的Sass @each … in … 循环,我们可以通过对$animations map循环为每个动画生成预期的CSS @keyframe声明:

@each $animation-name, $animation in $animations {  // keyframe declaration  @keyframes #{$animation-name} {    @each $offsets, $transform in $animation {      @each $offset in $offsets {        // offset declaration block            #{percentage($offset / $duration)} {          // transform property          transform: #{$transform};        }      }    }  }}

登录后复制

这将生成如下所示的关键帧:

@keyframes nose {  14.70588% {    transform: rotateY(-4deg); }  23.52941% {    transform: rotateY(-4deg); }  29.41176% {    transform: rotateY(-4deg); }  41.17647% {    transform: rotateY(-4deg); }  26.47059% {    transform: rotateY(-4deg) rotateX(-3deg); }  44.11765% {    transform: rotateX(-3deg) rotateY(-28deg) rotateZ(-11deg); }  52.94118% {    transform: rotateX(-3deg) rotateY(-28deg) rotateZ(-11deg); }  55.88235% {    transform: rotateY(7deg); }  70.58824% {    transform: rotateY(7deg); }  76.47059% {    transform: rotateY(0); } }

登录后复制

在不使用SCSS的情况下,这些百分比的计算可能非常繁琐。它们代表动画的每个步骤中每个所需时间值相对于总$duration的百分比偏移量。

然后可以将动画应用于它们各自的身体部位,例如animation: nose $duration none infinite;。每个动画的持续时间都得是一样的,这样它们可以无缝循环。

逼真的Easing Curves

制作动画的另一个重要组成部分是看上去要逼真,所以要为动画的每个部分仔细选择(或创建)Easing Curves。最为生动的Easing Curves是“正弦曲线”——换句话说,是平滑起伏的Easing Curves。这样一来,自然动作就不会僵硬地起动或停止,animation-timing-function应该能反映出来。

对于狐狸和哈士奇,我使用cubic-bezier(0.645, 0.045, 0.355, 1)(在这里预览)。此曲线(见下文)开始略快,然后平稳地停住。当然,最好试验曲线以找到最适合动画的那种。

适合初学者学习的CSS3实现可爱的动物

最后:在Chrome中,你可以直观地检查所有排序的动画,以确保它们在正确的时间发生。你只需打开控制台,单击Style选项卡,然后单击播放按钮即可:

希望本教程可以帮助启发你创建更多的序列CSS动物动画!

更多相关知识,请访问 PHP中文网!!

以上就是适合初学者学习的CSS3实现可爱的动物的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2885647.html

(0)
上一篇 2025年3月10日 20:42:03
下一篇 2025年3月7日 20:50:27

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • CSS3 实现响应式手风琴

    最近看了国外大佬用CSS3实现手风琴效果的视频,所以自己学习后写了一下,以博客的形式记录下来,方便自己日后复习,代码结构如下(字体用的是Genericons ): 视屏教程推荐:《CSS视频教程-玉女心经版》 最终效果如下: 全屏时: 屏幕…

    2025年3月10日 编程技术
    200
  • css3 如何实现进度条效果

    项目过程中,开始使用了js的requestAnimationFrame方法实现进度条,但是在数据超级多的时候非常影响性能,如此改用css去实现,优化。 先贴代码: nbsp;html>                Document …

    2025年3月10日
    200
  • css3新增伪类有哪些

    css3新增伪类有:1、【p:first-of-type】;2、【p:last-of-type】;3、【p:only-of-type】;4、【p:only-child】;5、【p:nth-child(2)】。 (推荐教程:css快速入门) …

    2025年3月10日
    200
  • css3如何画出小黄人并实现动画效果?(代码示例)

    css3如何画出小黄人?下面本篇文章给大家介绍一下使用css画出小黄人并实现动画效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 首先来看看效果图(小黄人动画) 怎么样?虽然手脚动画还是不怎么神似,但人类聪明地大…

    2025年3月10日 编程技术
    200
  • CSS3变形-旋转实现4色花-案例解析(代码实例)

    本文目标: 1、掌握css3中如何让元素旋转 问题: 1、实现以下效果,且使用纯DIV+CSS 附加说明: 1、带蝴蝶的粉色圆圈是一张图片 立即学习“前端免费学习笔记(深入)”; 2、中间的“4色花”是由4个半圆通过旋转生成的,每个半圆的直…

    2025年3月10日
    200
  • 详解CSS3实现弹性布局的方式

    一、CSS3弹性盒子 弹性盒子是CSS3的一种新布局模式。 CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式。 引入弹性盒布局模型的目的是提…

    2025年3月10日 编程技术
    200
  • CSS3如何实现图片木桶布局?(附代码)

    本篇文章给大家通过代码示例介绍一下使用css3实现图片木桶布局的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 高度相同,而宽度不一样的布局,称之为木桶布局。它有几个鲜明的特点: 每行的图片高度一致;每行的图片都是占…

    2025年3月10日
    200
  • 九款纯CSS3绘制的复古相机特效代码

    本篇文章给大家分享九款纯css3绘制的复古相机特效代码。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 先看看制作出来的效果图: PS:  有人会说,这些东西实用性不强,没啥用。一开始我也是这么觉得,但后来我就改变自己的看…

    2025年3月10日 编程技术
    200
  • css3中过渡和动画的区别是什么

    css3中过渡和动画的区别是:过渡需要触发一个事件才会随着时间改变其CSS属性;动画在不需要触发任何事件的情况下,也可以随时间变化来改变元素CSS属性。 animation属性类似于transition,他们都是随着时间改变元素的属性值,其…

    2025年3月10日
    200
  • css3中让图像居中可以使用哪个元素

    css3中让图像居中可以使用【align-items:center】元素和【justify-content:center】元素。align-items属性定义flex子项在flex容器的当前行的纵轴方向上的对齐方式。 方法: 采用 alig…

    2025年3月10日
    200

发表回复

登录后才能评论