自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

CSS 奇思妙想 | 巧妙的實現(xiàn)帶圓角的三角形

開發(fā) 前端
本文介紹了幾種在 CSS 中實現(xiàn)帶圓角三角形的方式,雖然部分有些繁瑣,但是也體現(xiàn)了 CSS ”有趣且折磨人“ 的一面,具體應用的時候,還是要思考一下,對是否使用上述方式進行取舍,有的時候,切圖也許是更好的方案。

[[411591]]

之前在這篇文章中 -- 《老生常談之 CSS 實現(xiàn)三角形》[1],介紹了 6 種使用 CSS 實現(xiàn)三角形的方式。

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

本文將介紹幾種實現(xiàn)帶圓角的三角形的實現(xiàn)方式。

法一. 全兼容的 SVG 大法

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

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

代碼量非常少,核心代碼如下:

  1. <svg  width="250" height="250" viewBox="-50 -50 300 300"
  2.   <polygon class="triangle" stroke-linejoin="round" points="100,0 0,200 200,200"/> 
  3. </svg> 
  1. .triangle { 
  2.     fill: #0f0; 
  3.     stroke: #0f0; 
  4.     stroke-width: 10; 

實際圖形如下:

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

  • miter 是默認值,表示用方形畫筆在連接處形成尖角
  • round 表示用圓角連接,實現(xiàn)平滑效果
  • bevel 連接處會形成一個斜接

我們實際是通過一個帶邊框,且邊框連接類型為 stroke-linejoin: round 的多邊形生成圓角三角形的。

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

  1. .triangle { 
  2.     fill: #0f0; 
  3.     stroke: #000; 
  4.     stroke-width: 10; 

 

通過 stroke-width 控制圓角大小

那么如何控制圓角大小呢?也非常簡單,通過控制 stroke-width 的大小,可以改變圓角的大小。

當然,要保持三角形大小一致,在增大/縮小 stroke-width 的同時,需要縮小/增大圖形的 width/height:

完整的 DEMO 你可以戳這里:CodePen Demo -- 使用 SVG 實現(xiàn)帶圓角的三角形[2]

法二. 圖形拼接

不過,上文提到了,使用純 CSS 實現(xiàn)帶圓角的三角形,但是上述第一個方法其實是借助了 SVG。那么僅僅使用 CSS,有沒有辦法呢?

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

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

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

繪制帶圓角的菱形

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

1.首先將一個正方形變成一個菱形,利用 transform 有一個固定的公式:

  1. <div></div> 
  1. div { 
  2.     width:  10em; 
  3.     height: 10em; 
  4.     transform: rotate(-60deg) skewX(-30deg) scale(1, 0.866); 

 

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

  1. div { 
  2.     width:  10em; 
  3.     height: 10em; 
  4.     transform: rotate(-60deg) skewX(-30deg) scale(1, 0.866); 
  5.   + border-top-right-radius: 30%; 

 

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

拼接 3 個帶圓角的菱形

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

完整的代碼如下:

  1. <div></div> 
  1. div{ 
  2.     position: relative
  3.     background-color: orange; 
  4. div:before, 
  5. div:after { 
  6.     content: ''
  7.     position: absolute
  8.     background-color: inherit; 
  9. div, 
  10. div:before, 
  11. div:after { 
  12.     width:  10em; 
  13.     height: 10em; 
  14.     border-top-right-radius: 30%; 
  15. div { 
  16.     transform: rotate(-60deg) skewX(-30deg) scale(1,.866); 
  17. div:before { 
  18.     transform: rotate(-135deg) skewX(-45deg) scale(1.414, .707) translate(0,-50%); 
  19. div:after { 
  20.     transform: rotate(135deg) skewY(-45deg) scale(.707, 1.414) translate(50%); 

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

完整的代碼你可以戳這里:CodePen Demo -- A triangle with rounded[3]

法三. 圖形拼接實現(xiàn)漸變色圓角三角形

完了嗎?沒有!

上述方案,雖然不算太復雜,但是有一點還不算太完美的。就是無法支持漸變色的圓角三角形。像是這樣:

 

如果需要實現(xiàn)漸變色圓角三角形,還是有點復雜的。但真就還有人鼓搗出來了,下述方法參考至 -- How to make 3-corner-rounded triangle in CSS[4]

同樣也是利用了多塊進行拼接,但是這次我們的基礎(chǔ)圖形,會非常的復雜。

首先,我們需要實現(xiàn)這樣一個容器外框,和上述的方法比較類似,可以理解為是一個圓角菱形(畫出 border 方便理解):

  1. <div></div> 
  1. div { 
  2.     width: 200px; 
  3.     height: 200px; 
  4.     transform: rotate(30deg) skewY(30deg) scaleX(0.866); 
  5.     border: 1px solid #000; 
  6.     border-radius: 20%; 

接著,我們同樣使用兩個偽元素,實現(xiàn)兩個稍顯怪異的圖形進行拼接,算是對 transform 的各種用法的合集:

  1. div::before, 
  2. div::after { 
  3.     content: ""
  4.     position: absolute
  5.     width: 200px; 
  6.     height: 200px; 
  7. div::before { 
  8.     border-radius: 20% 20% 20% 55%; 
  9.     transform: scaleX(1.155) skewY(-30deg) rotate(-30deg) translateY(-42.3%) skewX(30deg) scaleY(0.866) translateX(-24%); 
  10.     background: red; 
  11. div::after { 
  12.     border-radius: 20% 20% 55% 20%; 
  13.     background: blue; 
  14.     transform: scaleX(1.155) skewY(-30deg) rotate(-30deg) translateY(-42.3%) skewX(-30deg) scaleY(0.866) translateX(24%); 

為了方便理解,制作了一個簡單的變換動畫:

本質(zhì)就是實現(xiàn)了這樣一個圖形:

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

由于這兩個元素重疊空間的特殊結(jié)構(gòu),此時,給兩個偽元素添加同一個漸變色,會完美的疊加在一起:

  1. div::before, 
  2. div::after, { 
  3.     background: linear-gradient(#0f0, #03a9f4); 

最終得到一個漸變圓角三角形:

上述各個圖形的完整代碼,你可以戳這里:CodePen Demo -- A triangle with rounded and gradient background[5]

最后

本文介紹了幾種在 CSS 中實現(xiàn)帶圓角三角形的方式,雖然部分有些繁瑣,但是也體現(xiàn)了 CSS ”有趣且折磨人“ 的一面,具體應用的時候,還是要思考一下,對是否使用上述方式進行取舍,有的時候,切圖也許是更好的方案。

參考資料

[1]《老生常談之 CSS 實現(xiàn)三角形》:

https://juejin.cn/post/6950081305560219679

[2]CodePen Demo -- 使用 SVG 實現(xiàn)帶圓角的三角形: https://codepen.io/Chokcoco/pen/eYWZvKo

[3]CodePen Demo -- A triangle with rounded:

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

[4]How to make 3-corner-rounded triangle in CSS:

https://stackoverflow.com/questions/14446677/how-to-make-3-corner-rounded-triangle-in-css

[5]CodePen Demo -- A triangle with rounded and gradient background:

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

[6]Github -- iCSS: https://github.com/chokcoco/iCSS

 

責任編輯:姜華 來源: iCSS前端趣聞
相關(guān)推薦

2022-03-16 14:27:49

CSS三角形前端

2016-10-20 13:36:28

WebRTC瀏覽器服務器

2021-10-19 10:09:21

三角形個數(shù)數(shù)組

2024-02-20 18:30:53

CSS屬性邊框

2024-09-05 11:20:54

2021-08-29 18:32:18

CSS

2021-04-15 06:02:50

CSS 三角形技巧

2023-11-01 07:51:15

WebGPU3D 圖形

2023-04-17 09:01:01

WebGL繪制三角形

2020-12-09 08:34:24

css生成器設計師

2022-02-22 07:50:10

CSS前端CSS-doodle

2021-07-13 06:10:02

CSS 技巧background-

2018-03-02 15:54:37

三角形主機比特幣

2022-09-14 15:17:26

ArkUI鴻蒙

2023-01-31 10:23:00

CSS倒影效果

2021-07-06 06:07:14

CSS 技巧背景

2023-05-06 07:23:57

2013-09-26 13:43:13

iOS開發(fā)OpenGL ES教程圖元

2012-12-24 09:55:15

iOSUnity3D

2022-07-14 07:01:56

Eureka讀鎖線程
點贊
收藏

51CTO技術(shù)棧公眾號