d3.js 共享交换平台demo

今天在群里遇到一张图  遂来玩一玩,先来上图!!

点击相应按钮,开关线路,此项目的重点是计算相应图形的位置,由于是个性化项目就没有封装布局。好了直接上代码。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>$Title$</title><script src="https://d3js.org/d3.v4.min.js"></script><style>.container {padding: 0 100px;}button {width: 100px;}.rect {stroke: #406DA7;fill: #6693CC;stroke-width: 2;}.center {stroke: #FF3336;fill: #FF7F7E;stroke-width: 2;}.text {fill: #ffffff;text-anchor: middle;font-size: 30px;shape-rendering: crispEdges;}.circle {fill: #ffffff;stroke: #FF7F7E;stroke-width: 2;}.cha {fill: #ffffff;stroke: #FF7F7E;stroke-width: 2;}.dash1 {stroke-dashArray: 15 5;stroke-width: 4;stroke: #6693CC;}.dash2 {stroke-dashArray: 15 5;stroke-width: 4;stroke: #FF7F7E;}.marker1 {fill: none;stroke: #6693CC;stroke-width: 4;}.marker2 {fill: none;stroke: #FF7F7E;stroke-width: 4;}.line {stroke: #6693CC;stroke-width: 4;}</style>
</head>
<body>
<script>var width = 2000;var height = 1200;var margin = 100;var everyW = 280;var leftData = ['上海市城管局','北京市城管局','天津市城管局','重庆市城管局','大庆市城管局','黑河市城管局','鸡西市城管局','鹤岗市城管局'];var rightData = ['上海市建筑委','北京市建筑委','天津市建筑委','重庆市建筑委','大庆市建筑委','黑河市建筑委','鸡西市建筑委','鹤岗市建筑委'];var everyH = ( height - margin * 2 ) / leftData.length / 2;var scaleL = d3.scaleLinear().domain([0, leftData.length - 1]).range([0, height - margin * 2 - everyH])var scaleR = d3.scaleLinear().domain([0, rightData.length - 1]).range([0, height - margin * 2 - everyH])var text = '共享交换平台'render();function render() {var svg = d3.select('body').append('svg').attr('width',  1000).attr('height', 600).attr('viewBox', `0, 0, ${width}, ${height}`).attr("preserveAspectRatio", "xMidYMid meet").style('border', '1px solid #777')var defs = svg.append('defs')var cha = defs.append('g').attr('id', 'cha')cha.append('circle').attr('cx', 20).attr('cy', 20).attr('r', 19).attr('class', 'circle')cha.append('path').attr('d', 'M 11 15 L 25 31 A 3 3 0 0 0 29 25 L 15 9 A 3 3 0 0 0 11 15 Z').attr('class', 'cha')cha.append('path').attr('d', 'M 29 15 L 15 31 A 3 3 0 0 1 11 25 L 25 9 A 3 3 0 0 1 29 15 Z').attr('class', 'cha')var markerA1 = defs.append('g').attr('id', 'markerA1')markerA1.append('line').attr('x1', everyW + 2).attr('y1', everyH / 2).attr('x2', everyW * 1 / 4 + width / 4 - margin / 2).attr('y2', everyH / 2).attr('class', 'dash1')var markerA2 = defs.append('g').attr('id', 'markerA2')markerA2.append('line').attr('x1', everyW + 2).attr('y1', everyH / 2).attr('x2', everyW * 1 / 4 + width / 4 - margin / 2).attr('y2', everyH / 2).attr('class', 'dash2')markerA2.append('use').attr('x', everyW * 5 / 8 + width / 8 - margin / 4 - 20).attr('y', everyH / 2 - 20).attr('xlink:href', '#cha')var markerB1 = defs.append('g').attr('id', 'markerB1')markerB1.append('line').attr('x1', everyW * 3 / 4 - width / 4 + margin  / 2).attr('y1', everyH / 2).attr('x2', -10).attr('y2', everyH / 2).attr('class', 'dash1')markerB1.append('path').attr('d', `M -30 ${everyH / 2 - 16} L -10 ${everyH / 2} L -30 ${everyH / 2 + 16}`).attr('class', 'marker1')var markerB2 = defs.append('g').attr('id', 'markerB2')markerB2.append('line').attr('x1', everyW * 3 / 4 - width / 4 + margin  / 2).attr('y1', everyH / 2).attr('x2', -10).attr('y2', everyH / 2).attr('class', 'dash2')markerB2.append('path').attr('d', `M -30 ${everyH / 2 - 16} L -10 ${everyH / 2} L -30 ${everyH / 2 + 16}`).attr('class', 'marker2')markerB2.append('use').attr('x', everyW * 3 / 8 - width / 8).attr('y', everyH / 2 - 20).attr('xlink:href', '#cha')var body = svg.append('g').attr('transform', `translate(${margin},${margin})`).attr('class', 'body')var leftG = body.append('g').attr('class', 'left');var rightG = body.append('g').attr('class', 'right');let leftObj = leftG.selectAll('g.left-g').data(leftData).enter().append('g').attr('class', 'left-g').attr('transform', (d,i) => `translate(0,${scaleL(i)})`).attr('id', (d,i) => `l_${i}`);let rightObj = rightG.selectAll('g.right-g').data(rightData).enter().append('g').attr('class', 'right-g').attr('transform', (d,i) => `translate(${width - margin * 2 - everyW},${scaleL(i)})`).attr('id', (d,i) => `r_${i}`);;leftObj.append('rect').attr('width', everyW).attr('height', everyH).attr('rx', 6).attr('class', 'rect')leftObj.append('text').attr('class', 'text').attr('dy', '1.4em').text(d => d).attr('transform', `translate(${everyW / 2}, 0)`)leftObj.append('use').attr('x',0).attr('y', 0).attr('xlink:href', '#markerA1')rightObj.append('rect').attr('width', everyW).attr('height', everyH).attr('rx', 6).attr('class', 'rect')rightObj.append('text').attr('class', 'text').attr('dy', '1.4em').text(d => d).attr('transform', `translate(${everyW / 2}, 0)`)rightObj.append('use').attr('x',0).attr('y', 0).attr('xlink:href', '#markerB1')var centerObj = body.append('g').attr('transform', `translate(${width / 2 - margin - everyW / 2}, ${height / 2 - margin - everyH / 2   })`)centerObj.append('rect').attr('width', everyW).attr('height', everyH).attr('rx', 6).attr('class', 'center')centerObj.append('text').attr('class', 'text').attr('dy', '1.4em').text(text).attr('transform', `translate(${everyW / 2}, 0)`)body.append('line').attr('x1', everyW * 1 / 4 + width / 4 - margin / 2).attr('y1', everyH / 2 - 2).attr('x2', everyW * 1 / 4 + width / 4 - margin / 2).attr('y2', height - margin * 2 - everyH / 2 + 2).attr('class', 'line')body.append('line').attr('x1', width * 3 / 4 - margin * 3 / 2 - everyW * 1 / 4).attr('y1', everyH / 2 - 2).attr('x2', width * 3 / 4 - margin * 3 / 2 - everyW * 1 / 4).attr('y2', height - margin * 2 - everyH / 2 + 2).attr('class', 'line')body.append('line').attr('x1', everyW * 1 / 4 + width / 4 - margin / 2).attr('y1', height / 2 - margin).attr('x2', width / 2 - margin - everyW / 2 - 10).attr('y2', height / 2 - margin).attr('class', 'line')body.append('path').attr('d', `M ${width / 2 - margin - everyW / 2 - 30} ${height / 2 - margin - 16} L ${width / 2 - margin - everyW / 2 - 10} ${height / 2 - margin} L ${width / 2 - margin - everyW / 2 - 30} ${height / 2 - margin + 16}`).attr('class', 'marker1')body.append('line').attr('x1', (width - margin * 2 - 3 * everyW ) / 2 + 2 * everyW).attr('y1', height / 2 - margin).attr('x2', (width - margin * 2 - 3 * everyW ) * 3 / 4 + 2 * everyW).attr('y2', height / 2 - margin).attr('class', 'line')}function clickLeft(dom, num) {if(dom.getAttribute('off') == "true") {dom.setAttribute('off', "false");d3.select(".left").select(`#l_${num}`).select('use').attr('xlink:href', '#markerA2');} else {dom.setAttribute('off', "true");d3.select(".left").select(`#l_${num}`).select('use').attr('xlink:href', '#markerA1');}}function clickRight(dom, num) {if(dom.getAttribute('off') == "true") {dom.setAttribute('off', "false");d3.select(".right").select(`#r_${num}`).select('use').attr('xlink:href', '#markerB2');} else {dom.setAttribute('off', "true");d3.select(".right").select(`#r_${num}`).select('use').attr('xlink:href', '#markerB1');}}</script><div class="container"><table><tr><td>左侧</td><td><button off="true" onclick="clickLeft(this, 0)">1</button></td><td><button off="true" onclick="clickLeft(this, 1)">2</button></td><td><button off="true" onclick="clickLeft(this, 2)">3</button></td><td><button off="true" onclick="clickLeft(this, 3)">4</button></td><td><button off="true" onclick="clickLeft(this, 4)">5</button></td><td><button off="true" onclick="clickLeft(this, 5)">6</button></td><td><button off="true" onclick="clickLeft(this, 6)">7</button></td><td><button off="true" onclick="clickLeft(this, 7)">8</button></td></tr><tr><td>右侧</td><td><button off="true" onclick="clickRight(this, 0)">1</button></td><td><button off="true" onclick="clickRight(this, 1)">2</button></td><td><button off="true" onclick="clickRight(this, 2)">3</button></td><td><button off="true" onclick="clickRight(this, 3)">4</button></td><td><button off="true" onclick="clickRight(this, 4)">5</button></td><td><button off="true" onclick="clickRight(this, 5)">6</button></td><td><button off="true" onclick="clickRight(this, 6)">7</button></td><td><button off="true" onclick="clickRight(this, 7)">8</button></td></tr></table>
</div></body>
</html>

这里坐标原点没有挡在画布中心使得计算量增大(多思考确实可以减少好多代码量)。

由于是定制化很高的简单的demo,所有代码没有做模块化,用到的人不会很多,但是学好d3,可以让我们做更多更好的定制化项目。

 

想预览代码和下载的朋友请移步至 http://www.bettersmile.cn

转载于:https://www.cnblogs.com/vadim-web/p/11582560.html

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

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

相关文章

Java知识系统回顾整理01基础05控制流程07结束外部循环

一、break是结束当前循环 二、结束当前循环实例 break; 只能结束当前循环 public class HelloWorld { public static void main(String[] args) { //打印单数 for (int i 0; i < 10; i) { for (int j 0; j < 1…

Ajax — 新闻列表

注意&#xff1a;本项目主要利用到了template&#xff0c;模板引擎进行编写 模板引擎代码下载地址 <div id"news-list"><!-- 这里放数据 --></div>.news-item {display: flex;border: 1px solid #eee;width: 700px;padding: 10px;margin-bottom: …

Ajax — 第四天

数据交换格式 XML 写法&#xff1a; 一个文档有且只有一个根标签标签必须闭合属性值必须加引号 如果说服务器返回的数据是xml格式的 前端需要把服务器返回的xml当做document对象来处理目前无法演示&#xff0c;自己写接口的时候&#xff0c;我们可以测试一下。 JSON 写法…

数据库系统原理(第三章数据库设计 )

一、数据库设计概述 数据库的生命周期 数据库设计的目标&#xff1a; 满足应用功能需求&#xff08;存、取、删、改&#xff09;&#xff0c;良好的数 据库性能&#xff08;数据的高效率存取和空间的节省 共享性、完整性、一致性、安全保密性&#xff09;数据库设计的内容 数据…

Ajax — 第五天

Ajax-05 xhr&#xff08;level-2&#xff09;新特性 responseType属性和response属性 responseType: 表示预期服务器返回的数据的类型 “” &#xff0c;默认空text&#xff0c;和空一样&#xff0c;表示服务器返回的数据是字符串格式json&#xff0c;表示服务器返回的是js…

Swift傻傻分不清楚系列(十)枚举

本页内容包含&#xff1a; 枚举语法&#xff08;Enumeration Syntax&#xff09;使用 Switch 语句匹配枚举值&#xff08;Matching Enumeration Values with a Switch Statement&#xff09;关联值&#xff08;Associated Values&#xff09;原始值&#xff08;Raw Values&…

数据库系统原理(第四章:SQL与关系数据库基本操作 )

一、SQL概述 sql是结构化查询语言&#xff08;Structured Query Language&#xff0c;SQL&#xff09;是专门用来与数 据库通信的语言&#xff0c;它可以帮助用户操作关系数据库。 SQL的特点&#xff1a; SQL不是某个特定数据库供应商专有的语言&#xff1b; SQL简单易学 &…

selenium操作浏览器窗口最大化和刷新

实际测试过程中经常遇到打开一个页面并不是全屏显示&#xff0c;但是却希望它能够全屏显示或者新增一条记录后需要刷新一下看能不能再列表中正常显示。 于是就有了今天的关于对浏览器窗口的最大化和刷新页面。需要说明的一点&#xff1a;所有和python相关的记录都是基于3.6版本…

Git安装步骤+Mac终端配置

Git安装步骤 其实可以直接略过。因为安装的时候&#xff0c;一路 next 即可。 注意&#xff0c;安装路径中不能出现中文。安装完成后&#xff0c;不得更改安装路径。 检查Git是否安装成功 在任何文件夹&#xff0c;空白处&#xff0c;右键。如果看到 “Git Bash Here”&#xf…

数据库系统原理(第5章:数据库编程)

一、存储过程 概念&#xff1a;存储过程是一组为了完成某项特定功能的SQL语句集&#xff0c; 其实质就是一段存储在数据库中的代码。 它可以由声明式的sql语句和过程式sql语句组成。 特点&#xff1a; 可增强SQL语言的功能和灵活性良好的封装性高性能可减少网络流量可作为一种安…

科学-中医:儒医

ylbtech-科学-中医&#xff1a;儒医"儒医"是一种历史悠久的社会文化现象。阐释了"儒医"的三重境界,即良医、大医、圣医。"良医"注重技,属于知识论,追求的是"真";"大医"注重德,属于道德论,追求的是"善";"圣医…

Ajax — 第六天

Ajax-06 GET和POST的区别 字面意思不同 GET 是获取意思。想从服务器获取数据&#xff0c;用GET方式的请求POST是邮递、邮寄意思。如果提交数据到服务器&#xff0c;用POST方式 请求参数位置不同 GET 请求参数会和url拼接到一起&#xff0c;形如 api/getbooks?id2&age3PO…

iOS Tips 模拟器屏幕截图

当我们发布app到AppStore的时候&#xff0c;在itunes connect里面&#xff0c;苹果官方要求我们提供各种尺寸的屏幕截图。由于受到硬件条件的限制&#xff0c;我们不可能在每个真实的物理机器上测试并截图&#xff0c;相反如果我们能直接在模拟器上进行屏幕截图的话&#xff0c…

数据库系统原理(第6章:数据库安全与保护)

一、数据库完整性 数据库完整性是指数据库中数据的正确性和相容性。 完整性约束条件的作用对象 列级约束&#xff1a; 包括对列的类型、取值范围、精度等的约束元组约束&#xff1a; 指元组中各个字段之间的相互约束表级约束&#xff1a; 指若干元组、关系之间的联系的约束定义…

.net core WebApi 使用Swagger生成API文档

关于 Swagger Swagger能成为最受欢迎的REST APIs文档生成工具之一&#xff0c;有以下几个原因&#xff1a; Swagger 可以生成一个具有互动性的API控制台&#xff0c;开发者可以用来快速学习和尝试API。Swagger 可以生成客户端SDK代码用于各种不同的平台上的实现。Swagger 文件可…

Git — 初体验

准备工作 版本管理软件 作用 记录代码的版本实现多人协作 分类 集中式&#xff0c;典型代表 SVN分布式&#xff0c;典型代表 Git 注册远程仓库账号 远程仓库相当于中央服务器我们需要在github上或码云上注册一个账号&#xff0c;用于创建远程仓库使用注册的时候&#xff0…

iOS CoreTelephony框架介绍与使用案列

昨晚看一篇文章时看到了私有API这个词&#xff0c;貌似开发者对私有API的使用很反感于是果断百度谷歌&#xff0c;以下是Stackoverflow中关于Private Frameworks的一个解释&#xff1a; Private frameworks are frameworks which you are not allowed to use. They are not exp…

JS数组的迭代器方法

迭代器forEachevery一、迭代器方法 迭代器方法&#xff0c; 这些方法对数组中的每一个元素应用一个函数&#xff0c;可以返回一个值&#xff0c;一组值或一个新数组。 不生成新数组的迭代器方法 1.forEach() forEach()输出 forEach输出结果2.every() 该方法按接受一个返回值为布…

Git 笔记

三个区域 下面三个区域&#xff0c;是Git虚拟的区域&#xff0c;看不到&#xff0c;摸不着。 工作区 工作区&#xff0c;指的是使用Git管理后的文件&#xff0c;这些文件显示在磁盘上&#xff0c;供我们使用或修改的区域。所以&#xff0c;粗略的说&#xff0c;项目文件夹就是…

git -- 练习的笔记

gitgitee.com:my_exercises/my_exercises.githttps://gitee.com/my_exercises/my_exercises/invite_link?invite3ab56c724a0aed34ae2bd193ce87e741e67fe05ee029cc01b7993663152babc57d76203fdafbbb42e766b0d826817bc91.在任意位置右键打开 2.初始化设置 3.添加远程仓库地址 4.…