用echart玩點好玩的--酷炫熱力圖
先bb兩句
首先承認酷炫是標題黨,哈哈哈,參考了echart的官網開發示例,對一些樣式做了自己的改動,變得稍微極客一點,另外在html中使用了ajax獲取現成json資料,如果你有介面的話可以直接請求介面!
上效果圖
其中氣泡的大小和顏色都是根據各省不同的人數來展示,顏色還可以你自己調整成你認為好看的,波紋是動態的輻射,感覺做的很low,直接用的官方文件調整的,應該有更帥的。
程式碼
地址:https://github.com/lightTrace/echart/tree/master/hotMap
程式碼所依賴的全部官方檔案都有的,可以在idea直接open in browser選擇瀏覽器直接開啟hotmap.html即可看到效果,直接開啟是不行的,因為加入了ajax呼叫,或者部署到nginx上面也行。
走過路過的點個讚唄
hotmap.html簡單說說
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=EDGE">
<title>ECharts</title>
<link rel="stylesheet" type="text/css"/>
<script src="gf-js/jquery.min.js"></script>
<script src="gf-js/echarts.js"></script>
<script src="gf-js/china.js"></script>
<style>#china-map {width:100%; height: 100%;margin: auto;}</style>
</head>
<body>
<div id="china-map"></div>
<script>
var province = "河北省、山西省、遼寧省、吉林省、黑龍江省、江蘇省、浙江省、安徽省、福建省、江西省、山東省、河南省、湖北省、湖南省、廣東省、海南省、四川省、貴州省、雲南省 、陝西省 、甘肅省、青海省、臺灣省、西藏自治區、廣西壯族自治區、內蒙古自治區、寧夏回族自治區、新疆維吾爾自治區、北京市、上海市、天津市、重慶市、香港、澳門"
var ajaxReqs = null;
function reqs() {
if(ajaxReqs !== null) {
ajaxReqs.abort();
ajaxReqs = null;
}
var data=[]
var geoCoordMap={}
var max = 0,
min = 1000; // min,max為了自動計算出人數最多的省和最小的省從而自動分配顏色
var maxSize4Pin = 55,
minSize4Pin = 35;
$.ajax({
type : "GET",
// url : "http://192.168.2.184:9001/collect/region",
url:"./data.json",
async: false,
dataType : "json",
cache:false,
success : function (datas) {
list = datas.data.list
$.each(list, function (i, item) {
if(province.indexOf(item.region)!=-1)
{
if(max < item.activityNumber){
max = item.activityNumber
}
if(min > item.activityNumber){
min = item.activityNumber
}
data.push({
name: item.region,
value: item.activityNumber
})
var point = []
point.push(item.lng, item.lat)
geoCoordMap[item.region]=point
}
});
}
});
console.log(min)
console.log(max)
$('#china-map').width($('#china-map').width());
$('#china-map').height($('#china-map').width());
var myChart = echarts.init(document.getElementById('china-map'));
var name_title = ''
var subname = ''
var nameColor = '#2880fc'
var name_fontFamily = '宋體'
var subname_fontSize = 15
var name_fontSize = 25
var mapName = 'china'
/*獲取地圖資料*/
myChart.showLoading();
var mapFeatures = echarts.getMap(mapName).geoJson.features;
myChart.hideLoading();
var convertData = function(data) {
var res = [];
for (var i = 0; i < data.length; i++) {
var geoCoord = geoCoordMap[data[i].name];
if (geoCoord) {
res.push({
name: data[i].name,
value: geoCoord.concat(data[i].value),
});
}
}
return res;
};
option = {
backgroundColor: 'rgba(29, 52, 108, 1)',
title: {
text: name_title,
subtext: subname,
x: 'left',
y:'200px',
textStyle: {
color: nameColor,
fontFamily: name_fontFamily,
fontSize: name_fontSize
},
subtextStyle:{
fontSize:subname_fontSize,
fontFamily:name_fontFamily
}
},
visualMap: {
show: false,
min: min,
max: max,
left: 'left',
top: 'bottom',
color: '#b70d05',
text: ['高', '低'], // 文字,預設為數值文字
calculable: true,
seriesIndex: [1],
inRange: {
color: ['#00467F', '#A5CC82','#c3fc0a','#fca80d', '#cc0529'] // 地圖不同省份填充的顏色
}
},
geo: {
show: true,
map: mapName,
label: {
normal: {
show: false
},
emphasis: {
show: false,
}
},
roam: true, //地圖是否可以縮放
itemStyle: {
normal: {
areaColor: '#031525',
borderColor: '#00effc',
},
emphasis: {
areaColor: '#2B91B7',
}
},
regions: [
{
name: '南海諸島',
value: 0,
itemStyle: {
normal: {
opacity: 0,
label: {
show: false
}
}
}
}
]
},
series: [{
name: '散點',
type: 'scatter',
coordinateSystem: 'geo',
data: convertData(data),
symbolSize: function(val) {
return 1;
},
label: {
normal: {
formatter: '{b}',
position: 'right',
show: true
},
emphasis: {
show: true
}
},
itemStyle: {
normal: {
color: '#05C3F9'
}
}
},
{
type: 'map',
map: mapName,
geoIndex: 0,
aspectScale: 0.75, //長寬比
showLegendSymbol: true, // 存在legend時顯示
label: {
normal: {
show: true
},
emphasis: {
show: false,
textStyle: {
color: '#fff'
}
}
},
roam: true,
itemStyle: {
normal: {
areaColor: '#031525',
borderColor: '#3B5077',
},
emphasis: {
areaColor: '#2B91B7'
}
},
animation: false,
data: data
},
{
name: '點',
type: 'effectScatter',
coordinateSystem: 'geo',
symbol: 'pin', //氣泡
effectType: 'ripple',
animation: true,
rippleEffect: {
period: 5,
scale: 1.5,
brushType: 'stroke'
},
symbolSize: function(val) {
var a = (maxSize4Pin - minSize4Pin) / (max - min);
var b = minSize4Pin - a * min;
b = maxSize4Pin - a * max;
return a * val[2] + b;
},
label: {
normal: {
show: true,
formatter:'{@[2]}', //這裡加這個是防止echart地圖載入資料載入氣泡的數值載入成緯度,這個bug很尷尬
textStyle: {
color: '#fff',
fontSize: 9,
}
}
},
itemStyle: {
normal: {
color: '#F62157', //標誌顏色
}
},
zlevel: 6,
data: convertData(data),
},
]
};
myChart.setOption(option);
}
reqs();
setInterval(reqs, 3000);
</script>
</body>
</html>
發現沒什麼好說的,程式碼很簡單,註釋也有,主要我寫的菜,請大家諒解,起碼提供了官方下載檔案,哈哈哈,後面學習下可能會做一點更酷的。
相關文章
- 適用於 Fedora 28 的 3 款酷炫生產力應用
- 2.24 炫酷支配點對
- SVG動畫應用-酷炫的圖片展示效果SVG動畫
- 高仿QQ視訊加點炫酷特效—你這樣玩過嗎特效
- 4 款酷炫的終端應用
- 用WPF做炫酷的透明窗體
- android炫酷的textviewAndroidTextView
- 打造炫酷效果:用Java優雅地製作Excel迷你圖JavaExcel
- 炫酷動圖讓你從CABasicAnimation看到CATransition
- echart 環圖
- 使用flutter打造炫酷的listFlutter
- 七款酷炫的 Mac 屏保Mac
- Android原生繪圖之炫酷倒數計時Android繪圖
- InteractiveGraph 實現酷炫關係圖譜之前瞻
- 前端炫酷特效合集前端特效
- 帶動格鬥遊戲新熱潮《時空獵人3》炫酷格鬥技盤點遊戲
- Leaflet-vue 熱力圖 (設定熱力圖顏色)Vue
- jQuery帶炫酷輪播圖效果的Lightbox彈出層外掛jQuery
- Qt實現炫酷啟動圖-動態進度條QT
- 那些炫酷的特效–QQ空間+VUE特效Vue
- Atom安裝炫酷外掛
- Hyperspace 炫酷太空隧道穿梭屏保
- 3 個好玩的前端開源專案「GitHub 熱點速覽」前端Github
- IntelliJ IDEA 新版釋出:支援CPU火焰圖,新增酷炫主題IntelliJIdea
- vue寫一個炫酷的日曆元件Vue元件
- Lens —— 最炫酷的 Kubernetes 桌面客戶端客戶端
- 請收下這72個炫酷的CSS技巧CSS
- Flutter 實現酷炫的3D效果Flutter3D
- 如何讓你的Cadence Library看起來酷炫
- 11個炫酷的Linux終端命令大全Linux
- 如何實現炫酷的數字大屏
- 一個炫酷的頭像懸停效果
- 不規則圖形背景排版高階技巧 -- 酷炫的六邊形網格背景圖
- echart 各種圖實現
- 8個超炫酷仿蘋果應用的HTML5動畫蘋果HTML動畫
- 部落格園皮膚炫酷效果
- js炫酷訊息通知外掛JS
- Android 炫酷多重水波紋 MultiWaveHeaderAndroidHeader