首頁 > web前端 > css教學 > 純CSS實現圓角三角形的3種方法(技巧分享)

純CSS實現圓角三角形的3種方法(技巧分享)

青灯夜游
發布: 2021-08-04 18:36:23
轉載
4486 人瀏覽過

本篇文章跟大家介紹利用CSS繪製圓角三角形的3種方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

純CSS實現圓角三角形的3種方法(技巧分享)

之前在這篇文章中-- 《利用CSS繪製三角形的6種技巧(分享)》,介紹了6 種使用CSS 實現三角形的方式。

但是其中漏掉了一個非常重要的場景,如何使用純 CSS 實現帶圓角的三角形呢? ,像是這樣:

純CSS實現圓角三角形的3種方法(技巧分享)

本文將介紹幾種實作帶圓角的三角形的實作方式。

法一. 全相容的SVG 大法

想要產生一個圓角的三角形,程式碼量最少、最好的方式是使用SVG 生成。

使用 SVG 的 多邊形標籤 <polygon></polygon> 產生一個三邊形,使用 SVG 的 stroke-linejoin="round" 產生連接處的圓角。

程式碼量非常少,核心程式碼如下:

<svg>
  <polygon></polygon>
</svg>
登入後複製
.triangle {
    fill: #0f0;
    stroke: #0f0;
    stroke-width: 10;
}
登入後複製

實際圖形如下:

純CSS實現圓角三角形的3種方法(技巧分享)

這裡,其實是藉助了SVG 多邊形的stroke-linejoin: round 屬性產生的圓角,stroke-linejoin 是什麼?它用來控制兩條描邊線段之間,有三個可選值:

  • miter 是預設值,表示用方形畫筆在連接處形成尖角
  • round 表示以圓角連接,實現平滑效果
  • ##bevel 連接處會形成一個斜接

純CSS實現圓角三角形的3種方法(技巧分享)

我們實際上是

透過一個有邊框,且邊框連接類型為stroke-linejoin: round 的多邊形產生圓角三角形的

如果,我們把底色和邊框色區分開,實際上是這樣的:

.triangle {
    fill: #0f0;
    stroke: #000;
    stroke-width: 10;
}
登入後複製

純CSS實現圓角三角形的3種方法(技巧分享)

透過stroke-width 控制圓角大小

那麼要如何控制圓角大小呢?也非常簡單,透過控制

stroke-width 的大小,可以改變圓角的大小。

當然,要保持三角形大小一致,在增大/縮小

stroke-width 的同時,需要縮小/增大圖形的width/height

純CSS實現圓角三角形的3種方法(技巧分享)

完整的DEMO 你可以戳這裡:CodePen Demo -- 使用SVG 實作圓角的三角形

https: //codepen.io/Chokcoco/pen/eYWZvKo

#法二.圖形拼接

不過,上文提到了,

使用純CSS實作圓角的三角形,但上述第一個方法其實是藉助了SVG。那麼只要使用 CSS,有沒有辦法呢?

當然,發散思維,CSS 有趣的地方正在於此處,用一個圖形,能夠有非常多種巧妙的解決方案!

我們看看,一個圓角三角形,它其實可以被拆分成幾個部分:

純CSS實現圓角三角形的3種方法(技巧分享)

所以,其實我們只需要能夠畫出一個這樣的帶圓角的菱形,經過3 個進行旋轉疊加,就能得到圓角三角形:

純CSS實現圓角三角形的3種方法(技巧分享)

#畫出圓角的菱形

那麼,接下來我們的目標就變成了繪製一個帶圓角的菱形,方法有很多,本文給出其中一種方式:

1、首先將一個正方形變成一個菱形,利用

transform 有一個固定的公式:

<div></div>
登入後複製
登入後複製
登入後複製
div {
    width:  10em;
    height: 10em;
    transform: rotate(-60deg) skewX(-30deg) scale(1, 0.866);
}
登入後複製

純CSS實現圓角三角形的3種方法(技巧分享)

2、將其中一個角變成圓角:

div {
 width:  10em;
 height: 10em;
 transform: rotate(-60deg) skewX(-30deg) scale(1, 0.866);
  + border-top-right-radius: 30%;
}
登入後複製

純CSS實現圓角三角形的3種方法(技巧分享)

至此,我們就順利的得到一個圓角的菱形了!

拼接3 個圓角的菱形

接下來就很簡單了,我們只需要利用元素的另外兩個偽元素,再產生2 個帶圓角的菱形,將一共3 個圖形旋轉位移拼接起來即可!

完整的程式碼如下:

<div></div>
登入後複製
登入後複製
登入後複製
div{
    position: relative;
    background-color: orange;
}
div:before,
div:after {
    content: &#39;&#39;;
    position: absolute;
    background-color: inherit;
}
div,
div:before,
div:after {
    width:  10em;
    height: 10em;
    border-top-right-radius: 30%;
}
div {
    transform: rotate(-60deg) skewX(-30deg) scale(1,.866);
}
div:before {
    transform: rotate(-135deg) skewX(-45deg) scale(1.414, .707) translate(0,-50%);
}
div:after {
    transform: rotate(135deg) skewY(-45deg) scale(.707, 1.414) translate(50%);
}
登入後複製

就可以得到一个圆角三角形了!效果如下:

1純CSS實現圓角三角形的3種方法(技巧分享)

完整的代码你可以戳这里:CodePen Demo -- A triangle with rounded

https://codepen.io/Chokcoco/pen/vYmLVZr

法三. 图形拼接实现渐变色圆角三角形

完了吗?没有!

上述方案,虽然不算太复杂,但是有一点还不算太完美的。就是无法支持渐变色的圆角三角形。像是这样:

1純CSS實現圓角三角形的3種方法(技巧分享)

如果需要实现渐变色圆角三角形,还是有点复杂的。但真就还有人鼓捣出来了,下述方法参考至 -- How to make 3-corner-rounded triangle in CSS。

同样也是利用了多块进行拼接,但是这次我们的基础图形,会非常的复杂。

首先,我们需要实现这样一个容器外框,和上述的方法比较类似,可以理解为是一个圆角菱形(画出 border 方便理解):

1純CSS實現圓角三角形的3種方法(技巧分享)

<div></div>
登入後複製
登入後複製
登入後複製
div {
    width: 200px;
    height: 200px;
    transform: rotate(30deg) skewY(30deg) scaleX(0.866);
    border: 1px solid #000;
    border-radius: 20%;
}
登入後複製

接着,我们同样使用两个伪元素,实现两个稍显怪异的图形进行拼接,算是对 transform 的各种用法的合集:

div::before,
div::after {
    content: "";
    position: absolute;
    width: 200px;
    height: 200px;
}
div::before {
    border-radius: 20% 20% 20% 55%;
    transform: scaleX(1.155) skewY(-30deg) rotate(-30deg) translateY(-42.3%) skewX(30deg) scaleY(0.866) translateX(-24%);
    background: red;
}
div::after {
    border-radius: 20% 20% 55% 20%;
    background: blue;
    transform: scaleX(1.155) skewY(-30deg) rotate(-30deg) translateY(-42.3%) skewX(-30deg) scaleY(0.866) translateX(24%);
}
登入後複製

为了方便理解,制作了一个简单的变换动画:

純CSS實現圓角三角形的3種方法(技巧分享)

本质就是实现了这样一个图形:

1純CSS實現圓角三角形的3種方法(技巧分享)

最后,给父元素添加一个 overflow: hidden 并且去掉父元素的 border 即可得到一个圆角三角形:

1純CSS實現圓角三角形的3種方法(技巧分享)

由于这两个元素重叠空间的特殊结构,此时,给两个伪元素添加同一个渐变色,会完美的叠加在一起:

div::before,
div::after, {
    background: linear-gradient(#0f0, #03a9f4);
}
登入後複製

最终得到一个渐变圆角三角形:

1純CSS實現圓角三角形的3種方法(技巧分享)

上述各个图形的完整代码,你可以戳这里:CodePen Demo -- A triangle with rounded and gradient background

https://codepen.io/Chokcoco/pen/LYyGRpV

最后

本文介绍了几种在 CSS 中实现带圆角三角形的方式,虽然部分有些繁琐,但是也体现了 CSS ”有趣且折磨人“ 的一面,具体应用的时候,还是要思考一下,对是否使用上述方式进行取舍,有的时候,切图也许是更好的方案。

好了,本文到此结束,希望对你有帮助 :)

原文地址:https://segmentfault.com/a/1190000040344317

作者:chokcoco

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

以上是純CSS實現圓角三角形的3種方法(技巧分享)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
css
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板