$(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}
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 } }); });