纯CSS3实现3d立体文字效果(源码分析)

本篇文章带大家了解一下3d文字效果的实现原理,没有考虑代码的复用性和可移植性,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

纯CSS3实现3d立体文字效果(源码分析)

1.单单纯纯的效果一

纯CSS3实现3d立体文字效果(源码分析)

为了简化操作,我们使用和上一篇文章《纯CSS3文字效果推荐》一样的文档结构,后面的效果大差小不差,也就不再列出。

前端开发whqet

css里面还是首先来全局的设置,依然和上一篇文章大差小不差,不过为了避免视觉疲劳,我们修改了背景颜色和文字颜色。

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

body{    background-color: #666;  }  @import url(http://fonts.googleapis.com/css?family=Dosis:500,800);  .text {      font-family:"微软雅黑", "Dosis", sans-serif;      font-size: 80px;      text-align: center;      font-weight: bold;      line-height:200px;      text-transform:uppercase;      position: relative;  }

然后是简单单纯的效果一的核心代码

/*简单单纯的效果一*/.effect01{    background-color: #7ABCFF;    color:#FFD300;    text-shadow:        0px 0px 0 #b89800,         1px -1px 0 #b39400,         2px -2px 0 #ad8f00,         3px -3px 0 #a88b00,         4px -4px 0 #a38700,         5px -5px 0 #9e8300,         6px -6px 0 #997f00,         7px -7px 0 #947a00,         8px -8px 0 #8f7600,         9px -9px 0 #8a7200,         10px -10px 0 #856e00,         11px -11px 0 #806a00,         12px -12px 0 #7a6500,         13px -13px 12px rgba(0, 0, 0, 0.55),         13px -13px 1px rgba(0, 0, 0, 0.5);}

从中我们可以看出,利用text-shadow实现立体效果的要素有三:

设置多个阴影实现纵深感,阴影的水平和垂直偏移变化实现方向感,阴影的颜色渐变实现错落感。

这种实现的方式虽说单纯,但是可移植性不强、复用性差,试想一下,不同方向的立体字如何修改?不同颜色的立体字如何实现?逐字实现不同效果肿么办?如果需要动画又如何?

接下来,通过逐步完善“单纯”的效果一,我们来一一解答这些疑问。

2.对“单纯”说不的效果二,sass实现3d文字mixin

纯CSS3实现3d立体文字效果(源码分析)

童鞋们就说了,哥,变化呢,好像跟前面那个没区别呀?大家且耐心,看看代码就明白了。

我用sass写了一个text 3d的mixin,利用这个mixin我们可以轻松控制,立体字的纵深感、方向感、错落感。

/*  对“单纯”说不的效果二,  sass实现的华丽转身  */ /*** 利用text-shadow实现3d文字效果** $color     立体字的初始颜色* $dx        立体字水平偏移位置,dx>0,向右偏,建议取值[-2,2]* $dy        立体字垂直偏移位置,dy>0,向下偏,建议取值[-2,2],dx和dy配合控制立体字的方向* $steps     立体字的层叠数量* $darken    立体字的颜色变暗数值,建议取值[0,1],需要结合层叠数量,避免过多的黑色出现* @copyright 前端开发whqet,http://blog.csdn.net/whqet */@mixin text3d($color: #ffd300, $dx: 1, $dy: -1,$steps:10, $darken:.1) {  color:$color;  $color:darken($color,30%);   $output: '';  $x:0px;  $y:0px;  @for $n from 1 to $steps{    $output: $output + '#{$x} #{$y} 0 #{$color},';    $x:$x+$dx;    $y:$y+$dy;    $color:darken($color, $darken * ($n+10));  }  $output: $output+'#{$x} #{$y} 12px rgba(0,0,0,0.3),#{$x} #{$y} 1px rgba(0,0,0,0.5);';    text-shadow:unquote($output);} .effect02{    @include text3d(#00d3ff,1,-1,15,.05);}

肿么样,大家仔细研究啦,利用sass实现的这个mixin,我们可以非常简单的实现立体字,并且可以搞起来动画,请看效果三。

3.“多动”的效果三,animation让阴影动起来

纯CSS3实现3d立体文字效果(源码分析)

有了效果二中的mixin,效果三就自然而然了。

/*  “多动”效果三, 加上动画 */.effect03{  animation:animateShadow 2s linear infinite; }@keyframes animateShadow{    0% {@include text3d(#00d3ff,1,1,15,.05); }  25% {@include text3d(#00d3ff,-1,-1,15,.05); }  50% {@include text3d(#00d3ff,1,1,15,.05); }  75% {@include text3d(#00d3ff,-1.5,1.5,15,.05); }}

4. 彰显“个性”的效果四,lettering.js实现逐字控制

纯CSS3实现3d立体文字效果(源码分析)

lettering.js是一个功能强大的jquery插件,可以把字符串拆分,类似于下面代码所示。

前端开发whqet
whqet

我们需要在页面里导入jquery.js和lettering.js,然后,我们就可以使用了。

//JS is only used to keep the HTML markup clean$(".effect04").lettering();

然后,利用sass实现个性化控制, adjust-hue生成连续色相的颜色,@for循环实现遍历。

/*   彰显“个性”的效果四,lettering.js实现逐字控制 */.effect04{  letter-spacing:.1em;}$base:#FFD300;@for $i from 1 through 9 {  .effect04 .char#{$i} {     @include text3d(adjust-hue($base, $i *15deg),-1,1,10,.05)  }}

5. “个性”升级的效果五,彩虹字动画

纯CSS3实现3d立体文字效果(源码分析)

/*   “个性”升级的效果五,彩虹字 */@for $i from 1 through 10 {  .effect05 .char#{$i} {     animation: rainbow 2s linear infinite;    animation-delay: 0.1s * $i;  }}$base2:#7E00FF;@keyframes rainbow {  @for $i from 0 through 10 {    #{$i* 10%}  {@include text3d(adjust-hue($base2, $i *36deg), 1, 1, 10,.1); }  }}

6.text-shadow IE9-的解决方案

当然,不幸的是直到IE10,text-shadow才得到了比较完善的支持,那么IE9-怎么办呢,尤其是在xp的狂热爱好的中国。所幸IE自带的滤镜可以达到一样的效果,所以就有了这个text-shadow polyfill,我们这里使用sass的方式来补丁text-shadow.

这样的话针对ie9以下的浏览器,我们的text3d mixin要这样修改

/*** 利用text-shadow实现3d文字效果** $color     立体字的初始颜色* $dx        立体字水平偏移位置,dx>0,向右偏,建议取值[-2,2]* $dy        立体字垂直偏移位置,dy>0,向下偏,建议取值[-2,2],dx和dy配合控制立体字的方向* $steps     立体字的层叠数量* $darken    立体字的颜色变暗数值,建议取值[0,1],需要结合层叠数量,避免过多的黑色出现* @copyright 前端开发whqet,http://blog.csdn.net/whqet */@mixin text3d($color: #ffd300, $dx: 1, $dy: -1,$steps:10, $darken:.1) {  color:$color;  $color:darken($color,30%);   $output: '';  $x:0px;  $y:0px;  @for $n from 1 to $steps{    $output: $output + '#{$x} #{$y} 0 #{$color},';    $x:$x+$dx;    $y:$y+$dy;    $color:darken($color, $darken * ($n+10));  }  $output: $output+'#{$x} #{$y} 12px rgba(0,0,0,0.3),#{$x} #{$y} 1px rgba(0,0,0,0.5);';    //for the mordern browser  //text-shadow:unquote($output);    //just for ie9-,这里做了修改  @include jquery-text-shadow(unquote($output));}

Enjoy it.

案例效果还是在codepen:在线研究:http://codepen.io/whqet/pen/eGuqf

更多编程相关知识,请访问:编程视频!!

以上就是纯CSS3实现3d立体文字效果(源码分析)的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 07:05:25
下一篇 2025年12月24日 07:05:42

相关推荐

  • css3如何设置背景图片

    css3设置背景图片的方法是添加属性【background-image: url(css.jpg)】。background-image属性用来设置一个元素的背景图像,url中填写图像的url地址。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 如果我们要添加一张…

    2025年12月24日
    000
  • 使用css过渡有哪些触发方式

    触发方式有:1、通过伪类元素“:hover”触发,语法“元素{transition:属性 过渡时间}元素:hover{属性:属性值}”;2、通过“element.classList.add(“元素名称”)”语句触发css过渡效果。 本教程操作环境:windows7系统、CSS…

    2025年12月24日
    000
  • css3新增的伪类有哪些

    css3伪类:“:first-of-type”、“:last-of-type”、“:only-of-type”、“:only-child”、“:nth-child(2)”、“:enabled”、“:disabled”、“:checked”。 本教程操作环境:windows7系统、CSS3版、Dell…

    2025年12月24日
    000
  • 如何判断浏览器是否支持css3

    判断方法:1、使用“@supports”规则判断,语法格式“@supports(属性:值){标签名称{属性:值}}”2、使用“CSS.supports()”函数判断,语法格式“CSS.supports(“属性”,”值”)”。。 本教程操作环境:wind…

    2025年12月24日
    000
  • css3动画如何停止

    在css中,可以使用animation-play-state属性控制动画的暂停,语法“animation-play-state:paused”;该属性在不同浏览器的兼容性不同,需加上对应前缀(如“-ms-”,“ -webkit-”等)。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日 好文分享
    000
  • CSS3三角形如何实现不断放大

    本文给大家介绍css3三角形如何实现不断放大。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 CSS3三角形不断放大特效 图片预览 index.html代码 立即学习“前端免费学习笔记(深入)”; CSS3三角形不断放大特效 style.css代码 html {height: 10…

    2025年12月24日
    000
  • css3支持为网页添加多个背景图片吗

    css3支持为网页添加多个背景图片。在css中,可以通过直接在background-image属性中指定多个背景路径来为网页添加多个背景图片,语法格式“background-image: url(图片地址), url(图片地址)…;”。 本教程操作环境:windows7系统、CSS3&a…

    2025年12月24日
    000
  • css3中媒体查询的语法组成是什么

    媒体查询的语法组成是“@media not|only mediatype and (expressions) {CSS代码…;}”;媒体查询可由多种媒体组成,可以包含一个或多个表达式,表达式根据条件是否成立返回true或false。 本教程操作环境:windows7系统、CSS3&amp…

    2025年12月24日
    000
  • 用css3实现一个奥运五环

    css3实现奥运五环的方法:首先给5个div设置border-radius样式,制作五个圆环;然后使用position属性设置五个圆环的位置;最后使用z-index属性调整各环的层级关系即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 五环…

    2025年12月24日
    000
  • css3中新增加的颜色模式有哪些

    css新增了3种颜色模式:1、RGBA模式,是在RGB模式上新增了Alpha透明度,例“rgba(255,0,0,0.5)”;2、HSL模式,例“hsl(360,50%,50%)”;3、HSLA模式,是在HSL模式上新增了Alpha透明度。 本教程操作环境:windows7系统、CSS3版、Dell…

    2025年12月24日
    000
  • 详解CSS3+SVG滤镜实现不规则边框的方法

    本篇文章将介绍一种配合 svg 滤镜实现各种不规则图形添加边框的小技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 需求背景,给不规则图形添加边框 在我们日常开发中,时长会遇到一些非矩形、非圆形的图案。类似下面这些: 使用纯 CSS,搭配一些技巧,是可以制作出上面的图形的,当然…

    2025年12月24日 好文分享
    000
  • css怎么实现翻转效果

    css实现翻转效果的方法:首先创建一个演示方块,并为其添加transition和transform属性;然后将transition属性添加到需要翻转的p上;最后添加perspective和transform-style属性即可。 本文操作环境:Windows7系统、HTML5&&CS…

    2025年12月24日 好文分享
    000
  • 29个CSS面试题总结(知识点解析)

    本篇文章给大家分享29个css 面试知识点。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 CSS是层叠样式表( Cascading Style Sheets )的缩写,是一种样式表语言,用于描述以 HTML 之类的标记语言编写的文档的布局。 它是用于设计Web页面的三剑客之一,另…

    2025年12月24日
    000
  • CSS3如何实现流星雨效果?(代码示例)

    本篇文章给大家通过代码示例介绍一下使用css3如何实现流星雨效果。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【推荐教程:CSS视频教程】 说明:正文只讲述单个流星雨的实现方式,多个的效果只需要对单个的动画起始点、宽度稍加修改即可,具体示例见文末 github 地址。 难度系数…

    2025年12月24日
    000
  • css3中实现动画有哪两种方式

    css3中实现动画的两种方式分别是:1、分别利用transition属性和transform属性来设置过渡和形状;2、利用动画属性animation设置动画效果。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 1、利用transition设置过渡,添加trans…

    2025年12月24日
    000
  • 什么是CSS优先级

    所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序;浏览器是通过优先级来判断哪些属性值与元素最相关以决定并应用到该元素上的。优先级就是分配给指定的CSS声明的一个权重,它由匹配的选择器中的每一种选择器类型的数值决定。 本教程操作环境:windows7系统、CSS3版、Dell G3电脑。 …

    2025年12月24日 好文分享
    000
  • 使用CSS3实现简单时间轴效果(附代码)

    本篇文章分享一个使用css3实现的时间轴效果。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【推荐教程:CSS视频教程 】 最近打开电脑就能看到一个实战路径图页面,效果是这样的: 立即学习“前端免费学习笔记(深入)”; 有点像时间轴的赶脚,而且每一块鼠标悬浮上去也有下拉效果展开介…

    2025年12月24日
    000
  • css3中怎么调节透明度

    css3中调节透明度的方法:可以使用opacity属性来设置透明度,如【opacity:0.5; filter:Alpha(opacity=50);】,表示将元素透明度设置为0.5。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 属性介绍: opacity 属性…

    2025年12月24日
    000
  • 浅谈css3 device-width和width之间的差异

    本篇文章和大家谈谈css媒体查询中device-width与width的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【推荐教程:CSS视频教程 】 1.device-width 定义:定义输出设备的屏幕可见宽度。 立即学习“前端免费学习笔记(深入)”; 不管你的网页是在s…

    2025年12月24日
    000
  • css3怎么设置元素背面不可见

    在css3中,可以利用backface-visibility属性,通过给元素添加“backface-visibility: hidden;”样式来设置背面不可见。backface-visibility属性可以设置当元素不面向屏幕时是否可见。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信