<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="height:800px"></div>
<!-- ECharts单文件引入 -->
<script src="${pageContext.request.contextPath}/lib/echart/dist/echarts.js"></script>
<script type="text/javascript">
// 路径配置
require.config({
paths: {
echarts: '${pageContext.request.contextPath}/lib/echart/dist'
}
});

// 使用
require(
[
'echarts',
'echarts/chart/bar', // 使用柱状图就加载bar模块,按需加载
'echarts/chart/line', // 使用柱状图就加载line模块,按需加载
'echarts/chart/force', // 使用柱状图就加载force关系网络模块,按需加载
'echarts/chart/map' // 使用柱状图就加载map模块,按需加载
],
function (ec) {
// 基于准备好的dom,初始化echarts图表,ec是包含echarts的对象,但不是echarts实例
var myChart = ec.init(document.getElementById('main'),'default'); //后面是主题,默认不添加
//myChart.showLoading();
//添加点击事件
var ecConfig = require('echarts/config');
myChart.on(ecConfig.EVENT.CLICK, eConsole);
//添加双击事件
//myChart.on(ecConfig.EVENT.DBCLICK, eConsoledb);
var option = {
title : {
text: 'iphone销量',//主标题
subtext: '纯属虚构',//副标题
x:'center'//居中
},
//提示框
tooltip : {
trigger: 'item'
},
//图例
legend: {
orient: 'vertical',//图例布局方式: 默认水平布局 可选为:'horizontal' | 'vertical'
x:'left',//左 中 右 三个选择 left center right
y:'top',//上 中 下 三个选择 top center bottom
data:['iphone3','iphone4','iphone5'],//图例名
backgroundColor:'#aaa',//背景色
textStyle:{color:'#333'}//设置文字的样式
},
//值域范围
dataRange: {
min: 0,
max: 2500,
x: 'left',
y: 'bottom',
text:['高','低'], // 文本,默认为数值文本
calculable : true
},
//工具箱的使用
toolbox: {
show: true,
orient : 'vertical',//垂直布局
x: 'right',//右
y: 'center',//中
feature : {
mark : {show: true},
dataView : {show: true, readOnly: false},
restore : {show: true},
saveAsImage : {show: true},
restore : {
show : true,
title : '还原'
},
dataZoom : {
show : true,
title : {
dataZoom : '区域缩放',
dataZoomReset : '区域缩放后退'
}
}
}
},
//缩放漫游组件,仅对地图有效。
roamController: {
show: true,
x: 'right',
mapTypeControl: {
'china': true
}
},
//驱动图表生成的数据内容数组,数组中每一项为一个系列的选项及数据,其中个别选项仅在部分图表类型中有效
series : [
{
name: 'iphone3',//系列名称 与legend关联
type: 'map',//图表类型
mapType: 'china',//地图类型
roam: false,
//图形样式,可设置图表内图形的默认样式和强调样式(悬浮时样式):
itemStyle:{
normal:{label:{show:true}},
emphasis:{label:{show:true}}
},
//iPhone3的全国分布数据,Math.round()是四舍五入取整
data:[
{name: '北京',value: Math.round(Math.random()*1000)},
{name: '天津',value: Math.round(Math.random()*1000)},
{name: '上海',value: Math.round(Math.random()*1000)},
{name: '重庆',value: Math.round(Math.random()*1000)},
{name: '河北',value: Math.round(Math.random()*1000)},
{name: '河南',value: Math.round(Math.random()*1000)},
{name: '云南',value: Math.round(Math.random()*1000)},
{name: '辽宁',value: Math.round(Math.random()*1000)},
{name: '黑龙江',value: Math.round(Math.random()*1000)},
{name: '湖南',value: Math.round(Math.random()*1000)},
{name: '安徽',value: Math.round(Math.random()*1000)},
{name: '山东',value: Math.round(Math.random()*1000)},
{name: '新疆',value: Math.round(Math.random()*1000)},
{name: '江苏',value: Math.round(Math.random()*1000)},
{name: '浙江',value: Math.round(Math.random()*1000)},
{name: '江西',value: Math.round(Math.random()*1000)},
{name: '湖北',value: Math.round(Math.random()*1000)},
{name: '广西',value: Math.round(Math.random()*1000)},
{name: '甘肃',value: Math.round(Math.random()*1000)},
{name: '山西',value: Math.round(Math.random()*1000)},
{name: '内蒙古',value: Math.round(Math.random()*1000)},
{name: '陕西',value: Math.round(Math.random()*1000)},
{name: '吉林',value: Math.round(Math.random()*1000)},
{name: '福建',value: Math.round(Math.random()*1000)},
{name: '贵州',value: Math.round(Math.random()*1000)},
{name: '广东',value: Math.round(Math.random()*1000)},
{name: '青海',value: Math.round(Math.random()*1000)},
{name: '西藏',value: Math.round(Math.random()*1000)},
{name: '四川',value: Math.round(Math.random()*1000)},
{name: '宁夏',value: Math.round(Math.random()*1000)},
{name: '海南',value: Math.round(Math.random()*1000)},
{name: '台湾',value: Math.round(Math.random()*1000)},
{name: '香港',value: Math.round(Math.random()*1000)},
{name: '澳门',value: Math.round(Math.random()*1000)}
]
},
{
name: 'iphone4',
type: 'map',
mapType: 'china',
itemStyle:{
normal:{label:{show:true}},
emphasis:{label:{show:true}}
},
data:[
{name: '北京',value: Math.round(Math.random()*1000)},
{name: '天津',value: Math.round(Math.random()*1000)},
{name: '上海',value: Math.round(Math.random()*1000)},
{name: '重庆',value: Math.round(Math.random()*1000)},
{name: '河北',value: Math.round(Math.random()*1000)},
{name: '安徽',value: Math.round(Math.random()*1000)},
{name: '新疆',value: Math.round(Math.random()*1000)},
{name: '浙江',value: Math.round(Math.random()*1000)},
{name: '江西',value: Math.round(Math.random()*1000)},
{name: '山西',value: Math.round(Math.random()*1000)},
{name: '内蒙古',value: Math.round(Math.random()*1000)},
{name: '吉林',value: Math.round(Math.random()*1000)},
{name: '福建',value: Math.round(Math.random()*1000)},
{name: '广东',value: Math.round(Math.random()*1000)},
{name: '西藏',value: Math.round(Math.random()*1000)},
{name: '四川',value: Math.round(Math.random()*1000)},
{name: '宁夏',value: Math.round(Math.random()*1000)},
{name: '香港',value: Math.round(Math.random()*1000)},
{name: '澳门',value: Math.round(Math.random()*1000)}
]
},
{
name: 'iphone5',
type: 'map',
mapType: 'china',
itemStyle:{
normal:{label:{show:true}},
emphasis:{label:{show:true}}
},
data:[
{name: '北京',value: Math.round(Math.random()*1000)},
{name: '天津',value: Math.round(Math.random()*1000)},
{name: '上海',value: Math.round(Math.random()*1000)},
{name: '广东',value: Math.round(Math.random()*1000)},
{name: '台湾',value: Math.round(Math.random()*1000)},
{name: '香港',value: Math.round(Math.random()*1000)},
{name: '澳门',value: Math.round(Math.random()*1000)}
]
}
]
};

// 为echarts对象加载数据
//myChart.showLoading();
myChart.setOption(option);

function eConsole(param) {
if (typeof param.seriesIndex == 'undefined') {
return;
}
if (param.type == 'click') {
alert(param.name+"*-*"+param.value);
}
}
}
);

</script>
</body>

 另外:使用后台动态加载如下:

定义 数据接口:地图上iphone3 iphone4 iphone5的三个数据来源对象为 obj, obj1, obj2

var obj =[];//数据1,赋值给data
var obj1=[];//数据2  ...
var obj2=[];//数据3  ...

function ObjStory(name,value) //声明对象
{
  this.name = name;//对象的属性有name
  this.value= value; //对象的属性value
}
$.ajax({

//后台请求
  url : '${pageContext.request.contextPath}/media/getProvinceData.action', //TODO
  data : { },
  type : 'post',
  async : false,
  dataType : "json",
  success: function(data){
  //debugger;

  for(var i=0;i<data.length;i++)
  {

    //遍历后台获取到的数据 ,并将得到的数据分别赋值给新建对象的name 和value属性,最后将对象加入数组中 ,这里全国三十四个省份的数据都加入该数组
    obj.push(new ObjStory(data[i].PROVINCE,data[i].IPHONE3));
    obj1.push(new ObjStory(data[i].PROVINCE,data[i].IPHONE4));
    obj2.push(new ObjStory(data[i].PROVINCE,data[i].IPHONE5));
  }

}
})

最新文章

  1. Android中点击事件的实现方式
  2. ESENT分布式数据存储
  3. 解决iOS9下隐藏App返回按钮文字导致的诡异闪屏问题
  4. 内存溢出OOM与内存泄漏ML
  5. makefile多目录的.c 格式.cpp混合编译
  6. SURF
  7. Hbase总结(一)-hbase命令,hbase安装,与Hive的区别,与传统数据库的区别,Hbase数据模型
  8. asp.net的decimal保留两位小数
  9. Dijkstra in python
  10. -_-#【Better Code】字符串匹配
  11. Android学习笔记之viewholder
  12. (细节控)swift3.0与融云IMKIT开发问题(一部分) override func onSelectedTableRow Method does not override any method from its superclass
  13. angularjs的几种常见写法
  14. python_10_文件操作
  15. spawn-fcgi运行fcgiwrap
  16. 有些人表面风光,背地里for循环怎么写都要百度
  17. sql重点题
  18. Learning-Python【20】:Python常用模块(3)—— shelve、pickle、json、xml、configparser
  19. Java虚拟机JVM相关知识整理
  20. Git教程学习(四)

热门文章

  1. dragsort html拖拽排序
  2. windows 2003自动登录的具体步骤
  3. JS中误用/g导致的正则test()无法正确重复执行
  4. scala Basic 第三课
  5. 使用好压(HaoZip)软件打包EverEdit制作安装程序
  6. RSA加密算法的简单案例
  7. Markdown 完全指南
  8. Freemarker与Springmvc
  9. 第2章 Linux系统安装(2)_Linux系统分区及文件系统
  10. Netron开发快速上手(一):GraphControl,Shape,Connector和Connection