【D3.js in Action 3 精译_024】3.4 让 D3 数据适应屏幕(上)

news2024/9/21 15:06:54

当前内容所在位置(可进入专栏查看其他译好的章节内容)

  • 第一部分 D3.js 基础知识
    • 第一章 D3.js 简介(已完结)
      • 1.1 何为 D3.js?
      • 1.2 D3 生态系统——入门须知
      • 1.3 数据可视化最佳实践(上)
      • 1.3 数据可视化最佳实践(下)
      • 1.4 本章小结
    • 第二章 DOM 的操作方法(已完结)
      • 2.1 第一个 D3 可视化图表
      • 2.2 环境准备
      • 2.3 用 D3 选中页面元素
      • 2.4 向选择集添加元素
      • 2.5 用 D3 设置与修改元素属性
      • 2.6 用 D3 设置与修改元素样式
      • 2.7 本章小结
    • 第三章 数据的处理 ✔️
      • 3.1 理解数据(已完结)
      • 3.2 准备数据(已完结)
      • 3.3 将数据绑定到 DOM 元素(已完结)
        • 3.3.1 利用数据给 DOM 属性动态赋值
      • 3.4 让数据适应屏幕 ✔️
        • 3.4.1 比例尺简介(上篇) ✔️
        • 3.4.2 线性比例尺(中篇,精译中 ⏳)
        • 3.4.3 分段比例尺(下篇,待翻译 ⏳)
      • 3.5 加注图表标签
      • 3.6 本章小结

文章目录

    • 3.4 让数据适应屏幕 Adapting data for the screen
      • 3.4.1 比例 Scales

《D3.js in Action》全新第三版封面

《D3.js in Action》全新第三版封面

译者按
上一节介绍了 D3 数据绑定相关的知识,并将整理好的数据集绑定到本章的示例条形图中。这一节就来看看 D3 在调整数据以适配屏幕显示方面有什么独道之处。由于篇幅较长,这一节拟分为上、中、下三篇进行介绍。本篇为上篇,主要介绍 D3 比例尺相关的内容。一起来看看吧。

3.4 让数据适应屏幕 Adapting data for the screen

创建数据可视化时,通常会将数据转化为 视觉变量(visual variables),例如元素的大小、颜色或者屏幕上的位置等。这种转换在 D3 项目中通常是由各类 比例尺(scales) 实现的,如图 3.22 中的最后一步所示:

图 3.22 D3 数据工作流最后一步:使用比例尺实现数据值到屏幕属性值(长度、位置、颜色等)的转换

图 3.22 D3 数据工作流最后一步:使用比例尺实现数据值到屏幕属性值(长度、位置、颜色等)的转换

3.4.1 比例 Scales

比例尺是将数据中的一个值作为输入(input)并返回一个输出值的函数。该输出值可以直接用来设置数据可视化元素的尺寸大小、位置或者颜色。说得再具体些,输入数据是 定义域(domain 中的一份子;定义域是该数据能取到的值的某个范围。在屏幕上,定义域又被映射到某个 值域(range 上;而值域则是输出值能取到的值的某个范围。

D3 提供了多个比例尺函数,它们各自接收不同种类的定义域与值域。以线性比例尺 d3.scaleLinear() 为例,要初始化该比例尺函数,需要链式调用 domain()range() 方法,并将包含所有可能性的数值范围作为参数传入,参数类型为一个有序数组,里面分别包含一个最小值与一个最大值:

const myScale = d3.scaleLinear()
  .domain([0, 200])
  .range([0, 20]);

得到的比例尺函数与 JavaScript 其他函数相比没什么不同。将定义域中的某个值作为参数传入,函数则会从值域中返回一个对应的结果:

myScale(100) => 10

比例尺的输入与输出值既可以是 连续的(continuous 也可以是 离散的(discrete。连续值可以在预定范围内的任意位置存在,例如 0 到 100 之间的某个浮点数,或者介于 2020 年 6 月到 2021 年1 月之间的某个日期等等。一个连续的定量型数据可被视为一个可滑动的刻度尺;另一方面,离散型输入与输出则对应一组预设值,例如现有 T 恤的尺码型号一般为 XS 特小号、S 小号、M 中号、L 大号以及 XL 加大号,或者颜色类型包含蓝色、绿色、黄色和红色等等。定性型数据就如同将物品放入不同的盒子,每个物品只能放入一个盒子。

在 D3 中,定量数据往往与一个有着连续型定义域(continuous domain)的比例尺相关联;相反,定性数据则对应某个离散型定义域(discrete domain),通常是一个由所有可能的值所构成的数组。同理,一个有着连续型输出结果的比例尺可在指定的值域内取到任意值;而离散型输出只能返回预设值列表中的某个结果。

根据连续与离散、输入与输出等概念,可将 D3 比例尺分为以下四类:

  • 具有连续型输入、连续型输出的比例尺;
  • 具有离散型输入、离散型输出的比例尺;
  • 具有连续型输入、离散型输出的比例尺;
  • 具有离散型输入、连续型输出的比例尺。

假设我们在谷歌上搜索 2021 年推出的电视剧,并将前 10 个结果汇总到一个数据集中(即撰写本章时笔者进行的一个练习操作),然后分别搜集每部电视剧的体裁、“烂番茄”热度得分(译注:“烂番茄”即 Rotten Tomatoes,一个专注于影视节目评价的知名网站,1998 年成立于美国。)、专业影评人综合评分、以及可收看平台,将得到一个如下表 3.2 所示的数据集。其中既包含连续型数据(如观众评分和影评人评分),同时也有离散型数据(如体裁与可收看平台)。要绘制如图 3.23 所示的条形图,需要利用 D3 比例尺分别对上述每个维度进行处理。请注意,该条形图旨在演示 D3 比例尺的不同类型及其用法,您无需亲自创建。

译注

烂番茄(Rotten Tomatoes) 网站是美国一家专注于线上影视评论的知名网站,于 1998 年 8 月由加州大学伯克利分校的三名本科生 Senh Duong、Patrick Y. Lee 和 Stephen Wang 联合创办。虽然“烂番茄”一名与观众投掷烂番茄以反对拙劣的舞台表演的做法有关,但三人起这个名字的直接灵感据称来自 1992 年的一部加拿大电影《Léolo》中的一个类似场景。(摘自 维基百科)

表 3.2 谷歌推荐的 2021 年度热播电视剧

剧名 *体裁大众评分 (%)专业评分 (%)观看平台
Nine Perfect StrangersDrama5962Prime
MaidDrama8894Netflix
KatlaDrama78100Netflix
Jupiter’s LegacyAction7340Netflix
Hit & RunAction7282Netflix
The IrregularsCrime5480Netflix
Shadow and BoneAction8988Netflix
ClickbaitCrime6456Netflix
Sex/LifeComedy3423Netflix
The Wheel of TimeAction6482Prime

数据来源:www.rottentomatoes.com(*:为演示起见,剧名、体裁、观看平台等维度均不作翻译)

图 3.23 2021 年度热播剧专业点评与大众评分对比:四个维度均由相应的比例尺处理绘制而成

图 3.23 2021 年度热播剧专业点评与大众评分对比:四个维度均由相应的比例尺处理绘制而成

条形图中的每个矩形都对应一部热播剧,其长度与专业影评人给出的平均得分成正比。为了计算各矩形条的长度,需要使用上述 D3 比例尺中的第一类。其输入参数为专业影评人评分,输出则是一个连续型数值,对应该矩形条长度。

这个比例的定义域为 0% 到 100% 之间(即专业评分的取值范围),与之对应的矩形条长度值域为(以像素为单位):

定义域 => [0, 100] 输入的最小值和最大值,单位:%
值域  => [0, 500] 对应输出的最小值和最大值,单位:像素

再来看矩形条的颜色。它代表每部剧的体裁。要给不同的热播剧上色,需要用到第二类比例尺:输入数据为离散型数值(即体裁),输出为离散型数值(即对应的颜色)。该比例尺的定义域是一个由不同体裁构成的数组,值域则是一个对应的颜色名称数组:

定义域 => ["Drama", "Action", "Crime", "Comedy"]  输入值的取值范围
值域 => ["purple", "blue", "green", "yellow"]  对应输出的取值范围

此外,每个矩形条的末端还用了一个表情符号来表示大众热度评分情况。热度得分超过 80% 的电视剧将显示成一个“心形眼”表情符号(♥‿♥);热度在 70% 到 80% 之间的,则显示一个微笑表情(⌒‿⌒);热度在 60% 到 70% 的,则显示为一个中性表情(●_●);而热度不足 60% 的电视剧则会得到一个苦闷的表情(⊙﹏⊙)。于是我们就得到了一组连续的输入,即大众热度评分;以及一组离散的输出,即对应的表情符号:

定义域 => [60, 70, 80] 输入值的临界点
值域  => ["⊙﹏⊙", "●_●", "⌒‿⌒", "♥‿♥"] 对应的输出结果

最后要处理的,是矩形条的方位计算——各矩形条沿图表纵轴均匀分布。方位的计算,需要借助上述第四类 D3 比例尺:接受离散型输入(即剧名),并返回一个连续型输出(即纵轴坐标值):

定义域 => ["Nine Perfect Strangers", "Maid", "Katla", ...] 输入值列表
值域  => [0, 500] 对应输出的最小值和最大值,单位:像素

由此可见,每一类比例尺都包含多个比例尺函数,撰写本书时,d3-scale 模块已经提供了 20 个以上的现成比例尺函数(详见 https://d3js.org/d3-scale)。本章将重点介绍 d3.scaleLinear()d3.scaleBand() 函数,因为它们在 D3 开发中最常用,并且本章的示例条形图也需要依靠它们来实现。本书还将介绍许多其他的比例尺工具。想了解更多 D3 现有比例尺函数的概述性介绍、以及有利于手头项目比例尺函数合理选型的决策树,详见本书 附录 B(待翻译)。

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

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

相关文章

AJAX(一)HTTP协议(请求响应报文),AJAX发送请求,请求问题处理

文章目录 一、AJAX二、HTTP协议1. 请求报文2. 响应报文 三、AJAX案例准备1. 安装node2. Express搭建服务器3. 安装nodemon实现自动重启 四、AJAX发送请求1. GET请求2. POST请求(1) 配置请求体(2) 配置请求头 3. 响应JSON数据的两种方式(1) 手动,JSON.parse()(2) 设置…

AI绘画Flux【lora模型】【微缩景观】:惊艳!3D场景融入手机上的微景观!

大家好,我是灵魂画师向阳 今天和大家分享一款基于Flux底模训练的微缩景观模型——FLUX|手机上的微景观。此模型主要将手机作为微型景观的基底,强制将3d情景融入手机并控制在手机屏幕上方范围内。 作者在使用提示词直出和使用该Loar提示词生成的图片进行…

rsyslogd 内存占用很高解决方案

在Kubernetes(K8S)集群中,监控日志是非常重要的,而rsyslogd是Linux系统中用于处理系统和应用程序日志的守护进程。有时候rsyslogd可能会占用较高的内存,这时候我们就需要对其进行优化和调整。 阿里云虚拟服务器&…

JavaEE: 深入探索TCP网络编程的奇妙世界(二)

文章目录 TCP核心机制TCP核心机制二: 超时重传为啥会丢包?TCP如何对抗丢包?超时重传的时间设定超时时间该如何确定? TCP核心机制 书接上文~ TCP核心机制二: 超时重传 在网络传输中,并不会一帆风顺,而是可能出现"丢包情况"~ 为啥会丢包? 产生丢包的原因有很多…

其他比较条件

使用BETWEEN条件 可以用BETWEEN范围条件显示基于一个值范围的行。指定的范围包含一个下限和一个上限。 示例:查询employees表,薪水在3000-8000之间的雇员ID、名字与薪水。 select employee_id,last_name,salary from employees where salary between 3…

移植Linux:如何制作rootfs?

一、分析 1. 文件系统简介 理论上说一个嵌入式设备如果内核能够运行起来,且不需要运行用户进程的话,是不需要文件系统的,文件系统简单的说就是一种目录结构,由于 linux操作系统的设备在系统中是以文件的形式存在,将这…

Cypress安装与启动(开始学习记录)

一 Cypress安装 使用npm安装 1.查看node.js npm的版本,输入 npm --version 和 node --version,node.js没安装的可以去中文网下载最新稳定版安装,npm不建议升级到最新版本,会导致安装Cypress时Error: Cannot find module ansi-st…

2-94 基于matlab的最佳维纳滤波器的盲解卷积算法

基于matlab的最佳维纳滤波器的盲解卷积算法。维纳滤波将地震子波转换为任意所需要的形态。维纳滤波不同于反滤波,它是在最小平方的意义上为最 佳。基于最佳纳滤波理论的滤波器算法是莱文逊(Wiener—Levinson)算法。程序提供了4种子波和4种期望输出:零延迟…

JavaEE: 深入探索TCP网络编程的奇妙世界(一)

文章目录 TCPTCP协议段落格式TCP相关机制TCP核心机制一: 确认应答32位序号32位确认序号后发先至问题 TCP TCP要比UDP更复杂一些~ TCP的全称为"传输控制协议".他负责对数据的传输进行一个详细的控制. TCP协议段落格式 源/目的端口号: 表示数据是从哪个进程来.到哪个…

Innodb内存结构

缓冲池Buffer Pool: 缓冲池是innodb内存结构缓冲区中的核心部分,在服务启动的时候服务器会向操作系统申请一块大小为128MB的内存空间,所有对数据库中数据的增删查改操作均在缓冲池bufferPool中完成,并且缓冲区中其他组件的描述信息也都存储在…

[Linux]Vi和Vim编辑器

Vi和Vim编辑器 Linux系统会内置vi文本编辑器, 类似于windows中的记事本 Vim具有程序编辑的能力, 可以看作是Vi的增强版本, 可以进行语法检查, 代码补全,代码编译和错误调整等功能 Vi和Vim的模式 快速入门 使用vim开发一个Hello.java程序 通过Xshell连接Linux系统命令行输入…

技术美术百人计划 | 《4.5 DOF景深算法》笔记

1. 景深定义 景深(Depth of Field,DOF),是指在摄影机镜头或其他成像器前沿能够取得清晰图像的成像所测定的被摄物体前后距离范围。镜头光圈、镜头焦距、及焦平面到拍摄物的距离是影响景深的重要因素。在聚焦完成后,焦点…

2024年Q3国际信息系统安全认证联盟(ISC2)内部研讨会要点分享

2024年是CISSP认证成立30周年,这是一项具有里程碑意义的成就,代表了CISSP在网络安全领域的卓越、创新和领导力。博主于今年9月份参加了ISC2(国际信息系统安全认证联盟)组织的2024年第3季度内部网络研讨会,针对会议中的…

【sgCreateCallAPIFunction】自定义小工具:敏捷开发→调用接口方法代码生成工具

<template><div :class"$options.name" class"sgDevTool"><sgHead /><div class"sg-container"><div class"sg-start"><div style"margin-bottom: 10px">调用接口方法定义列表</div…

QT 带箭头的控件QPolygon

由于对当前项目需要绘制一个箭头控件&#xff0c;所以使用了QPainter和QPolygon来进行绘制&#xff0c;原理就是计算填充&#xff0c;下面贴出代码和效果图 这里简单介绍下QPolygon QPolygon是继承自 QVector<QPoint>那么可以很简单的理解为&#xff0c;他就是一个点的…

探索丹摩智算平台的奇妙之旅:我的CogVideoX实践实验与深刻体验

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀CogVideoX &#x1f4d2;1. 初识CogVideoX&#x1f4da;2. 部署与准备&#x1f31e;在丹摩智算平台上创建实例&#x1f338;CogVideoX代码仓库…

Linux基础命令——账户简单管理

一.添加用户 命令&#xff1a;useradd username eg:useradd yy 添加用户名为yy的用户 注意&#xff1a; inux中如果新建用户的时候没有用-d参数指定家目录&#xff0c;那么用户的家目录是什么? 指定的默认/home下面&#xff0c;以username命名 二.修改账户口令/密码 命令&…

漫步者头戴式耳机哪个型号好?热门主流头戴式耳机专业深度评测

一直以来头戴式蓝牙耳机凭借其独特的优势&#xff0c;逐渐成为了音乐爱好者、游戏玩家以及日常通勤者的首选&#xff0c;它们不仅融合了卓越的音质体验、便捷的无线连接&#xff0c;还融入了先进的降噪技术和人性化的佩戴设计&#xff0c;为用户带来了前所未有的听觉盛宴与舒适…

css实现居中的方法

水平居中 1. 行内设置text-align 给父元素设置text-align为center&#xff0c;一般用于实现文字水平居中 2. 给当前元素设置margin&#xff1a;0 auto 原理&#xff1a;块级独占一行&#xff0c;表现为在水平方向上占满整个父容器&#xff0c;当水平方向padding&#xff0c;…

500元以内头戴式耳机哪款好?盘点500元以内百元宝藏品牌机型推荐

作为耳机发烧友&#xff0c;我深知一副优质的头戴式耳机都能为我们带来沉浸式的听觉体验&#xff0c;但然而&#xff0c;面对市场上琳琅满目的耳机品牌和型号&#xff0c;500元以内头戴式耳机哪款好&#xff1f;对于这个问题我将为大家盘点500元以内百元宝藏品牌机型推荐无论你…