d3.js入门教程2-在 d3.js中构建形状

d3.js是一个用于绘图的JavaScript 库。 它可以可视化展示任何类型的数据。 d3.js允许绘制形状,然后将各种形状构建一个图形。本文档描述了一些函数,可以更有效地从数据中绘制svg。

形状的添加

圆形的添加

在svg中绘制圆形。需要三个参数:分别代表圆心x位置的cx、圆心y位置的cy和半径的r。基础调用函数如下:

<circle style="fill: #69b3a2" stroke="black" cx=100 cy=100 r=40></circle>

现在,让我们用javascript来实现它,这基本上是相同的过程。

    <!-- 直接绘图 -->
<svg>
<circle style="fill: #69b3a2" stroke="black" cx=100 cy=100 r=40></circle>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="circle"></svg>
<script>
// 创建svg元素
var svg = d3.select("#circle").append("svg").attr("width", 200).attr("height", 200) // 设置属性
// stroke设置轮廓颜色
svg.append('circle').attr('cx', 100).attr('cy', 100).attr('r', 30).attr('stroke', 'black').attr('fill', 'red')
</script>

其中蓝色圆是由html绘图元素创建,红色圆是通过js创建

矩形的添加

在svg中绘制矩形,四个参数是必需的:x,y,width和height。

<rect style="fill: #69b3a2" stroke="black" x=10 y=100, width=300 height=40></rect>

现在,让我们用javascript来实现它,这基本上是相同的过程。

    <!-- 直接绘图 -->
<svg>
<rect style="fill: #69b3a2" stroke="black" x=10 y=100, width=300 height=40></rect>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="rect"></svg> <script>
// 创建svg元素
var svg = d3.select("#rect").append("svg").attr("width", 800).attr("height", 200) // 设置属性
svg.append('rect')
.attr('x', 10)
.attr('y', 120)
.attr('width', 600)
.attr('height', 40)
.attr('stroke', 'black')
.attr('fill', 'red');

其中蓝色矩形是由html绘图元素创建,红色矩形是通过js创建

线段的添加

在svg中绘制线段,四个参数是必需的:x0,y0,x1和y1(线段的两个顶点坐标)。

<line stroke="#69b3a2" x0=10 y0=10, x1=500 y1=100></line>

现在,让我们用javascript来实现它,这基本上是相同的过程。

    <!-- 直接绘图 -->
<svg>
<line stroke="#69b3a2" x0=10 y0=10, x1=300 y1=100></line>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="segment"></svg> <script> // 创建svg元素
var svg = d3.select("#segment").append("svg").attr("width", 800).attr("height", 200) // 设置属性
svg.append('line')
.attr('x1', 10)
.attr('y1', 10)
.attr('x2', 700)
.attr('y2', 100)
.attr('stroke', 'red')
</script>

其中蓝色线段是由html绘图元素创建,红色线段是通过js创建

文本的添加

在svg中添加文本,需要三个参数:x,y和text。

<text stroke="#69b3a2" style="font-size: 19px" x=100 y=50>I'm a piece of text</text>

现在,让我们用javascript来实现它,这基本上是相同的过程。

    <!-- 直接绘图 -->
<svg>
<text stroke="#69b3a2" style="font-size: 19px" x=100 y=80>I'm a piece of text</text>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="text"></svg> <script> // 创建svg元素
var svg = d3.select("#text").append("svg").attr("width", 800).attr("height", 200) //设置属性
svg.append('text')
.attr('x', 60)
.attr('y', 50)
.attr('stroke', 'red')
.style("font-size", 19)
.text("I'm another piece of text")
</script>

其中蓝色文本是由html绘图元素创建,红色文本是通过js创建

折线的添加

在svg添加文本,参数比较复杂。具体如下:

<path style="fill: none" stroke="black" d="M0 20 L150 150 L300 100 L450 20 L600 130"></path>

幸运的是,d3.js提供可以更有效地绘制折线的函数

    <!-- 直接绘图 -->
<svg height=200 width=600>
<path style="fill: none" stroke="#69b3a2" d="M0 20 L150 150 L300 100 L450 20 L600 130"></path>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="line" height=200 width=600></svg> <script> // 创建svg元素
var svg = d3.select("#line").append("svg") // 创建数据,多个点连接成折线
var data = [{ x: 0, y: 20 }, { x: 150, y: 150 }, { x: 300, y: 100 }, { x: 450, y: 20 }, { x: 600, y: 130 }] // 创建连接函数
var lineFunc = d3.line()
.x(function (d) { return d.x })
.y(function (d) { return d.y }) // 添加元素
svg.append('path')
.attr('d', lineFunc(data))
.attr('stroke', 'red')
.attr('fill', 'none');
</script>

其中蓝色线条是由html绘图元素创建,红色线条是通过js创建

当然可以设置线条类型,如下所示


<!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="curve" height=300 width=600></svg> <script> // 创建数据
var data = [{ x: 0, y: 20 }, { x: 150, y: 150 }, { x: 300, y: 100 }, { x: 450, y: 20 }, { x: 600, y: 130 }] // 创建svg元素
var svg = d3.select("#curve").append("svg").attr("width", 1800).attr("height", 200) // 创建辅助函数
var curveFunc = d3.line()
// 设置线条类型,具体设置参考官方文档,可以尝试curveStep.
.curve(d3.curveBasis)
.x(function (d) { return d.x })
.y(function (d) { return d.y }) svg.append('path')
.attr('d', curveFunc(data))
.attr('stroke', 'black')
.attr('fill', 'none'); </script>

区域的添加

html的svg标签原生语法画区域很麻烦,还是用js容易。原生代码如下所示:

<path style="fill: #69b3a2" stroke="black" d="M0 200 L0 20 L150 150 L300 100 L450 20 L600 130 L600 200"></path>

js代码如下:


<!-- 原生绘图 -->
<svg height=300 width=800>
<path style="fill: #69b3a2" stroke="black" d="M0 200 L0 20 L150 150 L300 100 L450 20 L600 130 L600 200"></path>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="area" height=300 width=800></svg> <script> // 创建数据
var data = [{ x: 0, y: 20 }, { x: 150, y: 150 }, { x: 300, y: 100 }, { x: 450, y: 20 }, { x: 600, y: 130 }] // 创建svg元素
var svg = d3.select("#area").append("svg") // 创建辅助函数
var curveFunc = d3.area()
.x(function (d) { return d.x })
.y1(function (d) { return d.y }) // 区域上边界坐标
.y0(200) // 区域下边界坐标 // 添加属性
svg.append('path')
.attr('d', curveFunc(data))
.attr('stroke', 'black')
.attr('fill', 'red'); </script>

圆弧的添加

圆弧的添加也是一样,js最好。原生代码如下:

<path style="fill: #69b3a2" stroke="black" transform="translate(400,200)" d="M0,149 A150,150,0,0,1,-0.47,-149.9 L-0.3,-99.9 A100,100,0,0,0,0.15,99.9Z"></path>

现在,让我们使用d3.arc()辅助函数来绘制相同类型的形状。我们需要提供4个参数:innerRadius、outerRadius、startAngle、endAngle


<!-- 原生绘图 -->
<svg height=400 width=400>
<path style="fill: #69b3a2" stroke="black" transform="translate(400,200)"
d="M0,149 A150,150,0,0,1,-0.47,-149.9 L-0.3,-99.9 A100,100,0,0,0,0.15,99.9Z"></path>
</svg> <!-- 加载d3 -->
<script src="https://d3js.org/d3.v4.js"></script> <!-- 添加一个空的svg图片 -->
<svg id="arc" height=400 width=400></svg> <script>
// 创建svg元素
var svg = d3.select("#arc").append("svg")
// 添加弧形
svg
.append("path")
.attr("transform", "translate(400,100)") // 平移距离
.attr("d", d3.arc()
.innerRadius(100) // 内圈半径
.outerRadius(150) // 外圈半径
.startAngle(3.14) // 开始角度(弧度),最下方为3.14
.endAngle(3.14 * 1.6) // 结束角度(弧度)
)
.attr('stroke', 'black')
.attr('fill', 'red');
</script>

其中蓝色圆弧是由html绘图元素创建,红色圆弧是通过js创建

参考

[数据与分析可视化] D3入门教程2-在d3中构建形状的更多相关文章

  1. [数据与分析可视化] D3入门教程3-d3中的数据操作

    d3.js入门教程3-d3.js中的数据操作 文章目录 d3.js入门教程3-d3.js中的数据操作 数学操作 对象和数组 过滤Filtering 排序Sorting 映射group 循环loop 重 ...

  2. [数据与分析可视化] D3入门教程1-d3基础知识

    d3.js入门教程1-d3基础知识 文章目录 d3.js入门教程1-d3基础知识 1 HTML介绍 1.1 什么是HTML? 1.2 自定义文档样式CSS 1.3 构建svg图形 2 d3绘图入门 2 ...

  3. Wireshark数据包分析(一)——使用入门

    Wireshark简介: Wireshark是一款最流行和强大的开源数据包抓包与分析工具,没有之一.在SecTools安全社区里颇受欢迎,曾一度超越Metasploit.Nessus.Aircrack ...

  4. DotNetBrowser入门教程(更新完善中)

    DotNetBrowser 希望实现的目标:桌面软件可以完美运行Html5,内置支持MVC与WebSocket的微型服务器. 基于.Net 4.0开发.开发环境:VS2017,运行环境支持Window ...

  5. Entity Framework入门教程(3)---EF中的上下文简介

    1.DbContext(上下文类) 在DbFirst模式中,我们添加一个EDM(Entity Data Model)后会自动生成一个.edmx文件,这个文件中包含一个继承DbContext类的上下文实 ...

  6. Entity Framework入门教程(11)---EF6中的异步查询和异步保存

    EF6中的异步查询和异步保存 在.NET4.5中介绍了异步操作,异步操作在EF中也很有用,在EF6中我们可以使用DbContext的实例进行异步查询和异步保存. 1.异步查询 下边是一个通过L2E语法 ...

  7. Entity Framework入门教程(13)---EF中的高并发

    EF中的高并发 这里只介绍EF6中database-first开发方案的高并发解决方案,code-first开发方案中的高并发会在以后的EF CodeFirst系列中介绍. EF默认支持乐观并发:我们 ...

  8. WPF入门教程系列十七——WPF中的数据绑定(三)

    四. XML数据绑定 这次我们来学习新的绑定知识,XML数据绑定.XmlDataProvider 用来绑定 XML 数据,该XML数据可以是嵌入.Xmal文件的 XmlDataProvider 标记中 ...

  9. Unix/Linux环境C编程入门教程(35) 编程管理系统中的组

     组管理相关函数介绍 相关函数 getgid,setgid,setregid 表头文件 #include<unistd.h> #include<sys/types.h> 定 ...

随机推荐

  1. 为什么ArrayList的subList结果不能转换为ArrayList????

    subList是List接口中的一个方法,该方法主要返回一个集合中的一段子集,可以理解为截取一个集合中的部分元素,它的返回值也是一个List. 让我们初始化一个例子: import java.util ...

  2. [WPF] 抄抄超强的苹果官网滚动文字特效实现

    1. 前言 今天 ChokCoco 大佬发布了一篇博客 超强的苹果官网滚动文字特效实现,iPhone 我是买不起的,但不妨碍我对抄特效感兴趣,正好我这周安排的工作已经完成了,于是有空练练手实现了一个 ...

  3. win10设置或更改硬盘图标

    1.首先要找到".ico"的图标素材,存放在要更改图标的硬盘根目录,可命名为a.ico.图片素材大家可以去一些素材网找找,一般可以找到很多. 2.在该硬盘分区空白处鼠标右键新建一个 ...

  4. C# Static关键词的使用

    一.C#中类的方法分为静态方法和非静态方法 静态方法有Static关键词修饰 静态方法归类所有,而非静态方法归类的实例所有:静态方法无需类去实例化可直接调用 静态成员属于类所有,为各个类的实例所公用, ...

  5. 解决办法:ImportError:'module'object has no attribute 'check specifier'

    在安装envsubst命令不存在的报错, 安装centos本地源, 再安装gettext) 在指定版本的时候发现还是报错根据后面提示指定44.0.0问题解决 pip install --upgrade ...

  6. 将java装进u盘指南

    将java装入u盘指南 idea 将下载好的idea的文件夹移动到u盘中.在idea的bin目录里找到idea.properties文件,在最后添加以下两行 idea.config.path=U:/I ...

  7. 扫雷(哈希+bfs)

    扫雷 题目描述: 小明最近迷上了一款名为<扫雷>的游戏. 其中有一个关卡的任务如下: 在一个二维平面上放置着 n 个炸雷,第 i 个炸雷 (x\(_i\),y\(_i\),r\(_i\)) ...

  8. Xtrabackup使用帮助

    目录 1.安装工具 2.下载后上传到需要备份的服务器 全备 1.安装完成后我们进行数据库备份执行以下命令 2.查看备份的数据 3.进入数据库,删除一个测试库 4.删除school库 5.备份数据目录 ...

  9. 操作系统课程设计pintos project1实验摘记

    第一部分 项目概述 一.Pintos简介 Pintos是一个基于80x86架构的简单操作系统框架,它支持内核级线程.能够加载和运行用户程序,也拥有文件系统,不过,这些功能均以一种简单的形式实现. 二. ...

  10. 一文讲透CabloyJS全栈框架的来龙去脉

    本文受众 咱们做软件开发,就好比是建造一幢幢房屋,一座座桥梁,既可以是北方宫殿的巍峨,也可以有南方庭院的雅致,更可以是横跨群山的峻险与孤悬.那么,不同的语言.不同的框架也都由其内在的秉质吸引着一批粉丝 ...