- HTML 菜鸟教程
- HTML 教程
- HTML - 简介
- HTML - 编辑器
- HTML - 基本标签
- HTML - 元素
- HTML - 属性
- HTML - 标题
- HTML - 段落
- HTML - 字体
- HTML - 块和内联元素
- HTML - 样式表
- HTML - 文本格式化
- HTML - 引用
- HTML - 注释
- HTML - 颜色
- HTML - 图像
- HTML - 图像映射
- HTML - iframe
- HTML - 短语标签
- HTML - 类
- HTML - ID
- HTML - 背景
- HTML 表格
- HTML - 表格
- HTML - 表格标题
- HTML - 表格样式
- HTML - 表格 Colgroup
- HTML - 嵌套表格
- HTML 列表
- HTML - 列表
- HTML - 无序列表
- HTML - 有序列表
- HTML - 定义列表
- HTML 链接
- HTML - 文本链接
- HTML - 图片链接
- HTML - 电子邮件链接
- HTML 颜色名称和值
- HTML - 颜色名称
- HTML - RGB 和 RGBA 颜色
- HTML - 十六进制颜色
- HTML - HSL 和 HSLA 颜色
- HTML 表单
- HTML - 表单
- HTML - 表单属性
- HTML - 表单控件
- HTML - 输入属性
- HTML 媒体
- HTML - 视频元素
- HTML - 音频元素
- HTML - 嵌入多媒体
- HTML 标头
- HTML - 头部
- HTML - 网站图标
- HTML - JavaScript
- HTML 布局
- HTML - 布局
- HTML - 布局元素
- HTML - CSS布局
- HTML - 响应式网页设计
- HTML - 特殊符号
- HTML - 表情符号
- HTML - 样式指南
- HTML 图形
- HTML - SVG
- HTML - 画布
- HTML API 接口
- HTML - Geolocation API
- HTML - 拖放 API
- HTML - Web Workers API
- HTML - WebSockets
- HTML - Web 存储
- HTML - 服务器发送事件
- HTML 杂项
- HTML - 数学标记语言
- HTML - 微观数据
- HTML - 索引数据库
- HTML - Web 消息传递
- HTML - CORS
- HTML - Web RTC
- HTML 演示
- HTML - 音频播放器
- HTML - 视频播放器
- HTML - Web 幻灯片台
- HTML 工具
- HTML - 二维码
- HTML - Modernizr
- HTML - 验证器
- HTML 备忘单
- HTML - 标签参考
- HTML - 属性参考
- HTML - 事件参考
- HTML - 字体参考
- HTML - ASCII 代码参考
- HTML - 实体
- MIME 媒体类型
- HTML - URL 编码
- HTML - ISO 语言代码
- HTML - 字符编码
- HTML - 已弃用的标签和属性
HTML - SVG
HTML SVG(可缩放矢量图形)用于在 XML 中定义可嵌入到 HTML 页面中的矢量图形。SVG 与普通图像不同,因为即使在缩放后也不会降低质量。
什么是 SVG?
- SVG 代表 可缩放矢量图形。
- SVG 帮助我们使用 XML 编码绘制任何类型的图像。
- 缩放 XML 矢量不会降低其质量
- 它主要适用于矢量类型图(如饼图)和 X、Y 坐标系中的二维图形。
- SVG 于 2003 年 1 月 14 日成为 W3C 推荐标准。
SVG(可缩放矢量图形)
PNG、GIF 和 JPG 文件是位图图形,SVG 文件是矢量图形。这两者之间的主要区别在于,位图图形由微小像素的网格组成,但是,矢量图形是通过编码定义的,因此矢量图形在缩放后不会失去质量。
在 HTML 中使用 SVG 的方法?
有两种方法可以在 HTML 中嵌入 SVG 文件
使用 <img> 标签
我们可以使用 <img> 标签的 src 属性直接将 SVG 文件嵌入到我们的网页中,如下所示。我们可以将路径或在线链接传递给 svg 图像。
<img src = "yourfilename.svg"/>
使用 <svg> 标签
HTML 允许使用 <svg>...</svg> 标签,其语法如下
<svg>
<!-- code to create graphics -->
</svg>
SVG 元素内的标签
有一些预定义的 SVG 元素用于绘制各种形状,如圆形、矩形、线条等。它们如下
标签 | 描述 |
---|---|
<rect> | 定义矢量图形中宽度和高度的矩形属性。 |
<circle> | 定义将左上角和半径的给定坐标的圆属性。 |
<ellipse> | 定义给定左上角坐标的椭圆、长轴长度和短轴长度作为属性。 |
<line> | 绘制给定两个坐标的线作为属性 |
<polyline> | 定义为一系列连接点的给定坐标定义折线 |
<polygon> | 定义连接直线的给定坐标的多边形。 |
<svg> 标签是上述标签的顶级(根)元素。它们在 svg 元素中定义。
SVG 元素的属性
下表包含 SVG 元素的属性列表
属性 | 描述 |
---|---|
X |
左上角的 x 轴坐标。 |
Y |
左上角的 y 轴坐标。 |
width |
矩形图形的宽度。 |
height |
矩形图形的高度。 |
rx |
x 轴的椭圆度。 |
ry |
椭圆的 y 轴圆度。 |
style |
指示内联样式。 |
HTML SVG 元素的示例
以下是一些示例,展示了如何使用 SVG 标签绘制不同的图形元素。
使用 HTML SVG 标签绘制圆圈
以下是 SVG 示例,它将在 SVG 元素中使用 <circle> 标签绘制一个圆圈。这里 cx 是圆左上角的 x 坐标,cy 是圆右上角的 y 坐标
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Circle</h2>
<svg height="500" >
<circle cx="50"
cy="50"
r="50"
fill="red" />
</svg>
</body>
</html>
使用 HTML SVG 标签绘制矩形
以下是使用 <rect> 标签绘制矩形的 SVG 示例。我们使用 height 和 width 属性来制作矩形
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Rectangle</h2>
<svg height = "200">
<rect width = "300"
height = "100"
fill = "red" />
</svg>
</body>
</html>
使用 HTML SVG 标签画一条线
以下是 SVG 示例,它将使用 <line> 标签为提供的两点坐标(x1,y1, x2,y2)绘制一条线。我们还可以使用样式属性,它允许我们设置其他样式信息,例如描边和填充颜色、描边宽度等。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Line</h2>
<svg height="200">
<line x1="0" y1="0"
x2="200" y2="100"
style="stroke:red;stroke-width:2"/>
</svg>
</body>
</html>
使用 HTML SVG 标签绘制椭圆
以下是 SVG 示例,它将使用 <ellipse> 标签绘制椭圆。这里 cx 和 cy 是椭圆左上角的坐标,rx 是沿 x 轴的半径,ry 是沿 y 轴的半径。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Ellipse</h2>
<svg height="200">
<ellipse cx="100" cy="50"
rx="100" ry="50"
fill="red" />
</svg>
</body>
</html>
使用 HTML SVG 标签绘制多边形
以下是使用 <polygon> 标签绘制多边形的 SVG 示例。points 属性定义多边形的顶点。每对坐标 (x, y) 指定一个顶点,通过将这些顶点与直线连接来绘制多边形。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Polygon</h2>
<svg height="200">
<polygon points="20,10, 300,20, 170,50, 130,70"
fill="red" />
</svg>
</body>
</html>
使用 HTML SVG 标签绘制折线
以下是 SVG 示例,它将使用 <polyline> 标签绘制折线。我们在折线标签的“点”属性中给出了连接点的坐标。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Polyline</h2>
<svg height="200">
<polyline points="0,0 0,30 30,30 30,60 60,60"
fill="red" />
</svg>
</body>
</html>
填充形状的颜色渐变
以下是 SVG 示例,它将使用 <ellipse> 标签绘制椭圆,并使用 <radialGradient> 标签来定义 SVG 径向渐变。
同样,您可以使用 <linearGradient> 标签创建 SVG 线性渐变。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Gradient Ellipse</h2>
<svg height="200">
<defs>
<radialGradient id="gradient"
cx="50%" cy="50%"
r="50%"
fx="50%" fy="50%">
<stop offset="0%"
style="stop-color:rgb(200,200,200);"/>
<stop offset="100%"
style="stop-color:rgb(0,0,255);"/>
</radialGradient>
</defs>
<ellipse cx="100" cy="50"
rx="100" ry="50"
style="fill:url(#gradient)" />
</svg>
</body>
</html>
使用 HTML SVG 标签绘制星星
以下是 SVG 示例,它将使用 <polygon> 标签绘制星星。
<!DOCTYPE html>
<html>
<head>
<title>七科普 svg 示例</title>
</head>
<body>
<h2>HTML SVG Star</h2>
<svg height="200">
<polygon points="100,5 40,180 190,60 10,60 160,180"
fill="red"/>
</svg>
</body>
</html>