Echarts+大屏

news2025/1/7 6:57:59

先放上我做的大屏吧,做的不是很好看,希望大家能见谅。

一、实验目的

  1. 理解大数据可视化的原理和方法
  2. 掌握ECharts可视化的原理、步骤和效果
  3. 掌握使用D3读取数据的方法

二、实验任务与要求

  1.         通过网店运营的销售数据,分别从各月的销售情况、各产品销售情况、各地区销售情况、各省份销售情况及各产品经理的销售情况进行可视化。

    1、根据给定初步方案制定详细方案

            根据案例需求,按照大数据可视化流程的实施步骤进行实验方案的制订。主要包括但不限于:数据如何读取?如何处理?如何进行页面的整体设计?需要用那些图表?如何实现交互?如何发现问题与解决问题等。

    2、数据读取和处理

    选择合适的方式读取和处理网店运营数据

    3、页面设计和图表选择

            利用格式塔理论、色彩搭配理论以及数据可视化设计原则与技巧,进行页面的整体设计。将页面划分成多个模块,利用可视化方法,选择合适的图表分别进行可视化展现最后进行交互设计和实现。

    4、发现问题与解决问题

            进行大数据可视化的实施过程中,每个模块的可视化结果是否正确,如何验证与发现问题,并提出解决思路和方法。

三、实验原理(技术)

1.关于Echarts

官网地址:https://echarts.apache.org/zh/index.html

         ECharts,一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE9/10/11,Chrome,Firefox,Safari等),底层依赖矢量图形库 ZRender,提供直观,交互丰富,可高度个性化定制的数据可视化图表。

(1)、具有丰富的可视化类型

        ECharts 提供了常规的折线图、柱状图、散点图、饼图、K线图,用于统计的盒形图,用于地理数据可视化的地图、热力图、线图,用于关系数据可视化的关系图、treemap、旭日图,多维数据可视化的平行坐标,还有用于 BI 的漏斗图,仪表盘,并且支持图与图之间的混搭。

        除了已经内置的包含了丰富功能的图表,ECharts 还提供了自定义系列,只需要传入一个renderItem函数,就可以从数据映射到任何你想要的图形,更棒的是这些都还能和已有的交互组件结合使用而不需要操心其它事情。

        你可以在下载界面下载包含所有图表的构建文件,如果只是需要其中一两个图表,又嫌包含所有图表的构建文件太大,也可以在在线构建中选择需要的图表类型后自定义构建。

(2)、多种数据格式无需转换直接使用

        ECharts 内置的 dataset 属性(4.0+)支持直接传入包括二维表,key-value 等多种格式的数据源,通过简单的设置 encode 属性就可以完成从数据到图形的映射,这种方式更符合可视化的直觉,省去了大部分场景下数据转换的步骤,而且多个组件能够共享一份数据而不用克隆。

        为了配合大数据量的展现,ECharts 还支持输入 TypedArray 格式的数据,TypedArray 在大数据量的存储中可以占用更少的内存,对 GC 友好等特性也可以大幅度提升可视化应用的性能。

具体请查看官网文档:

2、ECharts的引入和使用

使用ECharts绘制图形,主要分为以下几个步骤完成:

(1)引入ECharts;

2)为ECharts准备一个具备大小的Dom;

3)初始化实例;

4)设定图表的配置项;

5)使用指定的配置项和数据显示图表。

2、D3读取数据

(1)关于D3

官网地址:https://d3js.org/ 

        D3.js 是一个 JavaScript 库,用于基于数据操作文档。D3 可帮助您使用 HTML、SVG 和 CSS 使数据栩栩如生。D3 对 Web 标准的强调为您提供了现代浏览器的全部功能,而无需将自己绑定到专有框架,将强大的可视化组件和数据驱动的 DOM 操作方法相结合。 

        D3 允许您将任意数据绑定到文档对象模型 (DOM),然后将数据驱动的转换应用于文档。例如,可以使用 D3 从数字数组生成 HTML 表。或者,使用相同的数据创建具有平滑过渡和交互的交互式 SVG 条形图。

        D3 不是一个寻求提供所有可能功能的整体框架。相反,D3 解决了问题的症结:基于数据高效操作文档。这避免了专有表示,并提供了非凡的灵活性,公开了 HTML、SVG 和 CSS 等 Web 标准的全部功能。D3 开销最小,速度极快,支持大型数据集以及交互和动画的动态行为。D3 的函数式风格允许通过各种官方和社区开发的模块重用代码。

(2)引入D3

在index.html页面的< head >和</head>标签之间引入d3.min.js。

<script src="js/d3.min.js"></script>

2)读取数据

先打开数据查看,在加载完数据后,对数据进行可视化展现。通过D3在index.html页面的< script >和</script >标签之间读取csv数据,并做相应的整理。

d3.csv("data/sales_region.csv",function(error,data){

console.log(data)

    //后面实验步骤的代码放在这里

    });

d3.json("data/ sales_product.json",function(error,data){

console.log(data)

    //后面实验步骤的代码放在这里

    });

四、编码实现

index.html

<!DOCTYPE html>

<html lang="zh-CN">
	<head>
		<meta charset="utf-8" />
	    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
	    <meta http-equiv="X-UA-Compatible" content="IE=edge, chrome=1" />
		<title>可视化大屏</title>
		<link rel="stylesheet" href="css/bootstrap.min.css" />
		<link rel="stylesheet" href="css/app.css" />
		<script src="js/echarts.min.js"></script>
		<script src="js/d3.min.js"></script>
		<script src="js/china.js"></script>
	</head>
	
	<body class="bg06">
		<header class="header">
		<div id='currentTime'></div>
			<h3>可视化大屏</h3>
		</header>
		
		<div class="wrapper" style="color: aqua;">
			<div class="container-fluid">
				<div class="row fill-h">
					<div class="col-lg-3 fill-h">
						<div class="xpanel-wrapper xpanel-wrapper-1-2">
							<div class="xpanel">
								<div class="title">地区</div>
								<div class="left_right_div" id="sales_region"></div>
							</div>
						</div>
						<div class="xpanel-wrapper xpanel-wrapper-1-2">
							<div class="xpanel">
								<div class="title">年利润</div>
								<div class="left_right_div" id="sales_month" style="background-color: aliceblue;"></div>
							</div>
						</div>
					</div>
					<div class="col-lg-6 fill-h">
						<div class="xpanel-wrapper xpanel-wrapper-1">
							<div class="xpanel no-padding no-bg">
								<div class="center_title">地图</div>
								<div class="center_div" style="background-color: lightskyblue;">
									<div id="map" style="height: 550px; width: 720px;"></div>
								</div>
							</div>
						</div>
					</div>
					<div class="col-lg-3 fill-h">
						<div class="xpanel-wrapper xpanel-wrapper-2-3">
							<div class="xpanel">
								<div class="title">销售经理</div>
								<div class="left_right_div" id="data_manager"></div>
							</div>
						</div>
						<div class="xpanel-wrapper xpanel-wrapper-1-3">
							<div class="xpanel">
								<div class="title">办公用品</div>
								<div class="left_right_div" id="data_product"></div>
							</div>
						</div>
					</div>
				</div>
			</div>
		</div>
	</body>
	<script src="js/sales_manager.js"></script>
	<script src="js/sales_region.js"></script>
	<script src="js/myMap.js"></script>
	<script src="js/sales_product.js"></script>
	<script src="js/sales_month.js"></script>
</html>

全局样式app.css

@charset "utf-8";

/********** Global **********/
/*
 *常用背景色: #0f1c30 #0b0f34 (6,64,102) (29,45,57) (7,33,58) (8,13,28) (15,43,36)
 */
html, body {
	width:100%;
	height:100%;
	min-height:635px;
	font-family:"microsoft yahei", arial, sans-serif;
	background-color:#152a59;
	background-repeat:no-repeat;
	background-position:center;
	background-size:100% 100%;
	overflow-x:hidden;
	overflow-y:auto;
}
body.bg06 {background-image:url("../img/bg06.png");}
.header {
	margin:0 auto;
	width:100%;
	height:55px;
	max-width:1920px;
	background:url("../img/header-left.png") left center no-repeat, url("../img/header-right.png") right center no-repeat;
	background-size:43% 100%, 43% 100%;
	overflow:hidden;
}
.header h3 {
	margin:0;
	padding:0;
	line-height:60px;
	text-align:center;
	font-size:24px;
	color:#5dc2fe;
}
#currentTime {
	position:absolute;
	height:100%;
	width:35%;
	line-height:25px;
	top:2%;
	left:75%;
	/*text-align: center;*/
	font-size:10px;
	color:#1890FF;
	}
@media (max-width: 1199px) {
	.header {
		background:url("../img/header-left.png") left bottom no-repeat, url("../img/header-right.png") right bottom no-repeat;
		background-size:100%, 100%;
	}
	.header h3 {line-height:48px;}
}
.wrapper {position:absolute;top:70px;bottom:0;left:0;right:0;min-height:555px;}
.container-fluid {height:100%;min-height:100%;}
.row {margin-left:-7px;margin-right:-8px;}
.row>div {padding-left:7px;padding-right:8px;}
.xpanel-wrapper {padding-bottom:15px;box-sizing:border-box;}
.xpanel-wrapper-1 {height:100%;}
.xpanel-wrapper-1-2 {height:50%;}
.xpanel-wrapper-1-3 {height:50%;}
.xpanel-wrapper-2-3 {height:50%;}
.xpanel {
	position: relative;
	padding:15px;
	height:100%;
	min-height:170px;
	background:url("../img/panel.png") center no-repeat;
	background-size:100% 100%;
	box-sizing:border-box;
}
.title {
	position: absolute;
	padding-left:24px;
	height:36px;
	width: 90%;
	line-height:36px;
	font-size:15px;
	font-weight:normal;
	color:#00C6FB;
	background-image:url("../img/title-bg.png");
	background-repeat:no-repeat;
	background-size:100% 100%;
	margin: 0;
}
.center_title {
	position: absolute;
	padding-left:24px;
	height:36px;
	width: 90%;
	line-height:36px;
	font-size:15px;
	font-weight:normal;
	color:#00C6FB;
	background-image:url("../img/title-bg.png");
	background-repeat:no-repeat;
	background-size:100% 100%;
	margin: 0;
	top:2%;
}
.title1 {
	position: absolute;
	padding-left:15px;
	height:30px;
	width: 90%;
	line-height:15px;
	font-size:15px;
	font-weight:normal;
	color:#FFFFFF;
	background:none;
	background-repeat:no-repeat;
	background-size:100% 100%;
	margin: 0;
}
/* tool */
.fill-h {height:100%;min-height:100%;}
.no-margin {margin:0 !important;}
.no-padding {padding:0 !important;}
.no-bg {background:none !important;}
.no-border {border:0 !important;}
.left_right_div {
	position: absolute;
	height:79%;
	width: 93%;
	top:20%;
	padding: 0px 0px 0px 0px;
	background:none;
	margin: 0;
}
.center_div {
	position: absolute;
	height:88%;
	width: 100%;
	top:8%;
	padding: 0;
	background:none;
	margin: 0;
}
.center_div1 {
	position: absolute;
	height:100%;
	width: 100%;
	top:5%;
	padding: 0;
	background:none;
	margin: 0;
}
/* scrollbar */
::-webkit-scrollbar {width:0;height:0;}
::-webkit-scrollbar-track {background-color:transparent;}
::-webkit-scrollbar-thumb {border-radius:5px;background-color:rgba(0, 0, 0, 0.3);}

大屏的地图展示

d3.csv("data/sales_province.csv", function(error, data) {
	console.log(data)
	var sales_data=[];
	var profit_data=[];
	var names=[];
	for (i=0;i<data.length;i++){
		temp={};
		temp1={};
		temp['value']=data[i].sales;
		temp['name']=data[i].province;
		temp1['value']=data[i].profit;
		temp1['name']=data[i].province;
		sales_data.push(temp);
		profit_data.push(temp1);
		names.push(data[i].province);
	}
	console.log([sales_data,profit_data])
	var myChart = echarts.init(document.getElementById('map'));
	var option = {
		title: {
			text: '全国销售额',
			left: 'center',
			textStyle:{
				color:'#0099FF',
				fontSize:20,
			}
		},
		tooltip: {
			trigger: 'item'
		},
		visualMap: {
			type: 'piecewise',
			pieces: [{
					min: 120000,
					max: 99999999,
					label: '销售额大于等于120000元',
					color: '#372a28'
				},
				{
					min: 90000,
					max: 120000,
					label: '销售额90000到120000元',
					color: '#4e160f'
				},
				{
					min: 60000,
					max: 90000,
					label: '销售额60000-90000元',
					color: '#974236'
				},
				{
					min: 30000,
					max: 60000,
					label: '销售额30000-60000元',
					color: '#ee7263'
				},
				{
					min: 1,
					max: 30000,
					label: '销售额1-30000元',
					color: '#f5bba7'
				},
			],
		},
		
		series: [{
			name: '销售额',
			type: 'map',
			map: 'china',
			roam: false,
			label: {
				show: true
			},
			data: sales_data
		},]
	};
	//使用指定的配置项和数据显示图表
	myChart.setOption(option);
})

兰丁格尔图进行数据展示

d3.csv("data/sales_region.csv",function(error,data){
//	console.log(data)
	var sales_data=[];
	var profit_data=[];
	var names=[];
	for (i=0;i<data.length;i++){
		temp={};
		temp1={};
		temp['value']=data[i].sales;
		temp['name']=data[i].region;
		temp1['value']=data[i].profit;
		temp1['name']=data[i].region;
		sales_data.push(temp);
		profit_data.push(temp1);
		names.push(data[i].region);
	}
	console.log([names,sales_data,profit_data])
	var myChart = echarts.init(document.getElementById('sales_region'));

option = {
	color: ["#EAEA26", "#906BF9", "#FE5656", "#01E17E", "#3DD1F9", "#FFAD05"],
    title: {
        text: '           销售情况                                          利润情况',
        left: 'left',
 		textStyle:{
 			color:'#0099FF',
 			fontSize:10,
 		}
    },
    tooltip: {
        trigger: 'item',
        formatter: '{a} <br/>{b} : {c} ({d}%)'
    },
    legend: {
        left: 'center',
        top: 'bottom',
        data: names,
        textStyle:{
        	color:["#EAEA26", "#906BF9", "#FE5656", "#01E17E", "#3DD1F9", "#FFAD05"],
        },
        padding:0,
        itemGap:3,
        itemWidth:30,    
    },
    series: [
        {
            name: '销售额',
            type: 'pie',
            radius: [5, 85],
            center: ['20%', '50%'],
            roseType: 'area',
            label: {
                show: false
            },
            labelLine: {
	            normal: {
	                show: false,
	            },
	            emphasis: {
	                show: false
	            }
	        },
            emphasis: {
                label: {
                    show: false
                }
            },
            data: sales_data,
        },
        {
            name: '利润',
            type: 'pie',
            radius: [5, 85],
            center: ['68%', '50%'],
            roseType: 'area',
            label:{
            	show:false,
            },
            labelLine: {
		            normal: {
		                show: false,
		            },
		            emphasis: {
		                show: false
		            }
		        },
            data: profit_data,
        }
    ]
};
	myChart.setOption(option);
})

⛵小结 

以上就是对从Echarts+大屏的概述,希望大家看的开心!!!!!!! 

        如果这篇文章有帮助到你,希望可以给作者点个赞👍,创作不易,如果有对后端技术、前端领域感兴趣的,也欢迎关注 ,我将会给你带来巨大的收获与惊喜💝💝💝! 

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

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

相关文章

【1】linux命令每日分享——mkdir创建目录

大家好&#xff0c;这里是sdust-vrlab&#xff0c;Linux是一种免费使用和自由传播的类UNIX操作系统&#xff0c;Linux的基本思想有两点&#xff1a;一切都是文件&#xff1b;每个文件都有确定的用途&#xff1b;linux涉及到IT行业的方方面面&#xff0c;在我们日常的学习中&…

剑指offer-消失的数字、数组中出现的次数

消失的数字 解法一&#xff1a;求和相减 假设nums为[0,1,2,4],消失的数字为3&#xff0c;完整的数组应该是[0,1,2,3,4]&#xff0c;则sum101247,sum20123410&#xff0c;我们很容易发现 sum2-sum1 01234 - 0124 3&#xff0c;即为消失的数字。因此&#xff0c;我们可以采用先…

国内有哪些值得一去的通信类博物馆?

众所周知&#xff0c;博物馆是收藏、展示和研究历史文物的地方。参观博物馆&#xff0c;既可以回顾历史往事&#xff0c;也可以学习知识。那么&#xff0c;作为通信人&#xff0c;你知道国内有哪些通信领域的博物馆吗&#xff1f;今天&#xff0c;就让小枣君给大家介绍介绍。█…

没有基础学习编程Python难学吗?

你听说过Python吗&#xff1f;如果是这样&#xff0c;你有没有想过它是否很难学习&#xff1f;在本文中&#xff0c;我将告诉您什么是 Python 以及为什么在 2023 年学习它是一个好主意。Python 是一种计算机编程语言&#xff0c;广泛用于 Web 开发、科学计算、数据分析、人工智…

ChatGPT的API接口的模型有多少种?这些模型都有什么功能或者在应用场景上有什么区别?【模型介绍使用与调用接口方法】

OpenAI 的 API 接口提供了多个 GPT-3 模型,每个模型针对不同的应用场景和任务进行了优化。以下是目前可用的 GPT-3 模型: davinci: 这是最大和最全面的模型,具有最高的准确性和灵活性,用于多种自然语言处理任务,如文本生成、对话系统、翻译等。 curie: 这个模型比 davin…

MySQL:想实现sql语句进行批量删除数据库或表,而引发的熬夜探究

因为在自测过程中&#xff0c;创建了很多数据库&#xff0c;一个个手动删除属实有点对不起程序员这个身份&#xff0c;那么有没有简单的sql语句操作来进行批量删除数据库呢&#xff1f;于是便有了本篇文章 上面图片是AI创作&#xff0c;未经允许&#xff0c;不可商用哦&#xf…

谷粒学苑第一天

谷粒学苑第一天 官方文档&#xff08;多看看&#xff09;&#xff1a;https://mybatis.org/mybatis-3/zh/sqlmap-xml.html#Auto-mapping 问题1&#xff1a;新建springboot没有pom文件&#xff08;已解决&#xff09; 修改pom文件 有这个web依赖&#xff0c;properties才会是小…

CRM外呼系统

对于如今企业来讲&#xff0c;电销依然是企业进行销售的主要手段&#xff0c;因其成本低&#xff0c;覆盖率较广&#xff0c;时间获客较短。运用公司自动化信息管理技术和专业化运行平台&#xff0c;完成公司产品的推介、咨询、报价以及产品成交条件确认等主要营销过程的业务 …

yolov5源码解读--数据处理模块

yolov5源码解读--数据处理模块加载数据读取图片加载标签马赛克数据增强图片标签其他的数据增强变图像变标签__getitem__构建Batch加载数据 create_dataloader 跳转到datasets.py文件中&#xff0c;可以看到支持输入的文件类型非常丰富。。 回归正题 跳转LoadImagesAndLabel…

小程序(九)后端 签到1

文章目录一、考勤时间表设计1、表设计二、缓存考勤时间1、mapper.xml2、常量封装类三、封装检测当天是否可以签到1、为什么要检测是否可以签到&#xff1f;2、怎么判断当天是工作日还是节假日&#xff1f;3、封装持久层代码1&#xff09;查询特殊休息日2&#xff09;查询特殊工…

jjava企业级开发-01

一、Spring容器演示 采用Spring配置文件管理Bean 1、创建Maven项目 修改项目的Maven配置 2、添加Spring依赖 在Maven仓库里查找Spring框架&#xff08;https://mvnrepository.com&#xff09; 同上添加其他依赖 <?xml version"1.0" encoding"UTF-8…

stm32f407探索者开发板(十八)——串口通信实验讲解(USART_RX_STA流程图详解)

文章目录一、uart_init&#xff08;串口初始化&#xff09;二、USART1_IRQHandler&#xff08;串口1中断服务程序&#xff09;三、main.c&#xff08;主函数&#xff09;四、关于printf的支持一、uart_init&#xff08;串口初始化&#xff09; 就是根据上一篇的一样的步骤&…

数据结构之树

树是一种数据结构 包括&#xff1a; 根节点 度&#xff1a;每一个节点的子节点个数 左子节点&#xff1a;左下方的节点 右子节点&#xff1a;右下方的节点 左子树 右子树 树的内部结构 二叉查找树 又称二叉搜索树或者二叉排序树 特点 每一个节点最多只有两个节点 任…

【强化学习】解决gym安装Atari2600环境gym[atari,accept-rom-license] RuntimeError 无法下载Roms的问题

先上Roms.tar.gz安装地址&#xff1a;Roms.tar.gz 以下内容是解决问题的思路&#xff0c;如果已经完全知道问题原因可以直接跳过 安装gym[accept-rom-license]时会出现安装失败的情况: 先是卡在&#xff1a;Building wheel for AutoROM.accept-rom-license 然后是显示安装失败…

非常优秀的网站设计案例,设计师必备

厚积才能薄发&#xff0c;一个优秀的设计师的天性一定是想要获得更多网站设计灵感&#xff0c;擅于为新项目寻找创意切入点、搜索设计参考资源、最新的设计趋势。今天为大家带来了一组免费可商用的网站设计案例&#xff0c;通过这些网站设计案例&#xff0c;你可以获得&#xf…

To prevent a memory leak, the JDBC Driver has been forcibly unregistered.

java项目发布到kubernetes集群中&#xff0c;报错 SEVERE: The web application [] registered the JDBC driver [com.alibaba.druid.proxy.DruidDriver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has …

Obsidium一键编码作业,Obsidia惊人属性

Obsidium一键编码作业,Obsidia惊人属性 每个区域都包含几个可定制的功能&#xff0c;允许用户确定如何完全执行应用程序的安全性。Obsidia的功能区允许用户存储任何调整或一键编码作业。 Obsidia惊人属性&#xff1a; 代码虚拟化&#xff1a;代码虚拟化允许您转换程序代码的特定…

【电商】库存管理

库存管理&#xff0c;简单的说&#xff0c;就是管理商品和数量之间的关系。库存系统是电商后台系统中不可或缺的一部分 在电商系统中商品库存是非常重要的&#xff0c;在财务进销存系统中也梳理过存货的内容&#xff0c;在销售系统和仓库中的库存有什么区别&#xff1f; 一、什…

SSH 服务支持弱加密算法

漏洞扫描有SSH 服务支持弱加密算法&#xff0c;解决方案有两个&#xff1a; 方案一&#xff1a;修改 SSH 配置文件&#xff0c;添加加密算法&#xff1a; vi /etc/ssh/sshd_config 最后添加一下内容&#xff08;去掉 arcfour、arcfour128、arcfour256 等弱加密算法&#xff09;…

教你数分钟内创建并运行一个 DolphinScheduler Workflow

点击蓝字 关注我们作者 | 鲍亮&#xff0c;Apache DolphinScheduler PMC Member01Workflow是什么&#xff1f;对于数仓场景和数据湖场景来说&#xff0c;最显著的特点就是数据处理的长流程和高复杂度任务依赖关系&#xff0c;从源数据采集到最终报表数据的生成&#xff0c;中间…