首页 web前端 H5教程 关于使用HTML5进行SVG矢量图形绘制的代码

关于使用HTML5进行SVG矢量图形绘制的代码

Jun 20, 2018 am 10:00 AM
html5 svg 矢量图

这篇文章主要介绍了使用HTML5进行SVG矢量图形绘制的入门教程,包括基本图形的绘制和简单的渐变效果等介绍,注意旧版本IE对其的支持并不好,需要的朋友可以参考下

VG 表示可伸缩矢量图形,这是一门用于描述 2D 图形的语言,图形应用使用 XML 编写,然后 XML 由 SVG 阅读器程序呈现。

SVG 主要用于矢量类型的图表,比如饼图,X,Y 坐标系统中的二维图等等。

SVG 在 2003 年 1 月 14 日成为 W3C 推荐标准,你可以在 SVG 规范 页面中查看最新版本的 SVG 规范。

查看 SVG 文件
大多数 Web 浏览器都可以显示 SVG,就像它们可以显示 PNG,GIF 以及 JPG 图形。IE 用户可能需要安装 Adobe SVG 阅读器 以便能够在浏览器中查看 SVG。

在 HTML5 中嵌入 SVG
HTML5 允许我们直接使用 __... 标签嵌入 SVG,下面是简单的语法:

<svg xmlns="http://www.w3.org/2000/svg">
...       
</svg>

HTML5 - SVG 圆

下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个圆:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Circle</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
    <circle id="redcircle" cx="50" cy="50" r="50" fill="red" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112130340.jpg (223×186)


HTML5 - SVG 矩形
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个矩形:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Rectangle</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
    <rect id="redrect" width="300" height="100" fill="red" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112200272.jpg (316×152)


HTML5 - SVG 线条
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个线条:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Line</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
    <line x1="0" y1="0" x2="200" y2="100"
          style="stroke:red;stroke-width:2"/>
</svg>
</body>
</html>

你可以使用 style 属性给它设置额外的样式信息,比如笔画,填充色,笔画宽度等等。

在启用 HTML5 的最新版 FireFox 中会生成如下结果:
2016219112220725.jpg (217×159)


HTML5 - SVG 椭圆
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个椭圆:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Ellipse</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
    <ellipse cx="100" cy="50" rx="100" ry="50" fill="red" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112240763.jpg (225×148)


HTML5 - SVG 多边形
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个多边形:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Polygon</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
    <polygon  points="20,10 300,20, 170,50" fill="red" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112258796.jpg (310×118)


HTML5 - SVG 折线
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个折线图:

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Polyline</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
 <polyline points="0,0 0,20 20,20 20,40 40,40 40,60" fill="red" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112318049.jpg (245×114)


HTML5 - SVG 渐变
下面是一个 SVG 示例的 HTML5 版本,用 标签绘制一个椭圆,使用 标签定义一个 SVG 径向渐变。

我们可以以类似的方式用 标签创建 SVG 线性渐变。

<!DOCTYPE html>
<head>
<title>SVG</title>
<meta charset="utf-8" />
</head>
<body>
<h2>HTML5 SVG Gradient Ellipse</h2>
<svg id="svgelem" height="200" xmlns="http://www.w3.org/2000/svg">
   <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-opacity:0"/>
      <stop offset="100%" style="stop-color:rgb(0,0,255);   
      stop-opacity:1"/>
      </radialGradient>
   </defs>
   <ellipse cx="100" cy="50" rx="100" ry="50"
      style="fill:url(#gradient)" />
</svg>
</body>
</html>

在启用 HTML5 的最新版 FireFox 中会生成如下结果:

2016219112338977.jpg (319×157)

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

如何使用HTML5 File接口在web页面上使用文件下载

html5如何实现图片转圈的动画效果

HTML5的Canvas实现绘制曲线的方法

以上是关于使用HTML5进行SVG矢量图形绘制的代码的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1604
29
PHP教程
1509
276
如何在HTML5中使用无线电按钮? 如何在HTML5中使用无线电按钮? Jul 21, 2025 am 01:08 AM

在HTML5中使用单选按钮的关键在于理解其工作原理并正确组织代码结构。1.每个radio按钮的name属性必须相同,以实现互斥选择;2.使用label标签提升可访问性和点击体验;3.推荐将每个选项包裹在div或label中以增强结构清晰度和样式控制;4.通过checked属性设置默认选中项;5.value值应简洁有意义,便于表单提交处理;6.可通过CSS自定义样式,但需确保功能正常。掌握这些要点能有效避免常见问题并提升使用效果。

HTML5中是否仍在使用标签? HTML5中是否仍在使用标签? Jul 21, 2025 am 02:47 AM

是的,是HTML5的一部分,但其使用已逐渐减少且存在争议。用于将主标题与副标题组合在一起,使文档大纲中仅识别最高级别的标题;例如,主标题和副标题可被包裹在中,以表明仅为辅助标题而非独立章节标题;然而,其不再广泛使用的原因包括:1.浏览器和屏幕阅读器对其支持不一致,2.存在更简单的替代方案如使用CSS控制样式,3.HTML文档大纲算法未被广泛支持;尽管如此,在语义要求较高的网站或文档中仍可考虑使用;而大多数情况下,开发者倾向使用单一、通过CSS管理样式并保持清晰的标题层级。

如何编写基本的HTML5页模板? 如何编写基本的HTML5页模板? Jul 26, 2025 am 07:23 AM

声明文档为HTML5,避免浏览器进入怪异模式;2.定义根元素并指定语言以提升可访问性和SEO;3.中包含确保正确字符编码,实现响应式设计,设置页面标题;4.放置所有可见内容,可选添加CSS、favicon和JavaScript链接;该模板结构完整、兼容现代浏览器,适用于任何新HTML文件。

了解HTML5中的服务器范围事件 了解HTML5中的服务器范围事件 Jul 23, 2025 am 01:21 AM

Server-SentEvents(SSE)是HTML5中用于实现服务器向客户端实时推送数据的技术,适用于股票行情、通知系统等场景。它基于HTTP协议,建立一次连接后保持开放,服务器可随时发送更新,支持自动重连和标准数据格式。前端通过创建EventSource对象并监听消息事件接收数据。后端需设置正确的MIME类型(text/event-stream)并保持连接开放持续输出数据流。使用时需注意跨域问题、连接超时、浏览器兼容性及中间层限制等问题。

使用html5 schema.org标记定义自定义词汇。 使用html5 schema.org标记定义自定义词汇。 Jul 31, 2025 am 10:50 AM

Schema.org标记是通过语义标签(如itemscope、itemtype、itemprop)帮助搜索引擎理解网页内容的结构化数据格式;其可用于定义自定义词汇表,方法包括扩展已有类型或使用additionalType引入新类型;实际应用中应保持结构清晰、优先使用官方属性、测试代码有效性、确保自定义类型可访问;注意事项包括接受部分支持、避免拼写错误、选择合适格式如JSON-LD。

HTML5解析器如何处理错误? HTML5解析器如何处理错误? Aug 02, 2025 am 07:51 AM

HTML5parsershandlemalformedHTMLbyfollowingadeterministicalgorithmtoensureconsistentandrobustrendering.1.Formismatchedorunclosedtags,theparserautomaticallyclosestagsandadjustsnestingbasedoncontext,suchasclosingabeforeaandreopeningitafterward.2.Withimp

什么是HTML5数据属性? 什么是HTML5数据属性? Aug 06, 2025 pm 05:39 PM

HTML5dataattributesarecustom,validHTMLattributesusedtostoreextrainformationinelementsforJavaScriptorCSS.1.Theyaredefinedasdata-*attributes,likedata-user-id="123".2.Theyallowembeddingprivate,customdatadirectlyinmarkupwithoutaffectinglayoutor

如何显示HTML5视频的控件? 如何显示HTML5视频的控件? Jul 26, 2025 am 08:11 AM

要显示HTML5视频的播放控制,必须添加controls属性;1.在标签中加入controls属性即可显示默认播放、暂停、音量、进度条、全屏等控制;2.如需自定义控制显示,可用JavaScript动态设置video.controls为true或false;3.默认控件样式因浏览器和操作系统而异,若需完全自定义界面,需移除controls并用JavaScript构建自定义控件,添加controls属性是实现播放控制的基本且必要步骤。

See all articles