CSS shapes布局

一、前言&索引

CSS Shapes布局可以实现不规则的文字环绕效果,需要和浮动配合使用。

CSS shapes布局相关属性并不多,学习成本比grid布局,flex布局小很多。

shapes布局相关属性

  • shape-outside
  • shape-margin
  • shape-image-threshold

二、详细了解shape-outside

shape-outside是不规则形状环绕布局的核心,支持的属性值分为如下四大类:

  1. none – 默认值
  2. <shape-box> – 图形盒子。
  3. <basic-shape> – 基本图形函数。
  4. <image> – 图像类。

其中:

  • none很好理解,表示就是普通的矩形环绕。
  • <shape-box>(图形盒子)是shape相关布局中的一个名词,比clip-path属性中的<geometry-box>(几何盒子)支持的盒子要少一些,就是CSS2.1中的基本盒模型的4种盒子,分别是margin-boxborder-boxpadding-boxcontent-box。要来指定文字环绕的时候是依照哪个盒子的边缘来计算的。
  • <basic-shape>指的是基本形状函数,和CSS clip-path剪裁属性支持的基本形状函数一模一样。
  • <image>值的是图像类,包括URL链接图片,渐变图像,cross-fade(),element()等。所有这些图像类,CSS3 mask遮罩属性也都支持,本文只会介绍常用的URL链接和渐变图像,其他图片类不介绍,有兴趣可以访问介绍遮罩的这篇文章,有完全展示。

不同类型属性值使用示意(取自MDN):

<pre style="margin: 0px; padding: 0px; overflow: auto;">/* 关键字值 */
shape-outside: none;
shape-outside: margin-box;
shape-outside: content-box;
shape-outside: border-box;
shape-outside: padding-box;

/* 函数值 */
shape-outside: circle();
shape-outside: ellipse();
shape-outside: inset(10px 10px 10px 10px);
shape-outside: polygon(10px 10px, 20px 20px, 30px 30px);

/* <url>值 */
shape-outside: url(image.png);

/* 渐变值 */
shape-outside: linear-gradient(45deg, rgba(255, 255, 255, 0) 150px, red 150px);</pre>

1. 关键字属性值

测试HTML和CSS代码如下:

<pre style="margin: 0px; padding: 0px; overflow: auto;"><span class="shape"></span>
<p>在CSS Shapes问世之前...</p></pre>


<pre style="margin: 0px; padding: 0px; overflow: auto;">.shape {</pre>

<pre style="margin: 0px; padding: 0px; overflow: auto;"> float: left;
width: 60px; height: 60px;
padding: 10px; margin: 10px;
border: 10px solid;
border-radius: 50%;
background-color: currentColor;
background-clip: content-box;
color: #cd0000;
shape-outside: none; /* 或margin-box,border-box,padding-box,content-box */
}</pre>

image

可以看到,当shape-outside属性值为none以外的其他关键字的时候,就算是普通的border-radius圆角也能实现环绕效果。

2. 基本的形状函数

指的是下面这四个基本的形状函数:

  • circle() – 圆
  • ellipse() – 椭圆
  • inset() – 内矩形(包括圆角矩形)
  • polygon() – 多边形

其中:

circle() – 圆
语法如下:

<pre style="margin: 0px; padding: 0px; overflow: auto;">circle( [<shape-radius>]? [at <position>]? )</pre>

其中问号 ?是正则表达式中的特殊字符,表示01,也就是说shape-radius(圆半径)和position(圆心位置)都是可以缺省的,表示。因此,下面的写法都是合法的:

<pre style="margin: 0px; padding: 0px; overflow: auto;">shape-outside: circle();
shape-outside: circle(50%);
shape-outside: circle(at 50% 50%);
shape-outside: circle(50% at 50% 50%);
shape-outside: circle(50px at 50px 50px);</pre>

ellipse() – 椭圆

语法如下:

<pre style="margin: 0px; padding: 0px; overflow: auto;">ellipse( [<shape-radius>{2}]? [at <position>]? )</pre>

<pre style="margin: 0px; padding: 0px; overflow: auto; color: rgb(0, 0, 0); font-size: 14px; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial;">半径分为x轴,y轴。 </pre>

x,y半径除了具体数值,还支持farthest-sideclosest-side这两个关键字,顾名思义,分别表示到最长边的长度和最短边的长度。例如:

<pre style="margin: 0px; padding: 0px; overflow: auto;">ellipse(farthest-side closest-side at 25% 25%)</pre>

表示在浮动元素25% 25%位置,以距离浮动元素最长边的距离作为椭圆的x坐标,以距离浮动元素边缘最短的距离作为椭圆的y坐标。于是,有如下的效果图(浮动元素尺寸100*100,红色点标记是25% 25%位置,可以看出椭圆的轮廓):

最长边和最短边效果

inset() – 内矩形(包括圆角矩形)

语法如下:

<pre style="margin: 0px; padding: 0px; overflow: auto;">inset( <shape-arg>{1,4} [round <border-radius>]? ) </pre>

其中shape-arg是必须参数,可以是1~4个值。当提供所有前四个参数时,它们表示从参考框向内的顶部,右侧,底部和左侧偏移,也就是定义了插入的矩形的边缘位置。 这些参数遵循边距缩写的语法(类似marginpadding等属性),我们可以使用1个,2个,3个或4个值。border-radius表示圆角大小,可以缺省。

因此,下面这些写法都是合法的:

<pre style="margin: 0px; padding: 0px; overflow: auto;">shape-outside: inset(10px);
shape-outside: inset(10px 20px);
shape-outside: inset(10px 20px 30px);
shape-outside: inset(10px 20px 30px 40px);
shape-outside: inset(10px 20px 30px 40px round 10px);</pre>

例如上面最后一行代码效果为:


内圆角矩形效果

控制台查看元素盒子可以看到:

圆角环绕效果

polygon() – 多边形

polygon()多边形反而是语法最好理解的:

<pre style="margin: 0px; padding: 0px; overflow: auto;">polygon( [<fill-rule>,]? [<shape-arg> <shape-arg>]# )</pre>

<pre style="margin: 0px; padding: 0px; overflow: auto; color: rgb(0, 0, 0); font-size: 14px; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial;">fill-rule表示填充规则,可以是nonzero以及evenodd,默认值是nonzero。 </pre>

就是一个一个多边形的点坐标。

<pre style="margin: 0px; padding: 0px; overflow: auto;">shape-outside: polygon(0 0, 0 100px, 100px 200px);
shape-outside: polygon(0 0, 100px 0, 0 50px, 100px 100px, 0 100px);</pre>

效果示意:


多边形示意
多边形效果示意

转载自:CSS shapes布局

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,427评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,551评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,747评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,939评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,955评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,737评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,448评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,352评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,834评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,992评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,133评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,815评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,477评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,022评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,147评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,398评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,077评论 2 355

推荐阅读更多精彩内容