CSS3解析抖音LOGO制作的方法步骤


Posted in HTML / CSS onApril 11, 2019

“抖音”,人气也是非常高,据说拥有7亿用户。

今天我们就来研究研究抖音的logo,蹭蹭热度。

效果预览:

CSS3解析抖音LOGO制作的方法步骤

主要用css3新增属性 mix-blend-mode ,”组成,然后有3种颜色,白色、红色、和天蓝色。

ok,我们先来完成一个“J”。根据以往的经验,我们把它拆分成3部分。

CSS3解析抖音LOGO制作的方法步骤

下面我们来分步骤实现。

完成单个“J”

<div class="jitter">
    <div class="logo"></div>
</div>

添加样式

.jitter {
  position: relative;
  width: 200px;
  margin: 100px auto;
}

// 第一部分
.logo {
  position: absolute;
  top: 0;
  left: 0;
  width: 47px;
  height: 218px;
  z-index: 1;
  background: #24f6f0;
}
// 第二部分
.logo::after {
  content: "";
  position: absolute;
  width: 140px;
  height: 140px;
  border: 40px solid #24f6f0;
  border-right: 40px solid transparent;
  border-top: 40px solid transparent;
  border-left: 40px solid transparent;
  top: -110px;
  right: -183px;
  border-radius: 100%;
  transform: rotate(45deg);
  z-index: -10;
}
// 第三部分
.logo::before {
  content: "";
  position: absolute;
  width: 100px;
  height: 100px;
  border: 47px solid #24f6f0;
  border-top: 47px solid transparent;
  border-radius: 50%;
  top: 121px;
  left: -147px;
  transform: rotate(45deg);
}

第一部分,就是个矩形

第二部分,是圆环的1/4

第三部分,是圆环的3/4

CSS3解析抖音LOGO制作的方法步骤

有句话叫做“方法不对,努力白费”所有的前端大神都有自己的学习方法,而学web前端的学习也基本一致,而对于一个什么都不懂的初学者,根本不会知道该怎么学,这也是造成失败的最直接原因。所以学web前端一定要有人指点。如果你处在迷茫期,找不到方向。可以加入我们的前端学习交流qun: 784783012 。有任何不明白的东西随时来问我。点击:前端学习圈

添加另外一个“J”

<div class="jitter">
    <div class="logo"></div>
    <div class="logo"></div>
</div>

样式只需要添加

...
// 省略上面的样式
...
// 和第一个J错开10px
.logo:last-child {
  left: 10px;
  top: 10px;
  background: #fe2d52;
  z-index: 100;
}
// 填充红色
.logo:last-child::before {
  border: 47px solid #fe2d52;
  border-top: 47px solid transparent;
}
.logo:last-child::after {
  border: 40px solid #fe2d52;
  border-right: 40px solid transparent;
  border-top: 40px solid transparent;
  border-left: 40px solid transparent;
}

CSS3解析抖音LOGO制作的方法步骤 

主角登场 - mix-blend-mode

CSS3 新增了一个很有意思的属性 – mix-blend-mode ,其中 mix 和 blend 的中文意译均为混合,那么这个属性的作用直译过来就是混合混合模式,当然,我们我们通常称之为混合模式。

混合模式最常见于 photoshop 中,是 PS 中十分强大的功能之一。下面来看看 mix-blend-mode 有哪些属性可以设置:

mix-blend-mode: normal;         // 正常
mix-blend-mode: multiply;       // 正片叠底
mix-blend-mode: screen;         // 滤色
mix-blend-mode: overlay;        // 叠加
mix-blend-mode: darken;         // 变暗
mix-blend-mode: lighten;        // 变亮
mix-blend-mode: color-dodge;    // 颜色减淡
mix-blend-mode: color-burn;     // 颜色加深
mix-blend-mode: hard-light;     // 强光
mix-blend-mode: soft-light;     // 柔光
mix-blend-mode: difference;     // 差值
mix-blend-mode: exclusion;      // 排除
mix-blend-mode: hue;            // 色相
mix-blend-mode: saturation;     // 饱和度
mix-blend-mode: color;          // 颜色
mix-blend-mode: luminosity;     // 亮度

mix-blend-mode: initial;
mix-blend-mode: inherit;
mix-blend-mode: unset;

然后我们添加 mix-blend-mode:lighten

.logo:last-child {
  ...
  mix-blend-mode: lighten;
}

看看效果:

CSS3解析抖音LOGO制作的方法步骤

是不是很Ok了?

然后我们添加动画,让第二个J缓慢和一个J融合。

动画融合

.logo:last-child {
  ...
  animation: move 10s infinite;
}
@keyframes move {
  0% {
    transform: translate(200px);
  }
  50% {
    transform: translate(0px);
  }
  100% {
    transform: translate(0px);
  }
}

最终就可以实现第一张图片的预览效果了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3 优势以及网页设计师如何使用CSS3技术
Jul 29 HTML / CSS
css3绘制天猫logo实现代码
Nov 06 HTML / CSS
今天学到的CSS最新技术(与图片背景相关)
Dec 24 HTML / CSS
实现CSS3中的border-radius(边框圆角)示例代码
Jul 19 HTML / CSS
一款css实现的鼠标经过按钮的特效
Sep 11 HTML / CSS
CSS3 函数技巧 用css 实现js实现的事情(clac Counters Tooltip)
Aug 15 HTML / CSS
CSS3制作轮播图的一种方法
Nov 11 HTML / CSS
CSS3+HTML5+JS 实现一个块的收缩与展开动画效果
Nov 17 HTML / CSS
Html5游戏开发之乒乓Ping Pong游戏示例(一)
Jan 21 HTML / CSS
HTML5在canvas中绘制复杂形状附效果截图
Jun 23 HTML / CSS
HTML5之语义标签介绍
Jul 07 HTML / CSS
HTML5不支持frameset的两种解决方法
Nov 14 HTML / CSS
浅谈CSS3 box-sizing 属性 有趣的盒模型
Apr 02 #HTML / CSS
CSS3 3D酷炫立方体变换动画的实现
Mar 26 #HTML / CSS
CSS3之2D与3D变换的实现方法
Jan 28 #HTML / CSS
CSS3移动端vw+rem不依赖JS实现响应式布局的方法
Jan 23 #HTML / CSS
用CSS3和table标签实现一个圆形轨迹的动画的示例代码
Jan 17 #HTML / CSS
简单几步用纯CSS3实现3D翻转效果
Jan 17 #HTML / CSS
css3实现3D文本悬停改变效果的示例代码
Jan 16 #HTML / CSS
You might like
php利用新浪接口查询ip获取地理位置示例
2014/01/20 PHP
PHP生成自适应大小的缩略图类及使用方法分享
2014/05/06 PHP
PHP的Laravel框架结合MySQL与Redis数据库的使用部署
2016/03/21 PHP
PHP自带方法验证邮箱、URL、IP是否合法的函数
2016/12/08 PHP
tp5(thinkPHP5)框架实现多数据库查询的方法
2019/01/10 PHP
javascript 一些用法小结
2009/09/11 Javascript
ExtJs的Date格式字符代码
2010/12/30 Javascript
Jquery跨域获得Json时invalid label错误的解决办法
2011/01/11 Javascript
jQuery EasyUI API 中文文档 DateTimeBox日期时间框
2011/10/16 Javascript
Knockout数组(observable)使用详解示例
2013/11/15 Javascript
JavaScript实现的encode64加密算法实例分析
2015/04/15 Javascript
Jquery实现遮罩层的方法
2015/06/08 Javascript
JS产生随机数的用法小结
2016/12/10 Javascript
javascript中递归的两种写法
2017/01/17 Javascript
详解Vue的computed(计算属性)使用实例之TodoList
2017/08/07 Javascript
nodejs结合Socket.IO实现的即时通讯功能详解
2018/01/12 NodeJs
react router4+redux实现路由权限控制的方法
2018/05/03 Javascript
微信小程序支付前端源码
2018/08/29 Javascript
Element中的Cascader(级联列表)动态加载省\市\区数据的方法
2019/03/27 Javascript
Django如何实现内容缓存示例详解
2017/09/24 Python
Python使用ConfigParser模块操作配置文件的方法
2018/06/29 Python
Python除法之传统除法、Floor除法及真除法实例详解
2019/05/23 Python
Python拆分大型CSV文件代码实例
2019/10/07 Python
numpy实现神经网络反向传播算法的步骤
2019/12/24 Python
python图形界面开发之wxPython树控件使用方法详解
2020/02/24 Python
Python如何读写字节数据
2020/08/05 Python
一款超酷的js+css3实现的3D标签云特效兼容ie7/8/9
2013/11/18 HTML / CSS
HTML5中5个简单实用的API
2014/04/28 HTML / CSS
使用layui实现左侧菜单栏及动态操作tab项的方法
2020/11/10 HTML / CSS
台湾屈臣氏网路商店:Watsons台湾
2020/12/29 全球购物
vue+django实现下载文件的示例
2021/03/24 Vue.js
完美主义个人的自我评价
2014/02/17 职场文书
学校捐款活动总结
2015/05/09 职场文书
大学社团活动总结怎么写
2019/06/21 职场文书
使用ICOM IC-R9500接收机同时测评十台收音机中波接收性能
2022/05/10 无线电
spring 项目实现限流方法示例
2022/07/15 Java/Android