261 lines
14 KiB
JavaScript
261 lines
14 KiB
JavaScript
$(function () {
|
||
alert("HI");
|
||
floorguid = localStorage.getItem('floorguid');
|
||
chartDom = document.getElementById("floor_map");
|
||
myChart = echarts.init(chartDom, null, { width: 'auto', });
|
||
console.log(floorguid);
|
||
|
||
$.ajax({
|
||
url: '/upload/meter_source_1_3.json',
|
||
type: 'GET',
|
||
dataType: 'json',
|
||
cache: false,
|
||
success: function (code, statut) {
|
||
console.log(code.reverse());
|
||
|
||
var filter3Floor = code.filter(function (i, n) {
|
||
return i.floor === 3;
|
||
});
|
||
|
||
currentData = filter3Floor[0].meter;
|
||
currentData = $.map(currentData, function (item) {
|
||
item.seleted = false;
|
||
return item;
|
||
});
|
||
|
||
console.log('currentData', currentData);
|
||
|
||
//#region 平面圖設定
|
||
$.get(`/upload/floor_map/${floorguid}.svg`, function (svg) {
|
||
echarts.registerMap('floor_svg', { svg: svg });
|
||
|
||
option = {
|
||
// animationDurationUpdate: 1500,
|
||
tooltip: {
|
||
formatter: function (params) {
|
||
return `名稱:${params.data.name}<br>
|
||
Guid:${params.data.guid}`
|
||
}
|
||
},
|
||
toolbox: { //工具欄
|
||
show: false
|
||
},
|
||
geo: {
|
||
map: 'floor_svg',
|
||
roam: true,
|
||
scaleLimit: { //限制放大縮小倍數
|
||
max: 8,
|
||
min: 1.5
|
||
},
|
||
layoutSize: '100%',
|
||
layoutCenter: ['50%', '50%'],
|
||
zoom: 1.5,
|
||
silent: true
|
||
},
|
||
series: [
|
||
{
|
||
type: 'scatter',
|
||
coordinateSystem: 'geo',
|
||
geoIndex: 0,
|
||
symbol: 'circle',
|
||
symbolSize: 10,
|
||
symbolOffset: [10, 10],
|
||
label: {
|
||
show: false
|
||
},
|
||
data: null,
|
||
z: 2
|
||
},
|
||
{ //放未選擇的
|
||
type: 'effectScatter',
|
||
coordinateSystem: 'geo',
|
||
geoIndex: 0,
|
||
showEffectOn: 'emphasis', //hover 才會顯示漣漪
|
||
symbol: "image://",
|
||
symbolSize: 30,
|
||
label: {
|
||
formatter: '{b}',
|
||
position: 'bottom',
|
||
show: true,
|
||
backgroundColor: 'orange'
|
||
},
|
||
emphasis: {
|
||
label: {
|
||
show: true,
|
||
fontSize: '20',
|
||
fontWeight: 'bold',
|
||
color: 'yellow'
|
||
}
|
||
},
|
||
selectedMode: 'single',
|
||
data: null,
|
||
z: 1
|
||
},
|
||
{ //放選擇的
|
||
type: 'effectScatter',
|
||
coordinateSystem: 'geo',
|
||
geoIndex: 0,
|
||
showEffectOn: 'render',
|
||
symbol: "image://",
|
||
symbolSize: 30,
|
||
label: {
|
||
formatter: '{b}',
|
||
position: 'bottom',
|
||
show: true,
|
||
backgroundColor: 'orange'
|
||
},
|
||
emphasis: {
|
||
label: {
|
||
show: true,
|
||
fontSize: '20',
|
||
fontWeight: 'bold',
|
||
color: 'yellow'
|
||
}
|
||
},
|
||
selectedMode: 'single',
|
||
data: null,
|
||
z: 1
|
||
}
|
||
],
|
||
};
|
||
|
||
myChart.setOption(option);
|
||
resetData();
|
||
|
||
myChart.getZr().on('click', function (params) {
|
||
console.log("click", params);
|
||
var pixelPoint = [params.offsetX, params.offsetY];
|
||
var dataPoint = myChart.convertFromPixel({ geoIndex: 0 }, pixelPoint);
|
||
console.log(dataPoint);
|
||
// currentData.push([dataPoint[0], dataPoint[1], 1]);
|
||
// myChart.setOption(option);
|
||
});
|
||
|
||
//myChart.on('selectchanged', function (params) {
|
||
// var pixelPoint = [params.offsetX, params.offsetY];
|
||
// var dataPoint = myChart.convertFromPixel({ geoIndex: 0 }, pixelPoint);
|
||
// console.log("selectchanged", params);
|
||
// // currentData.push([dataPoint[0], dataPoint[1], 1]);
|
||
// // myChart.setOption(option);
|
||
|
||
// currentData = $.map(currentData, function (item) {
|
||
// item.seleted = false;
|
||
// return item;
|
||
// });
|
||
|
||
// if (params.selected.length > 0) {
|
||
// currentData[params.selected[0].seriesIndex - 1].seleted = true;
|
||
// }
|
||
|
||
// resetData();
|
||
//});
|
||
|
||
// myChart.getZr().on('mousewheel', function (params) {
|
||
// console.log(params)
|
||
// })
|
||
myChart.on('georoam', function (params) {
|
||
var zoom = myChart.getOption().geo[0].zoom;
|
||
console.log(zoom)
|
||
|
||
if (zoom <= 2) {
|
||
myChart.setOption({
|
||
geo: {
|
||
roam: 'scale'
|
||
},
|
||
series: [{
|
||
symbolOffset: [0, 0],
|
||
}, {
|
||
data: [],
|
||
}]
|
||
});
|
||
} else {
|
||
myChart.setOption({
|
||
geo: {
|
||
roam: true
|
||
},
|
||
});
|
||
}
|
||
resetData();
|
||
});
|
||
});
|
||
//#endregion
|
||
|
||
//#region 重設平面圖設備資料
|
||
function resetData() {
|
||
const scatter_symbol_convertData = function (data) {
|
||
var res = [];
|
||
|
||
res = $.map(data, function (item) {
|
||
delete item.symbol;
|
||
switch (item.status) {
|
||
case 0:
|
||
// item.push({ 'itemStyle': { 'color': '#ccc' } });
|
||
item.itemStyle = { 'color': '#ccc' };
|
||
break;
|
||
case 1:
|
||
// item.push({ 'itemStyle': { 'color': 'green' } });
|
||
item.itemStyle = { 'color': 'green' };
|
||
break;
|
||
case 2:
|
||
// item.push({ 'itemStyle': { 'color': 'red' } });
|
||
item.itemStyle = { 'color': 'red' };
|
||
break;
|
||
}
|
||
return item;
|
||
});
|
||
|
||
return res;
|
||
}
|
||
|
||
const effectScatter_unselect_convertData = function (data) {
|
||
var res = [];
|
||
|
||
res = data.filter(function (item, index) {
|
||
return item.seleted == false;
|
||
});
|
||
|
||
return res;
|
||
}
|
||
|
||
const effectScatter_selected_convertData = function (data) {
|
||
var res = [];
|
||
|
||
res = data.filter(function (item, index) {
|
||
return item.seleted == true;
|
||
});
|
||
|
||
return res;
|
||
}
|
||
|
||
var zoom = myChart.getOption().geo[0].zoom;
|
||
console.log("resetData", currentData);
|
||
|
||
if (zoom <= 2) {
|
||
myChart.setOption({
|
||
series: [{
|
||
symbolOffset: [0, 0],
|
||
data: scatter_symbol_convertData(currentData)
|
||
}, {
|
||
data: []
|
||
}, {
|
||
data: []
|
||
}]
|
||
});
|
||
} else {
|
||
myChart.setOption({
|
||
series: [{
|
||
symbolOffset: [10, 10],
|
||
data: scatter_symbol_convertData(currentData)
|
||
}, {
|
||
data: effectScatter_unselect_convertData(currentData),
|
||
}, {
|
||
data: effectScatter_selected_convertData(currentData),
|
||
}]
|
||
});
|
||
}
|
||
}
|
||
//#endregion
|
||
}
|
||
});
|
||
|
||
}); |