• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > SVG基础|绘制SVG文字

SVG基础|绘制SVG文字

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含SVG,绘制,文字等相关知识,匿名希望在学习及工作中可以帮助到您
我们可以使用SVG 的<text>元素来在SVG图像上绘制文字。下面是一个简单的例子:

<svg xmlns="http://www.w3.org/2000/svg">
  <text x="20" y="40">这里是SVG文字</text>
</svg>

这个例子中定义一个位于x=20,y=40位置的文本。文字显示为“这里是SVG文字”。下面是它的返回结果:

这里是SVG文字

文字的定义

在深入了解SVG文字之前,先来看看下面的三个定义:

  • Glyphs:Glyphs是字母或符号的视觉表现。例如,因为字母“a”有多种不同的视觉表现方式,所以可以使用不同的Glyphs来绘制它。

  • Fonts:Fonts代表字体,它是glyphs的集合,可以用于表现一组字母或符号。

  • Characters:Characters是代表一个字母或符号的二进制数字。一个character可以使用1个或多个字节来表示。一个characters在被计算机渲染的时候,会将它映射为字体中的一个符号。

文字的位置

SVG文字的位置有<svg>元素的x和y属性来决定。x属性决定文字的左边部位置(文字的开始位置),y属性决定文字的下边部位置(注意这里不是上边部)。文字的y属性定位不同于其它SVG元素,如直线,矩形和其它图形。下面的例子显示了一串文字和一条直线,它们的y属性都是40:

观察直线位于文字的位置

注意观察,文字的y属性位于文字的下边,而不是上边。

Text Anchor

文字的anchor决定哪个部分的文字放置在text元素中的x属性定义的位置。默认的anchor是文字左边部,即文字的开始处。你也可以将anchor设置为middle,使它位于文字的中间,设置为end,使它位于文字的右边。

要设置文字的anchor,可以使用CSS的text-anchor属性。该属性的取值为:start、middle和end。下面的例子展示了设置不同的text-anchor值时文字的位置。

994.png

垂直的直线是三串文本的x位置。它们都位于x="50"的位置上。你可以观察不同的取值时文字的不同定位方式。

上效果的代码如下:

<text x="50" y="20"
      style="text-anchor: start">
    Start
</text>
<text x="50" y="40"
      style="text-anchor: middle">
    Middle
</text>
<text x="50" y="60"
      style="text-anchor: end">
    End
</text>

文字的描边和填充

和其它SVG图形一样,SVG文字也可以进行描边和填充操作。如果你只指定了文字的描边属性,文字将会渲染为一个文字轮廓。如果你只指定了文字的填充属性,那么文字看起来和平常是一样的。来看看下面的三种文字描边和填充的效果:

995.png

你也可以使用stroke-width属性为文字的描边设置宽度。下面的例子将文字的描边宽度设置为2:

996.png

SVG文字的间距和字距调整

我们可以使用letter-spacing和kerning属性来控制文字的间距和字距调整(两个glyphs之间的距离)。下面是一个简单的例子:

<svg xmlns="http://www.w3.org/2000/svg">
  <text x="20"  y="20" >Example SVG text</text>
  <text x="20"  y="40" style="kerning:2;">Example SVG text</text>
  <text x="20"  y="60" style="letter-spacing:2;">Example SVG text</text>
</svg>

下面是上面代码的返回结果:

Example SVG text
Example SVG text
Example SVG text

上面的letter-spacing和kerning使用的是正数值,如果你使用负数值,那么字距将会收缩。

单词间距

你可以使用word-spacing CSS属性来指定单词的间距。单词的间距是指单词之间的空白符的数量。看下面的例子:

<svg xmlns="http://www.w3.org/2000/svg">
  <text x="20" y="20">
    Word spacing is normal
  </text>
  <text x="20" y="40"
        style="word-spacing: 4;">
      Word spacing is 4
  </text>
  <text x="20" y="60"
        style="word-spacing: 8;">
      Word spacing is 8
  </text>
</svg>

下面是返回的结果。注意:Firefox浏览器有可能不支持这个word-spacing属性。

Word spacing is normal
Word spacing is 4
Word spacing is 8

word-spacing的值也可以设置为负数,这时单词的间距将会被压缩。

文字布局-SVG文字没有自动换行功能

SVG文字是没有自动换行功能的。你必须自己定位每一行文本。需要制作多行文本的话,<tspan>元素可能会有所帮助,我们将在后面的文章中讲解这个元素。

你还可以将文字放置在一条路径上,例如一个圆或一条曲线上。达到这种效果你需要使用<textpath>元素。

旋转文本

你可以像旋转其它SVG图形一样旋转SVG文字。旋转SVG文字需要使用SVG transform属性。

<svg xmlns="http://www.w3.org/2000/svg">  
  <text x="20"  y="40"
          transform="rotate(30 20,40)"
          style="stroke:none; fill:#000000;"
          >Rotated SVG text</text>
</svg>

上面代码的返回结果是:

997.png

关于SVG的transform属性,后面会有文字详细讲解。

垂直文字

你可以使用旋转的方法来制作垂直的SVG文字,但是还有一种简单的方法来显示垂直文字。那就是使用writing-mode属性,将它的值设置为tb(Top to Bottom)。Firefox22以下的版本不支持这个属性。看下面的例子:

<svg xmlns="http://www.w3.org/2000/svg">  
  <text x="10" y="20" style="writing-mode: tb;">
    垂直文字
  </text>
</svg>

上面的代码的返回结果是:

垂
直
文
字

我们在来看看英文的情况:

<svg xmlns="http://www.w3.org/2000/svg">  
  <text x="10" y="20" style="writing-mode: tb;
  


 

您可能想查找下面的文章:

  • 实例讲解使用SVG制作loading加载动画的方法
  • 使用HTML5进行SVG矢量图形绘制的入门教程
  • HTML5新特性之用SVG绘制微信logo
  • 深入浅析HTML5中的SVG
  • 深入解析HTML5使用SVG图像时的viewBox属性用法
  • html5+svg学习指南之SVG基础知识
  • html5中svg canvas和图片之间相互转化思路代码
  • HTML中使用SVG与SVG预定义形状元素介绍
  • HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
  • HTML5之SVG 2D入门12—SVG DOM及DOM操作介绍

相关文章

  • 2018-12-0322个HTML5 技巧三
  • 2018-12-03HTML5视频播放器<video>和音频播放器<audio>用法
  • 2017-08-06突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
  • 2018-12-03font-weight:blod的跳动问题怎样用CSS解决
  • 2018-12-03分享一个用html5实现的贪吃蛇特效代码
  • 2018-12-03HTML5 高级教程之web Storage
  • 2018-12-03有没有好的用 HTML5 做电子杂志的制作平台?
  • 2018-12-03HTML5实现眼睛移动效果的示例
  • 2017-08-06localstorage和sessionstorage使用记录(推荐)
  • 2018-12-03H5的LocalStorage如何在本地存储刷新值

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 浅析HTML5中header标签的用法
    • HTML5无插件多媒体Media-音频audio与视频video的详细介绍
    • HTML5实现Notification API桌面通知功能
    • HTML5 CSS3模仿优酷视频截图功能示例
    • HTML5 canvas画布详解(二)
    • html5 利用重力感应实现摇一摇换颜色可用来做抽奖等等_html5教程技巧
    • HTML5中Web Sql的学习小结
    • 一些常用的HTML5模式(pattern) 总结
    • 如何用v-for给src属性赋值
    • 关于 HTML5 的七个传说小结_html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有