ellipse()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2020å¹´1æ.
ellipse() 㯠CSS ã®é¢æ°ã§ã<basic-shape> ãã¼ã¿åã®ä¸ã¤ã§ãã
試ãã¦ã¿ã¾ããã
clip-path: ellipse(20px 50px);
clip-path: ellipse(4rem 50% at right center);
clip-path: ellipse(closest-side closest-side at 5rem 6rem);
clip-path: ellipse(closest-side farthest-side);
<section class="default-example" id="default-example">
<div class="transition-all" id="example-element"></div>
</section>
#default-example {
background: #ffee99;
}
#example-element {
background: linear-gradient(to bottom right, #ff5522, #0055ff);
width: 100%;
height: 100%;
}
æ§æ
shape-outside: ellipse(40% 50% at left);
shape-outside: ellipse(closest-side farthest-side at 30%);
æ¥åã¯åºæ¬çã«åãæ½°ãããã®ãªã®ã§ã ellipse() ã¯ã2 ã¤ã®åå¾ x 㨠y ãæå®ããªããã°ãªããªããã¨ãé¤ãã°ã circle() ã¨ããä¼¼ãæ¹æ³ã§åä½ãã¾ãã
å¤
<shape-radius>-
2 ã¤ã®åå¾ã§ãx ããã³ y ããã®é ã§æå®ãã¾ãã
<length>ã<percentage>ãã¾ãã¯closest-sideããã³farthest-sideã®å¤ã®ä½ããã§ããclosest-side-
ã·ã§ã¤ãã®ä¸å¿ããåç §ããã¯ã¹ã®æãè¿ã辺ã¾ã§ã®é·ãã使ç¨ãã¾ããæ¥åã®å ´åã¯ãåå¾ã®è»¸ã§æãè¿ã辺ã¨ãªãã¾ãã
farthest-side-
ã·ã§ã¤ãã®ä¸å¿ããåç §ããã¯ã¹ã®æãé ã辺ã¾ã§ã®é·ãã使ç¨ãã¾ããæ¥åã®å ´åã¯ãåå¾ã®è»¸ã§æãé ã辺ã¨ãªãã¾ãã
<position>-
åã®ä¸å¿ãç§»åãã¾ãã
<length>ã<percentage>ãã¾ãã¯leftã®ãããªå¤ã®ä½ããã§ãã
形弿æ³
<ellipse()> =
ellipse( <radial-size>? [ at <position> ]? )
<radial-size> =
<radial-extent> |
<length [0,â]> |
<length-percentage [0,â]>{2}
<position> =
<position-one> |
<position-two> |
<position-four>
<radial-extent> =
closest-corner |
closest-side |
farthest-corner |
farthest-side
<length-percentage> =
<length> |
<percentage>
<position-one> =
left |
center |
right |
top |
bottom |
x-start |
x-end |
y-start |
y-end |
block-start |
block-end |
inline-start |
inline-end |
<length-percentage>
<position-two> =
[ left | center | right | x-start | x-end ] && [ top | center | bottom | y-start | y-end ] |
[ left | center | right | x-start | x-end | <length-percentage> ] [ top | center | bottom | y-start | y-end | <length-percentage> ] |
[ block-start | center | block-end ] && [ inline-start | center | inline-end ] |
[ start | center | end ]{2}
<position-four> =
[ [ left | right | x-start | x-end ] <length-percentage> ] && [ [ top | bottom | y-start | y-end ] <length-percentage> ] |
[ [ block-start | block-end ] <length-percentage> ] && [ [ inline-start | inline-end ] <length-percentage> ] |
[ [ start | end ] <length-percentage> ]{2}
ä¾
>åºæ¬ç㪠ellipse() ã®ä¾
ãã®ä¾ã§ã¯ãæ°´å¹³æ¹åã®åå¾ã 40%ãåç´æ¹åã®åå¾ã 50%ãä½ç½®ãå·¦ã®æ¥åã示ãã¦ãã¾ããããã¯ãæ¥åã®ä¸å¿ãããã¯ã¹ã®å·¦ç«¯ã«ãããã¨ãæå³ãã¦ãããããã¹ããåãè¾¼ã¾ããããã®åæ¥åã®å½¢ã«ãªãã¾ãããããã®å¤ã夿´ããã¨ãæ¥åã®å¤åã確èªãããã¨ãã§ãã¾ãã Click "Play" in the code blocks to change these values to see how the ellipse changes:
<div class="box">
<div class="shape"></div>
<p>
1782 å¹´ 11 æã®ããå¤ãä¼ããããã¨ããã«ããã°ããã©ã³ã¹ã®å°ããªçºã¢ããã¼ã§ 2 人ã®å
å¼ãå¬ã®æçã®ãã°ã«åº§ããçããç«ã¡ä¸ãç°è²ã®ç
ã®æ¸¦ãåºãç
çªãããããã¨ç»ã£ã¦ããã®ãè¦ã¦ããã 2 人ã®ååã¯ã¹ããã¡ã³ããã³ã¸ã§ã»ãã»ã¢ã³ã´ã«ãã£ã¨ãè·æ¥ã¯ç´æ¼ãè·äººã§ãææ
®æ·±ããããããç§å¦çç¥èãæ°ããçºè¦ã«æ·±ãé¢å¿ãæã£ã¦ããããããè¨å¿µãã¹ãå¤ã§ãã£ããã¨ã証æããããã«ããã®å¤ä»¥åã«ããä½å人ãã®äººã
ãããã®äºå®ããç¹å¥ãªã¤ã³ã¹ãã¬ã¼ã·ã§ã³ãå¾ããã¨ãªããçãç«ã®ç
ãç«ã¡æãã®ãçºãã¦ããã
</p>
</div>
body {
font: 1.2em / 1.5 sans-serif;
}
.shape {
float: left;
shape-outside: ellipse(40% 50% at left);
margin: 20px;
width: 100px;
height: 200px;
}
closest-side / farthest-side ã®å¤ã®ä½¿ç¨
ãã¼ã¯ã¼ãå¤ã® closest-side 㨠farthest-side ã¯ãæµ®åè¦ç´ ã®åç
§ããã¯ã¹ã®å¤§ããã«åºã¥ãã¦ãç´ æ©ãæ¥åã使ããã®ã«ä¾¿å©ã§ãã
<div class="box">
<div class="shape"></div>
<p>
1782 å¹´ 11 æã®ããå¤ãä¼ããããã¨ããã«ããã°ããã©ã³ã¹ã®å°ããªçºã¢ããã¼ã§ 2 人ã®å
å¼ãå¬ã®æçã®ãã°ã«åº§ããçããç«ã¡ä¸ãç°è²ã®ç
ã®æ¸¦ãåºãç
çªãããããã¨ç»ã£ã¦ããã®ãè¦ã¦ããã 2 人ã®ååã¯ã¹ããã¡ã³ããã³ã¸ã§ã»ãã»ã¢ã³ã´ã«ãã£ã¨ãè·æ¥ã¯ç´æ¼ãè·äººã§ãææ
®æ·±ããããããç§å¦çç¥èãæ°ããçºè¦ã«æ·±ãé¢å¿ãæã£ã¦ããããããè¨å¿µãã¹ãå¤ã§ãã£ããã¨ã証æããããã«ããã®å¤ä»¥åã«ããä½å人ãã®äººã
ãããã®äºå®ããç¹å¥ãªã¤ã³ã¹ãã¬ã¼ã·ã§ã³ãå¾ããã¨ãªããçãç«ã®ç
ãç«ã¡æãã®ãçºãã¦ããã
</p>
</div>
body {
font: 1.2em / 1.5 sans-serif;
}
.shape {
float: left;
shape-outside: ellipse(closest-side farthest-side at 30%);
margin: 20px;
width: 100px;
height: 140px;
}
仿§æ¸
| Specification |
|---|
| CSS Shapes Module Level 1> # funcdef-basic-shape-ellipse> |
ãã©ã¦ã¶ã¼ã®äºææ§
é¢é£æ å ±
- ãã®ãã¼ã¿åã使ç¨ããããããã£:
clip-path,shape-outside - åºæ¬ã·ã§ã¤ãã®ã¬ã¤ã