最新消息:flex弹性布局更新完毕,阅读地址:http://www.01happy.com/css-flex/

svg中六种基本形状

html5 32浏览 0评论

svg简介

svg 意为可缩放矢量图形(Scalable Vector Graphics),最大的特点就是伸缩不会失真。

svg是用xml进行描述的,在前端方面现在应用越来越广泛,各大浏览器支持越来越好了。

这边尝试记录一下用svg画各种形状。

svg标签

要使用svg,需要先引入svg标签:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
</svg>

其中:

width表示图片的宽。
height表示图片的高。

画长(正)方形

画方形使用rect标签,其中有如下属性:

x、y表示左上顶点坐标,相对于svg左上角的位置。
width和height表示宽高。
fill设置填充色。
stroke表示轮廓颜色。
stroke-width表示轮廓宽度。

代码示例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
    <rect 
        x="0" 
        y="0" 
        width="200" 
        height="200" 
        fill="steelblue"
        stroke="pink" 
        stroke-width="10" 
    ></rect>
</svg>

运行效果

svg矩形

svg矩形

画圆形

画圆形使用circle标签,其中相关属性:

cx、cy表示圆形坐标,相对于svg左上角。
r表示半径。

代码示例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
    <circle 
        cx="100" 
        cy="100" 
        r="90" 
        fill="steelblue" 
        stroke="pink" 
        stroke-width="10"
        ></circle>
</svg>

运行效果:

svg圆形

svg圆形

画椭圆

画圆形使用ellipse标签,其中相关属性:

cx、cy表示圆心坐标,相对于svg左上角。
cx、cy表示圆心坐标,相对于svg左上角。
r表示半径。

代码示例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
    <ellipse 
        cx="100" 
        cy="100" 
        rx="90" 
        ry="50"
        fill="steelblue"
    ></ellipse>
</svg>

运行效果:

svg椭圆

svg椭圆

画直线

画圆形使用line标签,其中相关属性:

x1、y1表示点1坐标,相对于svg左上角。
x2、y2表示点2坐标,相对于svg左上角。
r表示半径。

主要是要确认两个点,两点确定一条直线。

代码示例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
    <line 
        x1="0" 
        y1="0" 
        x2="200" 
        y2="200" 
        stroke="steelblue" 
        stroke-width="2"
    />
</svg>

运行效果:

svg直线

svg直线

画多边形

画圆形使用polygon标签,其中相关属性:

points表示多个点的坐标,每个点用空格分离。

代码示例,画一个三角形:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
  <polygon 
        points="0,0 0,150 150,150" 
        fill="steelblue"
    />
</svg>

运行效果:

svg多边形三角形

svg多边形三角形

画多线段

画圆形使用polyline标签,其中相关属性:

points表示多个点的坐标,每个点用空格分离。

代码示例:

<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="200" height="200">
  <polyline 
        points="0,0 0,100 60,150 80,100" 
        fill="none"
        stroke="steelblue"
        stroke-width="3"
    />
</svg>

运行效果:

svg折线

svg折线

因为是画线段,所以fill设置为none表示不要填充色,通过 stroke 设置线段颜色。

相关参考资料:

  1. 菜鸟教程:https://www.runoob.com/svg/svg-tutorial.html
  2. svg浏览器兼容性:https://caniuse.com/?search=svg

转载请注明:快乐编程 » svg中六种基本形状

发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址