首页 > 其他分享 >【D3.js in Action 3 精译_024】3.4 让 D3 数据适应屏幕(上)

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

时间:2024-09-21 09:49:42浏览次数:3  
标签:输出 精译 js 离散 定义域 比例尺 数据 D3

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

  • 第一部分 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 本章小结

文章目录

《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(待翻译)。

标签:输出,精译,js,离散,定义域,比例尺,数据,D3
From: https://blog.csdn.net/frgod/article/details/142408664

相关文章

  • jsp大学生闲置物品交易平台k3y92
    jsp大学生闲置物品交易平台k3y9本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表项目功能用户,商品分类,商品信息技术要求:   开发语言:JSP前端使用:HTML5,CSS,JSP动态网页技术后端使用SpringBoot,Spring技......
  • jsp大学生西部计划管理系1a13g
    jsp大学生西部计划管理系1a13g本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表项目功能志愿者,岗位信息,补助信息技术要求:   开发语言:JSP前端使用:HTML5,CSS,JSP动态网页技术后端使用SpringBoot,Spring......
  • nodejs版本不对会怎么样
    使用与应用程序不匹配的node.js版本可能导致错误(编译、运行时)、不稳定性、性能问题和安全漏洞。为了避免版本不匹配,请检查应用程序要求,使用版本管理器,更新应用程序,或使用docker容器。Node.js版本不匹配的后果简短回答:Node.js版本不匹配会导致您的应用程序出现错误或无法正常......
  • nodejs版本兼容
    可以通过安装nvm(node版本管理器)并依次执行命令nvminstall、nvmaliasdefault和node--version来检查node.js版本兼容性。如果输出显示所需的版本号,则表明版本兼容;否则表明版本不兼容。其他兼容性注意事项包括软件包版本要求、使用最新版本的node.js以及部署和监控时的版本一致......
  • 494. 响应式动漫设计公司网站 大学生期末大作业 Web前端网页制作 html5+css+js
    目录一、网页概述二、网页文件 三、网页效果四、代码展示1.html2.CSS3.JS五、总结1.简洁实用2.使用方便3.整体性好4.形象突出5.交互式强六、更多推荐欢迎光临仙女的网页世界!这里有各行各业的Web前端网页制作的案例,样式齐全新颖,并持续更新!感谢CSDN,提供了这......
  • Nodejs 揭秘:单线程魔法背后的真相以及它如何为高性能应用程序提供动力
    Node.js有时被称为“单线程”,这个词对于习惯了Java或.NET等多线程环境的开发人员来说可能会令人困惑,甚至令人畏惧。然而,Node.js如何处理作业的真相远比这个简单术语所暗示的复杂和强大。在这篇博客中,我们将了解Node.js的架构、单线程意味着什么,以及Node.js如何通过其独......
  • Nodejs 的新功能
    TL;DR:让我们探索Node.js22的主要功能,包括ECMAScript模块支持和V8引擎更新。此版本引入了Maglev编译器和内置WebSocket客户端,以增强性能和实时通信。还涵盖了测试、调试和文件系统管理方面的改进。Node.js22将于10月进入LTS,现在是尝试这些功能的最佳时机!在本博......
  • nodejs中文官网
    node.js中文官方网站为https://nodejs.cn/,由node.js基金会维护,提供全面的node.js信息和资源,包括:文档、社区、资源和其他信息,特点是全面性、准确性、及时性、易用性和活跃社区。nodejs中文官网nodejs中文官网是哪个?Node.js中文官方网站为:https://nodejs.cn/详细介绍Node.js......
  • nodejs实际应用场景
    node.js是一种用于开发各种高性能应用程序的javascript运行时环境,其主要实际应用场景包括:后端web应用程序开发实时应用程序开发(例如聊天室和多人游戏)为移动应用程序提供后端服务构建轻量级微服务实时数据流处理和数据管道构建devops自动化和监控/日志记录物联网边缘计算和物......
  • nodejs应用领域
    node.js广泛应用于以下领域:后端开发(restapi、网站、web应用程序)事件流处理移动和桌面应用程序开发(跨平台、桌面应用程序)实时通信(实时聊天、多用户游戏)物联网(传感器数据采集、智能设备控制、自动化)大数据分析(分布式处理、可视化、机器学习)微服务架构(可扩展、模块化、独立的微服......