FontAwesome 5-彩色图标

时间:2018-09-30 14:19:54

标签: html css font-awesome font-awesome-5

FontAwesome 5提供了数千个使用SVG构建的图标。这样,通过使用fill即可为整个图标着色。但是,如果我想使用多种颜色怎么办?例如,给定图标Google,我想为它着色:

Google Logo

3 个答案:

答案 0 :(得分:4)

通过对颜色和两个图标使用渐变,我们可以实现此目的,但仍然是一种 hacky 方式,您需要专门处理每种情况(图标+着色):

.fa-google path{
  fill:url(#grad1);
}
.fa-google + .fa-google path{
  fill:url(#grad2);
}
.icon {
  display:inline-block;
  position:relative;
}
.fa-google + .fa-google {
   position:absolute;
   left:0;
   top:0;
   clip-path: polygon(0% 0%,120% 0%,0% 75%);
}
<script defer src="https://use.fontawesome.com/releases/v5.3.1/js/all.js" ></script>
<svg style="width:0;height:0;">
  <defs>
    <linearGradient id="grad1" x1="0%" y1="30%" x2="50%" y2="0%">
      <stop offset="50%" stop-color="#34a853" />
      <stop offset="50%" stop-color="#4285f4" />
    </linearGradient>
    <linearGradient id="grad2" x1="0%" y1="30%" x2="50%" y2="0%">
      <stop offset="50%" stop-color="#fbbc05" />
      <stop offset="50%" stop-color="#ea4335" />
    </linearGradient>
  </defs>
</svg>
<div class="icon"> 
<i class="fab fa-google fa-7x"></i>
<i class="fab fa-google fa-7x"></i>
</div>

答案 1 :(得分:2)

使用FontAwesome(或任何其他可用的图标字体)不使手变脏是不可能的,也就是说,修改字体并在创建的部分图标字符之上创建自己的自定义HTML和CSS

分别将每个图标彩色部分创建为一个字符,并将它们彼此堆叠。该示例堆叠了两个现有的FA图标以显示该技术:

.stack-icons {
  position: absolute;
}

.stack-icons i[class*=fa-] {
  position: absolute;
  color: orange;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.stack-icons i[class*=fa-]+i[class*=fa-] {
  color: #a00;
}
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.3.1/css/all.css" integrity="sha384-mzrmE5qonljUremFsqc01SB46JvROS7bZs3IO2EmfFsd15uHvIt+Y8vEf7N7fWAU" crossorigin="anonymous">
<div class="stack-icons">
  <i class="far fa-circle"></i>
  <i class="fas fa-angle-up"></i>
</div>

答案 2 :(得分:0)

.fa-google-g-new {
  background: conic-gradient(from -45deg, #ea4335 110deg, #4285f4 90deg 180deg, #34a853 180deg 270deg, #fbbc05 270deg) 72% 54%/151% 151% no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

use this class .fa-google-g-new  as new with font awesom