【D3.js in Action 3 精译】1.2.2 可缩放矢量图形(二)

news2025/1/14 17:54:10

当前内容所在位置

  • 第一部分 D3.js 基础知识
    • 第一章 D3.js 简介
      • 1.1 何为 D3.js?
      • 1.2 D3 生态系统——入门须知
        • 1.2.1 HTML 与 DOM
        • 1.2.2 SVG - 可缩放矢量图形 ✔️
          • 第一部分
          • 【第二部分】✔️
          • 第三部分(精译中 ⏳)
        • 1.2.3 Canvas 与 WebGL(待翻译)
        • 1.2.4 CSS(待翻译)
        • 1.2.5 JavaScript(待翻译)
        • 1.2.6 Node 与 JavaScript 框架(待翻译)
        • 1.2.7 Observable 记事本(待翻译)

译注
(接 1.2.2 小节(一))
……正如您看到的那样,viewBox 属性由四个属性值组成。前两个数值指定了 viewBox 的坐标系原点(xy)。本书将统一使用 0 0,知道这些值可以调整 SVG 容器在屏幕的可见部分还是很有帮助的。viewBox 后两个数值分别指定了宽度(width)和高度(height)。它们定义了 SVG 的宽高比,并确保它能完美适应任何容器并作相应缩放而不致失真。

(……而不致失真。)这里的关键是让 SVG 的尺寸与容器相适应。此时 SVG 所在容器为 <body> 元素,而 <body> 的尺寸又常常与浏览器视口(viewport)相适应。如果视口变得非常大,SVG 也会相应变大。通常,SVG 需要一个最大宽度,以免宽度超过页面上的其他内容。因此,SVG 需要放进一个 div 里面,并让该 div 的宽度为 100%、最大宽度为 1200px。为简便起见,我们将这些样式设为行内样式;实际项目中,它们都应该来自某个 CSS 文件。注意,为了让 SVG 水平居中,还多加了一个值为 0 auto 的外边距:

<div style="width:100%; max-width:1200px; margin:0 auto;">
  <svg viewBox="0 0 900 300" style="border:1px solid black;"> ... </svg>
</div>

改好后,再次调整浏览器大小,看看 SVG 是否能在保持最大宽度的情况下优雅适应任意屏幕大小。该方案有助于将 D3 可视化模块注入到响应式网页中,本书后续都将采用该方案进行演示。

2 SVG 的坐标系

实现 SVG 的响应式设计后,接下来需要重点考虑 SVG 图形在容器内的定位问题。SVG 容器就像一个空白画布,我们可以在上面绘制矢量图形。矢量图形是根据基本几何原理定义的,并相对于 SVG 容器的坐标系进行定位。

SVG 坐标系类似于直角坐标系,其二维平面通过两个相互垂直的轴来定位元素,即 x 轴和 y 轴;这两个轴的起点均为 SVG 容器的 左上角,如图 1.11 所示。y 轴的正方向为 从上到下,记住它可以少走很多弯路。

图 1.11 SVG 容器坐标系与元素位置图 1.11 SVG 容器坐标系与元素位置

要在 SVG 容器内定位一个元素,可以从左上角的原点开始向右移动。这样就得到了元素的水平位置(即 x);垂直位置(即 y)则从顶部开始向下移动。这些位置信息均由 SVG 图形的呈现属性(presentational attributes)来定义。

下面来看看构建 D3 项目常见的 SVG 图形及其主要的呈现属性。我们的目标并不是编写一份涵盖所有 SVG 图形及其功能特性的全方位指南,而是希望这些基础知识不会在后续的 D3 学习中拖您后腿。

数据可视化小知识:几何基元(Geometric primitives)

出色的艺术家可以用矢量图形来绘制任何事物,但您可能是带着更实际的目标来学习 D3 的。从这个角度来看,理解几何基元(也称图形基元,graphical primitives)的概念至关重要。几何基元是一些简单的形状,如点、线、圆和矩形。这些图形可以组合成更复杂的图形,尤其便于直观地展示信息。

几何基元对于理解现实世界中复杂的信息可视化也很有用。比如本书第 11 章要构建的树形布局,在您意识到它们也不过是一些圆和线时,也就不会那么令人生畏了;当您把交互式时间线看作是矩形和点的集合时,它们就更容易理解和创建了;即使是主要以多边形、点和线的形式出现的地理数据,如果将其分解为最基本的图形结构,也就不会那么令人困惑了。

3 直线

直线元素可能是所有 SVG 图形中最简单的。它需要两个点的位置信息作属性值,并在它们之间绘制出一条直线。回到 index.html 示例文件,在 SVG 容器内添加一个 <line /> 元素,并令其 x1y1 属性分别为 5045。也就是说,该直线的起点位于 SVG 坐标系的 (50, 45)。如果从 SVG 容器的左上角开始,右移 50px、下移 45px,就会到达该起点;同理,利用属性 x2y2 可将该直线的终点坐标设为 (140, 225),如图 1.12 所示。

<svg>
  <line x1="50" y1="45" x2="140" y2="225" />
</svg>

图 1.12 在 SVG 容器坐标系中定位直线元素图 1.12 在 SVG 容器坐标系中定位直线元素

如果保存并重新加载项目,会发现直线不可见——要让它可见,还需要设置其 stroke 属性(attribute)。stroke 用于控制直线段的描边颜色,其值与 CSS 的 color 属性(property)类似;该取值可以是一个颜色名称(blackblue …)、一个 RGB 颜色值(rgb(255,0,0))或一个十六进制值(#808080)。给直线段添加一个 stroke 描边属性,并选择合适的颜色(示例为黑色),应该就能显示了:

<line x1="50" y1="45" x2="140" y2="225" stroke="black" />

要设置线条宽度,使用 stroke-width 属性。该属性可接受一个绝对数(转换为像素)或一个相对值(%)。例如下面一行代码,直线的 stroke-width3px。如果未声明 stroke-width ,浏览器将默认取 1px

<line x1="50" y1="45" x2="140" y2="225" stroke="black" stroke-width="3" />

打开浏览器的检查工具(Inspect),找到 SVG 节点及其包含的直线。双击其中一个属性并修改它的值,观察新的属性值对直线起点或终点的影响。再尝试不同的值,以确认您充分理解了属性 x1y1x2y2 对直线位置和长度的影响。

接着,令 x1 属性值为 -20,如图 1.13 所示:

图 1.13 直线在 SVG 容器外的部分被隐藏图 1.13 直线在 SVG 容器外的部分被隐藏

看到直线的起点消失了吗? 在 SVG 中,任何位于 viewBox 之外的形状(或形状的一部分)在屏幕上都是不可见的。 此时该元素仍然在 DOM 中,并且可以访问和操作。当 SVG 元素不可见,而您又不清楚原因时,则需要首先检查该元素是否在 SVG 的 viewBox 之外!请牢牢记住,您可以随时通过开发工具查看 DOM 来找到它。前面讲过,在检查工具中只要将鼠标放到该元素上,就算它在 SVG 的 viewBox 之外,也会在视口中高亮显示。

注意

大多数 SVG 元素只需要一个自闭合标签即可(如使用 <line /> 而非 <line></line>)。与其他一些 HTML 标签一样,SVG 元素的固有结构在它们的自闭合标签内已经提供了所有必要的信息;但文本元素属于例外——其文本须放到开闭标签之间。

4 矩形

矩形元素 <rect />,顾名思义,会在屏幕上画出一个矩形。<rect /> 元素需要四个属性(attributes)才能正常显示。如图 1.14 所示,属性 xy 声明了矩形左上角的位置;属性 widthheight 分别控制其宽度和高度。在 SVG 容器中添加以下 <rect /> 元素及其属性:

<rect x="260" y="25" width="120" height="60"  fill="#6ba5d7" />

示例中,矩形的左上角位于 SVG 容器原点的右侧 260px ,下方 25px;该矩形宽 120px ,高 60px。与其他定位属性一样,这些属性值也可以用百分比来进行设置。例如将 width 设置为 50%,则该矩形将占据 SVG 容器宽度的一半。

图 1.14 在 SVG 坐标系中定位和调整矩形尺寸图 1.14 在 SVG 坐标系中定位和调整矩形尺寸

您或许注意到了,示例中的矩形被填充成了黑色。默认情况下,浏览器会将大多数 SVG 图形填充为黑色。要修改默认的填充色,可以设置元素的 fill 属性,令其值为任意 CSS 颜色值即可;要给矩形添加边框,则可以添加 stroke 属性。图 1.15 展示了几个例子。注意,如果不声明 stroke 属性,则矩形四周不会描边。此外,在最后一个示例矩形中,属性 fill-opacitystroke-opacity 可分别令 fillstroke 属性变为半透明效果。与 CSS 一样,不透明程度(opacity)可设为绝对值(介于 01 之间)或百分比(30%);与填充和描边相关的所有属性也都可以通过 CSS 文件进行设置或修改。

图 1.15 应用于矩形 SVG 图形的不同样式属性图 1.15 应用于矩形 SVG 图形的不同样式属性

如果想绘制带圆角的矩形,只需添加 rxry 属性即可,分别表示水平与垂直角半径。这些属性接受绝对值(像素)和相对值(百分比)。例如,下面矩形的每个角的半径都是 20px。将该矩形添加到示例中:

<rect x="260" y="100" width="120" height="60" rx="20" ry="20"  fill="#6ba5d7" />

讲到这您可能会问:SVG 中有没有专门画正方形的元素呢?答案是不需要——只要让 <rect /> 元素 widthheight 属性相同就行了。例如下面的 <rect /> 元素,最终将画出一个 60px × 60px 的正方形。在示例页中添加以下内容:

<rect x="260" y="175" width="60" height="60"  fill="transparent" stroke="#6ba5d7" />

作为参考,现在 SVG 画廊里有三种矩形:经典矩形、圆角矩形以及正方形。为了增添趣味性,先将颜色统一设为 #6ba5d7 ,再来玩玩它们的 strokefill 属性。注意,正方形上只有描边(stroke)是可见的,因为其 fill 属性值为 transparent(为 none 也是一样的)。这些矩形应该与图 1.16 相似,除非您更改了属性值,我们也希望您改改看!

<rect x="260" y="25" width="120" height="60" fill="#6ba5d7" />
<rect x="260" y="100" width="120" height="60" rx="20" ry="20" fill="#6ba5d7" />
<rect x="260" y="175" width="60" height="60" fill="transparent" stroke="#6ba5d7" />

图 1.16 三种 SVG 矩形效果图 1.16 三种 SVG 矩形效果

关于 SVG 描边(strokes)的位置

当对齐可视化项目中的图形时,需要特别注意:SVG 图形绘制出的描边是在内外边界上平均展布的。如下图所示,已知一个 width 属性为 40px 的矩形,令 stroke-width 的值为 1,则在视觉效果上会在矩形的左右两边各增加宽度为 0.5px 的描边(而不是下意识地以为的那样在各边均增加 1px),最终实际的总宽度为 41px;若令 stroke-width 的值为 2,则左右两边各增加 1px,以此类推。

描边宽度 stroke-width 对 SVG 图形实际宽度的影响描边宽度 stroke-width 对 SVG 图形实际宽度的影响

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1878998.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux多进程和多线程(一)

进程 进程的概念 进程&#xff08;Process&#xff09;是操作系统对一个正在运行的程序的一种抽象。它是系统运行程序的最小单位&#xff0c;是资源分配和调度的基本单位。 进程的特点如下 进程是⼀个独⽴的可调度的活动, 由操作系统进⾏统⼀调度, 相应的任务会被调度到cpu …

【鸿蒙学习笔记】尺寸设置

官方文档&#xff1a;尺寸设置 目录标题 width&#xff1a;设置组件自身的宽度&#xff0c;缺省时自适应height&#xff1a;设置组件自身的高度&#xff0c;缺省时自适应size&#xff1a;设置高宽尺寸。margin&#xff1a;设置组件的外边距padding&#xff1a;设置组件的内边距…

数据库-数据完整性-用户自定义完整性实验

NULL/NOT NULL 约束&#xff1a; 在每个字段后面可以加上 NULL 修饰符来指定该字段是否可以为空&#xff1b;或者加上 NOT NULL 修饰符来指定该字段必须填上数据。 DEFAULT约束说明 DEFAULT 约束用于向列中插入默认值。如果列中没有规定其他的值&#xff0c;那么会将默认值添加…

electron线上跨域问题

一、配置background.js win new BrowserWindow({webPreferences: {nodeIntegration: true, // 使渲染进程拥有node环境//关闭web权限检查&#xff0c;允许跨域webSecurity: false,// Use pluginOptions.nodeIntegration, leave this alone// See nklayman.github.io/vue-cli-p…

【计算机网络】HTTP——基于HTTP的功能追加协议(个人笔记)

学习日期&#xff1a;2024.6.29 内容摘要&#xff1a;基于HTTP的功能追加协议和HTTP/2.0 HTTP的瓶颈与各功能追加协议 需求的产生 在Facebook、推特、微博等平台&#xff0c;每分每秒都会有人更新内容&#xff0c;我们作为用户当然希望时刻都能收到最新的消息&#xff0c;为…

常用字符串方法<python>

导言 在python中内置了许多的字符串方法&#xff0c;使用字符串方法可以方便快捷解决很多问题&#xff0c;所以本文将要介绍一些常用的字符串方法。 目录 导言 string.center(width[,fillchar]) string.capitalize() string.count(sub[,start[,end]]) string.join(iterabl…

收银系统源码-千呼新零售【全场景收银】

千呼新零售2.0系统是零售行业连锁店一体化收银系统&#xff0c;包括线下收银线上商城连锁店管理ERP管理商品管理供应商管理会员营销等功能为一体&#xff0c;线上线下数据全部打通。 适用于商超、便利店、水果、生鲜、母婴、服装、零食、百货、宠物等连锁店使用。 详细介绍请…

基于星火大模型的群聊对话分角色要素提取挑战赛-Lora微调与prompt构造

赛题连接 https://challenge.xfyun.cn/topic/info?typerole-element-extraction&optionphb 数据集预处理 由于赛题官方限定使用了星火大模型&#xff0c;所以只能调用星火大模型的API或者使用零代码微调 首先训练数据很少是有129条&#xff0c;其中只有chat_text和info…

模版方法模式详解:使用和实现的指南

目录 模版方法模式模版方法模式结构模版方法模式适合应用场景模版方法模式优缺点练手题目题目描述输入描述输出描述题解 模版方法模式 模板方法模式是一种行为设计模式&#xff0c; 它在超类中定义了一个算法的框架&#xff0c; 允许子类在不修改结构的情况下重写算法的特定步…

游戏推荐: 植物大战僵尸杂交版

下载地址网上一搜就有. 安装就能玩. 2是显血. 4显示植物血, 5是加速. 都是左手主键盘的按钮, 再按是取消. 比较刺激: ps: 设置里面还能打开自动收集阳光和金币.

Elasticsearch (1):ES基本概念和原理简单介绍

Elasticsearch&#xff08;简称 ES&#xff09;是一款基于 Apache Lucene 的分布式搜索和分析引擎。随着业务的发展&#xff0c;系统中的数据量不断增长&#xff0c;传统的关系型数据库在处理大量模糊查询时效率低下。因此&#xff0c;ES 作为一种高效、灵活和可扩展的全文检索…

斜率优化DP——AcWing 303. 运输小猫

斜率优化DP 定义 斜率优化DP&#xff08;Slope Optimization Dynamic Programming&#xff09;是一种高级动态规划技巧&#xff0c;用于优化具有特定形式的状态转移方程。它主要应用于那些状态转移涉及求极值&#xff08;如最小值或最大值&#xff09;的问题中&#xff0c;通…

加密与安全_三种方式实现基于国密非对称加密算法的加解密和签名验签

文章目录 国际算法基础概念常见的加密算法及分类签名和验签基础概念常见的签名算法应用场景 国密算法对称加密&#xff08;DES/AES⇒SM4&#xff09;非对称加密&#xff08;RSA/ECC⇒SM2&#xff09;散列(摘要/哈希)算法&#xff08;MD5/SHA⇒SM3&#xff09; Code方式一 使用B…

每日算法-插值查找

1.概念 插值查找是一种改良版的二分查找,其优势在于,对于较为均匀分布的有序数列,能够更快地使得mid中间游标快速接近目标值. 2.计算公式 中间游标计算公式. 公式说明: 公式的主要思路是,以第一次定位mid中间游标为例, 在接近平均分配的情况下,左右游标之间的差值表示总计供…

Linux线程同步【拿命推荐版】

目录 &#x1f6a9;引言 &#x1f6a9;听故事&#xff0c;引概念 &#x1f6a9;生产者消费者模型 &#x1f680;再次理解生产消费模型 &#x1f680;挖掘特点 &#x1f6a9;条件变量 &#x1f680;条件变量常用接口 &#x1f680;条件变量的原理 &#x1f6a9;引言 上一篇…

新的特性使得数据处理更加直观本教程将带你逐步了解如何使用Java Stream API

本人详解 作者:王文峰,参加过 CSDN 2020年度博客之星,《Java王大师王天师》 公众号:JAVA开发王大师,专注于天道酬勤的 Java 开发问题中国国学、传统文化和代码爱好者的程序人生,期待你的关注和支持!本人外号:神秘小峯 山峯 转载说明:务必注明来源(注明:作者:王文峰…

暑假集中备考2024年汉字小达人:来做18道历年选择题备考吧

结合最近几年的活动安排&#xff0c;预计2024年第11届汉字小达人比赛还有4个多月就启动&#xff0c;那么孩子们如何利用这段时间有条不紊地准备汉字小达人比赛呢&#xff1f; 我的建议是充分利用即将到来的暑假&#xff1a;①把小学1-5年级的语文课本上的知识点熟悉&#xff0…

[数据集][目标检测]围栏破损检测数据集VOC+YOLO格式1196张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;1196 标注数量(xml文件个数)&#xff1a;1196 标注数量(txt文件个数)&#xff1a;1196 标注…

一篇就够了,为你答疑解惑:锂电池一阶模型-离线参数辨识(附代码)

锂电池一阶模型-参数离线辨识 背景模型简介数据收集1. 最大可用容量实验2. 开路电压实验3. 混合动力脉冲特性实验离线辨识对应模型对应代码总结下期预告文章字数有点多,耐心不够的谨慎点击阅读。 下期继续讲解在线参数辨识方法。 背景 最近又在开始重新梳理锂电池建模仿真与S…

Spring底层原理之bean的加载方式八 BeanDefinitionRegistryPostProcessor注解

BeanDefinitionRegistryPostProcessor注解 这种方式和第七种比较像 要实现两个方法 第一个方法是实现工厂 第二个方法叫后处理bean注册 package com.bigdata1421.bean;import org.springframework.beans.BeansException; import org.springframework.beans.factory.config.…