当前位置: 首页 > news >正文

【D3.js in Action 3 精译_030】3.5 给 D3 条形图加注图表标签(下):Krisztina Szűcs 人物专访 + 3.6 本章小结

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

  • 第一部分 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.2.1 基于 Mocha 测试 D3 线性比例尺(DIY 实战)
        • 3.4.3 分段比例尺(下篇)
          • 3.4.3.1 使用 Observable 在线绘制 D3 条形图(DIY 实战)
      • 3.5 加注图表标签(上篇)
        • 3.5.1 人物专访:Krisztina Szűcs(下篇) ✔️
      • 3.6 本章小结 ✔️

文章目录

  • 3.5.1 人物专访:克里斯蒂娜·苏茨(Krisztina Szűcs)
  • 3.6 本章小结

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

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

译者按
秉承“他山之石,可以攻玉”的创作理念,本章同前面两章一样,在章节末尾附上了一篇人物专访。本次接受访谈的数据可视化名家是一位来自匈牙利的著名平面设计师 克里斯蒂娜·苏茨,她以其在设计和数据可视化方面的独特视角和创新方法闻名于世。接下来就放松放松,看看她在学习 D3 的时候都踩过哪些坑,又有什么样的经验之谈给到大家——

3.5.1 人物专访:克里斯蒂娜·苏茨(Krisztina Szűcs)


苏茨(Szűcs) 是数据可视化领域的知名设计师 1

【问】能否介绍一下您的背景,以及您是如何发现 D3.js 的?

【Szűcs】 好的。我并没有编程相关的背景,我拿的是平面设计的硕士学位,只是在 Flash 盛行的时代接触过一些 ActionScript。起初,我用的是 Processing 2 来进行数据可视化的创作;但当我在 2012 年上网时,发现几乎人人都在尝试这个叫 d3.js 的新鲜事物,并且它还非常适合做数据可视化,我这才决定试着去学习它的。

【问】那您是怎样学习 D3 的呢?其间都遇到过哪些主要困难,后来又是怎么克服它们的呢?

【Szűcs】 我对学习新的工具库或者语言其实并不很热衷,反倒更喜欢只学一门,然后一直用下去(哈哈)。当一个崭新的新事物闪亮登场时,我通常会很不高兴,因为它貌似成了业内的新标配,而我自己也再无法将它拒之门外,不得不投入时间和精力去学习了解它了。

因此,当 D3.js 出现时,每个人都开始谈论起它来。我那会儿也已经知道自己想要创建的,是具有交互效果的数据可视化作品,所以就做了个决定:学习 D3 是我当时必须得拿下的一件事,也是唯一的一件。

我记得这比我预想的要困难得多。我按照 Scott Murray 编写的教程《Web 交互式数据可视化》(Interactive Data Visualization for the Web) 进行学习,然后尝试将所学应用到自己的项目中。一开始按照教程的每一步来操作,这些知识都很有用;可当我最终尝试用自己的数据来应用这些示例时,却遭遇了失败——因为大多数情况下我的真实数据集都太复杂了,在让这些数据与 D3.js 有机结合的过程中,我着实遇到了不小的困难。

此外,我从一开始就想制作大型的、与众不同的视觉效果,而当时并没有专门的教程,所以一时也很难弄明白如何从简单的柱状图过渡到我脑海中那些非常规的复杂设计。我也只能反复练习与尝试,直到每个部分都和我想象中的效果一致才肯罢休。

【问】除了 D3 之外,您还用过其他可视化工具吗?在您当前的数据可视化工作流程中,D3 大概处在一个怎样的位置?

【Szűcs】 我用过像 Figma 这样的设计工具来设计我的可视化作品外观;同时还用过 ExcelPython,主要是进行一些数据集的处理或者收集方面的工作。

在使用设计工具时,我会抱着设计师的心态,先不去想那些在实际开发可视化作品时必须要面对的限制条件、或者不得不解决的所有难题。这有助于我避免限制自己的想法,从而构建出更好的视觉效果。当视觉效果以静态图片的形式呈现出来后,我就会切换到“开发者思维”,尝试重新创建我在设计稿中看到的一切。有时我会做一些调整,但当我设计的东西在开发时遭遇挑战,我会强迫自己先去解决代码方面的难题,而不是先给编程一路开绿灯,回头再把设计改成简单的东西。我还发现,对我来说这是学习 D3.js 的最佳方法。

【佳作赏析:动画版体坛赛事(详见:https://krisztinaszucs.com/)】

图 1 国际泳联 2022 世锦赛男子 200 米仰泳比赛的动画演示截图

【图 1 国际泳联 2022 世锦赛男子 200 米仰泳比赛的动画演示截图】


【问】和我们说说您创作的这部作品(Animated Sport Results,动画版体坛赛事)吧。

【Szűcs】 我当时本来一直打算为 2020 年奥运会创作一部可视化作品。国际泳联 2022 年举办的这次世锦赛刚好就是个吸引了很多人关注的一项盛大国际体育赛事,并且里面的赛事数据资源也是现成的。我想,要是能创建一个与比赛相关的可视化作品,那么今后就可以在其他体育赛事(比如世锦赛)、甚至其他使用类似计分规则的体育项目中多次复用了。

我也希望观众能重温比赛的精彩,所以没有一开始就公布最终结果,而是慢慢地展示比赛的进程。

我很喜欢 Chartball.com 3 网站和《纽约时报》上类似的可视化设计,它们都是我这部作品的灵感来源。

【问】您能再分享分享下面这部作品的创作过程吗?

【Szűcs】 刚开始着手这个项目时,我就明确了自己要创作的是一部动画版的作品,并且主打极简主义风格。作品中要带有一抹红色,这让我在脑海中联想到了日本(2020 年奥运会就是在东京举办的)。

图 2 Krisztina Szűcs 为其作品《Animated Sport Results》准备的可视化设计草图

【图 2 Krisztina Szűcs 为其作品《Animated Sport Results》准备的可视化设计草图】


【Szűcs】 然而我并不知道具体要为哪项体育赛事构建可视化项目,所以就依次为跳高、跳远、标枪、铁饼、跑步、室内自行车……等不同的体育项目绘制了许多草图,最后还为水球项目设计了一版和得分进度相关的可视化效果(即上图右下角那幅)。不久我就意识到,得分进度可视化将会是我复用频率最高的一个设计,一旦对外观感到满意,我就开始着手写代码了。

当然,当时离奥运会还有几个月,我还没拿到任何数据,所以用了上届奥运会的比赛成绩作为样本数据。此外,我还给自己创建了一个以可视化主体效果为中心的用户界面,以便在调色板或数据集之间快速切换。

我在奥运会开幕的前几周便做好了准备,刚好欧洲足球锦标赛也在那段时间举行。尽管我的可视化作品都是为进球数在十个以上的赛事设计的,但还是准备用足球比赛的结果来进行预演。我加载了足球比赛的数据文件,即使只有 1 ~ 3 个进球,可视化也能正常工作。其间我还做了些改进,引入了点球得分相关的可视化效果。

图 3 根据 2021 年欧洲足球锦标赛的结果而尝试创作的得分情况可视化效果截图

【图 3 根据 2021 年欧洲足球锦标赛的结果而尝试创作的得分情况可视化效果截图】


【Szűcs】 但奥运会开赛后,我无法拿到最新的比赛数据,因为数据都是以 PDF 格式发布在官方网站上的。这期间由于从 PDF 获取数据是一个相当繁琐的手动过程,这是我始料未及的,因此只成功制作并发布了两三个动画作品。这次经历也让我明白,应该去寻找更好的数据源进行创作。所幸其他赛事,比如世锦赛或体育协会的网站可以提供质量更好、也更易获取的数据源。在奥运会结束后,我拿到了更好的数据源,才创作出了更多这样的动画作品。

【问】您是用 D3 创作的这些动画,还是用了其他的什么库或者工具?

【Szűcs】 我只用了 D3.js,但为了导出图片,我还用了录屏软件 ScreenToGif 来录制屏幕。

【问】您的作品风格极具辨识度,它们是怎么逐步演变过来的呢?在数据可视化领域有没有什么诀窍可以树立像您的作品这样的影响力(your voice)呢?

【Szűcs】 我在大学期间学习的平面设计知识无疑为我打下了坚实的基础,但当下的平面设计趋势(印刷、品牌设计、包装设计、排版等等)也对我的设计风格产生了很大影响。每天我都会浏览平面设计相关的网站来不断捕捉灵感。每当发现非常喜欢的视觉元素或设计图案,我就会立即开始思考“这可能是个不错的可视化应用(dataviz)”。

当然,并不是所有的视觉趋势都可以用图表来表示;但我在努力弄清怎样借助 D3.js 来重塑某些特定而又不寻常的外观效果的过程中,收获了很多东西。

【问】您在学习 D3 和创建个人项目方面,有没有什么想与读者朋友们分享的技巧呢?

【Szűcs】 要注意将设计和编码阶段分开(Separate the design and the coding phase in your process)。先设计出最终的外观效果,与此同时要主动屏蔽那些让你觉得后续开发阶段实现起来会有多么困难的任何想法。这样,才能不断遇到需要解决的新问题,从而学到很多新技巧。

如果设计不是你的强项,作为日常练习也可以随时去搜寻一些优秀的可视化作品,然后试着从头开始重新创作一遍。


3.6 本章小结

  • 在数据可视化中,我们主要处理两种数据类型:定量型数据和定性型数据。定量型数据是数字信息,如体重或温度;而定性数据通常是文本信息,如国家名称或电影类型。
  • 作为 D3 开发人员,我们需要处理不同格式的数据集。最常见的是表格格式,如 CSV 文件和 JSON 文件中的 JavaScript 对象;此外,数据也可以按照不同层次、网络结构或者地理信息可视化的特定方式进行组织。
  • D3 提供了将特定格式的数据集加载到项目中的工具函数。例如,d3.csv()d3.json() 函数可分别加载 CSVJSON 格式文件。在加载数据时,D3 会将其转换为对象数组。
  • 加载外部数据集时,我们通常需要确保数据(尤其是数值型数据)格式正确。d3.csv()d3.json() 的回调函数可以逐行访问数据集,是执行类型转换和其他数据操作的理想场所。
  • 数据加载是一个异步过程,这意味着加载时浏览器会继续读取与执行脚本:
    • 在操作数据前,必须等待数据完成加载。为此,可以使用 JavaScript 期约接口中的 then() 方法;
    • then() 方法的回调函数可在加载结束后访问整个数据集。然后,可以在构建可视化效果前进一步测量和重构数据。
  • 数据绑定模式产生的 SVG 元素数量与数据(单个数据点或者表格数据集中的行)数量相同:
    • 数据绑定模式由三个链式调用的方法组成:selectAll()data()join()
    • 使用数据绑定模式生成 SVG 元素后,就能通过内联函数(译注:inline functions,即访问器函数 accessor)访问与每个元素绑定的数据项。
    • 绑定到元素上的数据也会传递给它的后代元素。
  • D3 比例尺能将数据集中的值转换为用于指定 SVG 元素样式的各类属性值,如尺寸大小、位置及颜色:
    • 根据输入输出值是离散型还是连续型,可以将 D3 比例尺分为四个系列;
    • 线性比例尺从连续型定义域获取输入,并从连续型值域中返回一个输出值。其输出与输入值成正比。线性比例尺广泛应用于 D3 项目,例如计算条形图中矩形元素的长度;
    • 分段比例尺从离散型定义域中获取输入,并从连续型值域中返回一个输出值。这类比例尺对于在条形图的可用空间内排布各矩形元素特别好用。
  • 对 SVG 分组元素进行平移(translation)将影响其内部所有的后代元素。
  • 标签由 SVG 文本元素(text)构建。每个文本元素必须使用 xy 属性单独定位;还可以使用 text-anchor 属性(attribute)设置文本右对齐。

  1. 更多专访人物信息,可参阅 Krisztina Szűcs 的个人网站:https://krisztinaszucs.com/ ↩︎

  2. Processing 是一个基于 Java 的开源编程语言和环境,旨在通过简化代码来帮助艺术家和设计师创造视觉艺术和交互作品。更多详情,详见 Processing 官方:https://processing.org/ ↩︎

  3. Chartball 是一个专注于体育统计数据可视化的知名网站,提供直观的图表和分析工具,尤其是篮球和棒球相关的赛事数据。详见网站首页:https://www.chartball.com/ ↩︎

相关文章:

【D3.js in Action 3 精译_030】3.5 给 D3 条形图加注图表标签(下):Krisztina Szűcs 人物专访 + 3.6 本章小结

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一部分 D3.js 基础知识 第一章 D3.js 简介(已完结) 1.1 何为 D3.js?1.2 D3 生态系统——入门须知1.3 数据可视化最佳实践(上)1.3 数据可…...

【重学 MySQL】五十六、位类型

【重学 MySQL】五十六、位类型 定义赋值与使用注意事项应用场景 在MySQL数据库中,位类型(BIT类型)是一种用于存储位字段值的数据类型。 定义 BIT(n)表示n个位字段值,其中n是一个范围从1到64的整数。这意味着你可以存储从1位到64…...

Centos7 NTP客户端

目录 1. NTP客户端1.1 安装1.2 启动1.3 同步状态异常1.4 更改/etc/chrony.conf配置文件1.5 同步状态正常 1. NTP客户端 1.1 安装 如果chrony没有安装,可以使用以下命令安装 sudo yum install chrony1.2 启动 启动并设置开机自启 sudo systemctl start chronyd …...

手机号归属地查询-手机号归属地-手机号归属地-运营商归属地查询-手机号码归属地查询手机号归属地-运营商归属地

手机号归属地查询API接口是一种网络服务接口,允许开发者通过编程方式查询手机号码的注册地信息。关于快证签API接口提供的手机号归属地查询服务,以下是一些关键信息: 一、快证签API接口简介 快证签API接口可能是一个提供多种验证和查询服务…...

CoppeliaSim和Matlab建立远程连接教程

CoppeliaSim和Matlab建立远程连接教程 Matlab通过调用CoppeliaSim的远程API和库函数实现远程连接,为实现Matlab和CoppeliaSim的联合仿真做准备。 一、获取并查看版本信息 点击 Help 查看版本信息 使用的CoppeliaSim Edu版本为:4.4.0 位数:64bit 二、拷贝API函数和库文件…...

使用STS以及签名URL临时授权访问OSS资源

本文介绍JAVA如何使用STS以及签名URL临时授权访问OSS资源。 注意事项 由于STS临时账号以及签名URL均需设置有效时长,当您使用STS临时账号生成签名URL执行相关操作(例如上传、下载文件)时,以最小的有效时长为准。例如您的STS临时账…...

Next.js 14 使用 react-md-editor 编辑器 并更改背景颜色

1.简介 react-md-editor是一款markdown编辑器,本文介绍如何在Next.js中使用它。 2.安装 安装命令: npm install uiw/react-md-editor3.MD编辑器 markdown编辑器的使用: "use client" import MDEditor from uiw/react-md-edi…...

【Iceberg分析】Spark与Iceberg集成落地实践(一)

Spark与Iceberg集成落地实践(一) 文章目录 Spark与Iceberg集成落地实践(一)清理快照与元数据配置表维度自动清理元数据文件属性手动清理 清理孤岛文件合并数据文件 清理快照与元数据 配置表维度自动清理元数据文件属性 每一次写…...

【Verilog学习日常】—牛客网刷题—Verilog进阶挑战—VL45

异步FIFO 描述 请根据题目中给出的双口RAM代码和接口描述,实现异步FIFO,要求FIFO位宽和深度参数化可配置。 电路的接口如下图所示。 双口RAM端口说明: 端口名 I/O 描述 wclk input 写数据时钟 wenc input 写使能 waddr input 写…...

【强训笔记】day27

NO.1 代码实现&#xff1a; #include<iostream>using namespace std;int n,m; int main() {cin>>n>>m;long long retn;for(int i0;i<m-1;i)retret*(n-1)%109;cout<<ret<<endl;return 0; }NO.2 思路&#xff1a;bfs遍历实现&#xff0c;dis…...

Nginx06-静态资源部署

零、文章目录 Nginx06-静态资源部署 1、静态资源概述 静态资源&#xff1a;是在Web开发中不经常改变的文件&#xff0c;比如图片、CSS样式表、JavaScript脚本文件等。这些资源通常是预先编译好的&#xff0c;不需要服务器端的动态处理。动态资源&#xff1a;是在Web开发中需…...

MySQL数据库专栏(二)SQL语句基础操作

目录 数据库操作 创建数据库 查看数据库 选择数据库 删除数据库 数据表操作 数据表数据类型 数据表列约束 数据表索引 创建表 查看表 查看表结构 删除表 数据表的增删改操作 …...

【OpenCV 实战】1.手势虚拟拖拽(双手骨骼点识别)

step: 1.opencv 获取视频流 2.在画面上画一个方块 3.通过mediapipe获取手指关键点坐标 4.判断手指是否在方块上 5.若在方块上&#xff0c;方块跟着手指移动 mediapipe网站介绍&#xff1a;Hands - mediapipe (chuoling.github.io) 已上传到GitHub &#xff1a; plumqm/OpenC…...

基于springboot人力资源管理系统源码

项目技术&#xff1a;SpringBoot 运行环境&#xff1a;jdk1.8idea/eclipsemaven3mysql5.6 项目描述&#xff1a; 系统包括&#xff0c;员工管理&#xff0c;奖惩管理&#xff0c;合同管理&#xff0c;薪酬管理&#xff0c;培训管理&#xff0c;绩效评估等功能...

如何使用 Apt-Get 和 Apt-Cache 在 Ubuntu 和 Debian 中管理软件包

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 简介 Apt 是 dpkg 打包系统的命令行前端&#xff0c;也是许多发行版中管理软件的首选方式。它是 Debian 及基于 Debian 的 Linux 发行版…...

Linux系统创建新分区并挂载的方法

一、引言 本文以CentOS为例讲述Linux系统创建新分区并挂载的方法。如下图所示&#xff0c;用fdisk -l命令可以看到该CentOS系统下有一个磁盘/dev/vda&#xff0c;其容量为2199G&#xff0c;即2T。该磁盘有两个分区&#xff1a;vda1和vda2&#xff1a; 用lsblk命令可以查看到磁…...

反射第二弹:用注册器动态注册(用自定义的注解标注的)策略,实现策略模式的设计

目录 引言 设计思路: 代码实现: 标注注解:@StrategyClass 扫描注解:trategyScan 注册器抽象类: 动态策略注册类: AOP类: 总结: 引言 曾经有人问我,假如有一个业务或者数据处理逻辑,会根据甲方客户繁杂的业务需求,而动态变化,该怎么处理,具体怎么实现? 将…...

【Xcode Command Line Tools】安装指南

安装指令 xcode-select --install安装 完成安装 验证 $ xcode-select -p /Library/Developer/CommandLineTools...

springboot开发网站-使用redis数据库定时特征限制指定ip的访问次数

springboot开发网站-使用redis数据库定时特征限制指定ip的访问次数。近期网站经常有人恶意访问&#xff0c;提交了很多垃圾信息。为了屏蔽这类灌水帖&#xff0c;打算屏蔽ip地址&#xff0c;限制24小时内只能访问1次某个接口。下面是测试的案例代码内容。 1&#xff1a;首先&am…...

【大模型理论篇】大模型相关的周边技术分享-关于《NN and DL》的笔记

本文所要介绍的一本书《Neural Networks and Deep Learning》&#xff0c;该书作者Michael Nielsen&#xff0c;Y Combinator Research的研究员&#xff0c;是多年之前自己看的一本基础书籍&#xff0c;很适合入门了解一些关于深度学习的概念知识&#xff0c;当然也包含了一些小…...

浅谈 React Hooks

React Hooks 是 React 16.8 引入的一组 API&#xff0c;用于在函数组件中使用 state 和其他 React 特性&#xff08;例如生命周期方法、context 等&#xff09;。Hooks 通过简洁的函数接口&#xff0c;解决了状态与 UI 的高度解耦&#xff0c;通过函数式编程范式实现更灵活 Rea…...

电脑插入多块移动硬盘后经常出现卡顿和蓝屏

当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时&#xff0c;可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案&#xff1a; 1. 检查电源供电问题 问题原因&#xff1a;多块移动硬盘同时运行可能导致USB接口供电不足&#x…...

Psychopy音频的使用

Psychopy音频的使用 本文主要解决以下问题&#xff1a; 指定音频引擎与设备&#xff1b;播放音频文件 本文所使用的环境&#xff1a; Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...

Robots.txt 文件

什么是robots.txt&#xff1f; robots.txt 是一个位于网站根目录下的文本文件&#xff08;如&#xff1a;https://example.com/robots.txt&#xff09;&#xff0c;它用于指导网络爬虫&#xff08;如搜索引擎的蜘蛛程序&#xff09;如何抓取该网站的内容。这个文件遵循 Robots…...

图表类系列各种样式PPT模版分享

图标图表系列PPT模版&#xff0c;柱状图PPT模版&#xff0c;线状图PPT模版&#xff0c;折线图PPT模版&#xff0c;饼状图PPT模版&#xff0c;雷达图PPT模版&#xff0c;树状图PPT模版 图表类系列各种样式PPT模版分享&#xff1a;图表系列PPT模板https://pan.quark.cn/s/20d40aa…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...

比较数据迁移后MySQL数据库和OceanBase数据仓库中的表

设计一个MySQL数据库和OceanBase数据仓库的表数据比较的详细程序流程,两张表是相同的结构,都有整型主键id字段,需要每次从数据库分批取得2000条数据,用于比较,比较操作的同时可以再取2000条数据,等上一次比较完成之后,开始比较,直到比较完所有的数据。比较操作需要比较…...

为什么要创建 Vue 实例

核心原因:Vue 需要一个「控制中心」来驱动整个应用 你可以把 Vue 实例想象成你应用的**「大脑」或「引擎」。它负责协调模板、数据、逻辑和行为,将它们变成一个活的、可交互的应用**。没有这个实例,你的代码只是一堆静态的 HTML、JavaScript 变量和函数,无法「活」起来。 …...

MySQL 索引底层结构揭秘:B-Tree 与 B+Tree 的区别与应用

文章目录 一、背景知识&#xff1a;什么是 B-Tree 和 BTree&#xff1f; B-Tree&#xff08;平衡多路查找树&#xff09; BTree&#xff08;B-Tree 的变种&#xff09; 二、结构对比&#xff1a;一张图看懂 三、为什么 MySQL InnoDB 选择 BTree&#xff1f; 1. 范围查询更快 2…...

什么是VR全景技术

VR全景技术&#xff0c;全称为虚拟现实全景技术&#xff0c;是通过计算机图像模拟生成三维空间中的虚拟世界&#xff0c;使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验&#xff0c;结合图文、3D、音视频等多媒体元素…...