分布指數
摘要:效果圖準備工作高德地圖申請安裝中國地圖高德地圖官方點我進入創建動態創建標簽后的是需要的插件中國地圖安裝開始使用創建組件寫入需要的分布指數高低寫入高德地圖需要的
效果圖準備工作
高德地圖申請key
安裝Echarts 中國地圖
高德地圖
官方API:點我進入
創建AMap.js
export default function MapLoader () {
return new Promise((resolve, reject) => {
if (window.AMap) {
resolve(window.AMap)
} else {
// 動態創建script標簽
var script = document.createElement("script")
script.type = "text/javascript"
script.async = true
script.src = "https://webapi.amap.com/maps");;
// plugin后的是需要的插件
script.onerror = reject
document.head.appendChild(script)
}
window.initAMap = () => {
resolve(window.AMap)
}
})
}
Echarts 中國地圖
安裝Echarts
npm install echarts -S
創建組件 distribution.vue
寫入Echarts 需要的DOM
分布指數
高 低
寫入高德地圖需要的DOM
引入高德地圖、Echarts
import "echarts/map/js/china"; //中國地圖js
import MapLoader from "components/home/AMap"
Echarts方法
generateEcharts() {
var echarts = require("echarts");
var myChart = echarts.init(this.$refs.main); // 基于準備好的dom,初始化echarts實例
this.$ajax.get(this.HOST + "/redesign/home/findEnterpriseistribution").then( (res) => {
// 數據格式
// [
// {name: "北京", value: 3, ranking: 1},
// {name: "河北", value: 2, ranking: 2},
// {name: "上海", value: 1, ranking: 3},
// {name: "廣東", value: 1, ranking: 4}
// ...
// ]
this.homebution = res.data.resultObject;
var data = [];
for (let i = 0; i < res.data.resultObject.length; i++) {
this.homebutionnum += res.data.resultObject[i].value;
let classnum = ""
// 排名顯示樣式
if(res.data.resultObject[i].ranking == 1) {
classnum = "#1669e6"
}else if(res.data.resultObject[i].ranking > 1 && res.data.resultObject[i].ranking <= 4) {
classnum = "#31a4ed"
}else if(res.data.resultObject[i].ranking > 4 && res.data.resultObject[i].ranking <= 10) {
classnum = "#2cccfd"
}else if(res.data.resultObject[i].ranking > 10 && res.data.resultObject[i].ranking <= 20) {
classnum = "#7fe2fd"
}else {
classnum = "#d9f4fe"
}
data.push(
{
name: res.data.resultObject[i].name,
itemStyle: {
normal: {
areaColor: classnum,
// borderWidth: 2
},
emphasis: {//高亮狀態下的多邊形和標簽樣式
borderWidth: 1,
// borderColor: "#d9f4fe",
areaColor: "#d9f4fe",
label: {
shadowColor: "#d9f4fe", //默認透明
shadowBlur: 10,
show: true,
textStyle: {
fontSize: 12,
color: "#3db77f"
}
}
}
},
label: {
normal: {
show: true,
textStyle: {
fontSize: 12,
color: "#0d6fb8"
}
},
emphasis: {
show: true,
color: "#3db77f"
}
},
value: res.data.resultObject[i].value ");"",
ranking: res.data.resultObject[i].ranking ");""
}
)
}
// 準備提示數據
var option = {
tooltip: {
formatter: (params) => {
var info = "";
if(params.data) {
info = `
${ params.name }
${ params.data.value }
排名:${ params.data.ranking }
`
}else {
info = `
${ params.name }
`
}
return info;
},
backgroundColor: "rgba(0,0,0,.6)",//提示標簽背景顏色
textStyle: { color: "#fff" } //提示標簽字體顏色
},
//配置屬性
series: [{
name: "數據",
type: "map",
mapType: "china",
roam: true,
label: {
normal: {
show: false //省份名稱
},
emphasis: {
show: false
}
},
data: data //數據
}],
};
//使用制定的配置項和數據顯示圖表
myChart.setOption(option);
})
}
高德地圖方法
Scottmap() {
let that = this;
that.map = "";
MapLoader().then(AMap => {
console.log("地圖加載成功")
that.map = new AMap.Map("container", {
center: [116.05438, 38.98065],
// center: [116.397428, 39.90923],
zoom: 5
})
// 由于項目是按雄安地區使用 API暫時還未把雄安劃分 所以決定把安新縣、雄縣、容城縣(三縣合一就是雄安)繪制成高亮
// 繪制高亮
var district = new AMap.DistrictSearch({
// 返回行政區邊界坐標等具體信息
extensions: "all",
// 設置查詢行政區級別為 區
level: "district"
})
var polygons=[];
var polygons2=[];
var polygons3=[];
district.search("安新縣", (status, result) => {
if(polygons) {
that.map.remove(polygons)//清除上次結果
}
polygons = [];
let bounds = result.districtList[0].boundaries;
if (bounds) {
for (let i = 0; i < bounds.length; i++) {
//生成行政區劃polygon
var polygon = new AMap.Polygon({
strokeWeight: 1,
path: bounds[i],
fillOpacity: 0.4,
fillColor: "#80d8ff",
strokeColor: "#0091ea"
});
polygons.push(polygon);
}
}
that.map.add(polygons);
});
district.search("雄縣", (status2, result2) => {
if(polygons2) {
that.map.remove(polygons2)//清除上次結果
}
polygons2 = [];
let bounds = result2.districtList[0].boundaries;
if (bounds) {
for (let i = 0; i < bounds.length; i++) {
//生成行政區劃polygon
var polygon = new AMap.Polygon({
strokeWeight: 1,
path: bounds[i],
fillOpacity: 0.4,
fillColor: "#80d8ff",
strokeColor: "#0091ea"
});
polygons2.push(polygon);
}
}
that.map.add(polygons2)
})
district.search("容城縣", (status2, result2) => {
if(polygons3) {
that.map.remove(polygons2)//清除上次結果
}
polygons3 = [];
let bounds = result2.districtList[0].boundaries;
if (bounds) {
for (let i = 0; i < bounds.length; i++) {
//生成行政區劃polygon
var polygon = new AMap.Polygon({
strokeWeight: 1,
path: bounds[i],
fillOpacity: 0.4,
fillColor: "#80d8ff",
strokeColor: "#0091ea"
});
polygons3.push(polygon);
}
}
that.map.add(polygons3)
})
// 構造矢量圓形(圓)
let circle = new AMap.Circle({
center: [116.05438, 38.98065], // 雄安的中心點
radius: that.distance * 1000, //半徑
strokeColor: "#ffffff", //線顏色
strokeOpacity: 1, //線透明度
strokeWeight: 3, //線粗細度
fillColor: "#276cd4", //填充顏色
fillOpacity: 0.2 //填充透明度
});
that.map.add(circle);
that.map.setFitView(circle);
let lnglat = new AMap.LngLat(116.05438, 38.98065) // lng, lat 替換成傳入的坐標
let polylinePath = [
new AMap.LngLat(116.05438, 38.98065),
new AMap.LngLat(lnglat.offset(that.distance * 1000,0).lng,38.98065)
];
// 創建線覆蓋物
let polyline = new AMap.Polyline({
path: polylinePath,
strokeColor: "#ffffff", //線顏色
strokeOpacity: 1, //線透明度
strokeWeight: 2, //線寬
strokeStyle: "solid", //線樣式
strokeDasharray: [10, 5] //補充線樣式
});
that.map.add(polyline);
// 繪制字
let textPos = lnglat.offset(that.distance * 500,that.distance * 50);
let text = new AMap.Text({
text: `${ that.distance }公里`,
position: textPos,
map: this.map,
style:{
"background": "transparent",
"border": "0 none",
"color": "#276cd4",
"font-size":"14px"}
})
that.map.add(text);
// 測試距離
let Centralpoint = [116.05438, 38.98065];
let targetpoint = this.region
// debugger
// 轉經緯度
let geocoder = new AMap.Geocoder({
city: "全國", //城市設為北京,默認:“全國”
});
let markernum = 0
for (let i = 0; i < targetpoint.length; i++) {
geocoder.getLocation(targetpoint[i], (status, result) => {
if (status === "complete"&& result.geocodes.length) {
let dis = AMap.GeometryUtil.distance(Centralpoint,result.geocodes[0].location);
// 繪制點標記顯示內容,HTML要素字符串
if(dis <= that.distance * 1000) {
markernum++;
let markerContent = "" +
"" +
" " +
""+ markernum +""+
"";
this.$ajax.get(this.HOST + "/redesign/home/findCompanyAll").then( (res) => {
this.matchingenterpriseList.push(res.data.resultObject[i])
})
let marker = new AMap.Marker({
content: markerContent,
position: result.geocodes[0].location,
offset: new AMap.Pixel(-13, -30),
extData:{
id: markernum
}
});
that.markers.push(marker);
marker.setMap(this.map);
}
}
})
}
that.matchingenterpriseState = true;
}, e => {
console.log("地圖加載失敗" ,e)
})
},
左側企業列表
// 企業鼠標經過
matchingenterprisemouseenter(item,index) {
this.activemetchmouseenter = index;
let targetMarker = {};
for (let i = 0; i < this.markers.length; i++) {
let id = this.markers[i].getExtData().id;
if(id == index){
targetMarker = this.markers[i];
break;
}
}
// 重新替換樣式
let markerContent = "" +
"" +
" " +
""+ index +""+
"";
// targetMarker.setIcon("http://a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png");
targetMarker.setContent(markerContent)
let position = targetMarker.getPosition();
this.infoWindow = new AMap.InfoWindow({
position: position,
offset: new AMap.Pixel(0, -35),
content: item.companyName
});
this.infoWindow.open(this.map);
},
// 企業鼠標離開
matchingenterprisemouseleave(item,index) {
this.activemetchmouseenter = "";
let targetMarker = {};
for (let i = 0; i < this.markers.length; i++) {
let id = this.markers[i].getExtData().id;
if(id == index){
targetMarker = this.markers[i];
break;
}
}
let markerContent = "" +
"" +
" " +
""+ index +""+
"";
// targetMarker.setIcon("http://a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png");
targetMarker.setContent(markerContent)
this.map.remove(this.infoWindow);
},
// 企業點擊
matchingenterpriseclick(item,index) {
this.activeState3 = true;
this.activeState1 = false;
this.activeState = false;
this.itemList = item;
// this.map.remove(overlayGroups);
let geocoder = new AMap.Geocoder({
city: "全國", //城市設為北京,默認:“全國”
});
geocoder.getLocation(item.address, (status, result) => {
this.map.setCenter(result.geocodes[0].location); //設置地圖中心點
this.map.setZoom(30); // 縮放級別
})
},
具體代碼
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/7867.html
摘要:獲取富文本內容地圖我是使用高德地圖在全局導入為我申請的也可以自己去申請高德地圖官網案例 前言 今天是個好日子,大家六一快樂;vue-cli生成的template還需要配置axios,vuex,element等插件,該項目中將這些常用插件進行了配置;項目開發中template可以快速復用,也是可以快速上手vue的一個demo; 1.動態效果圖 showImg(https://segmen...
摘要:廣告開始最近做了表格數據轉成圖表展示的一個組件,地址如下整合地圖的時候發現針對地級市的一些文件太多了,全部引入后有將近,所以就用了下高德老爺給的組件和接口,然后弄完在這記錄一下雖然這種例子在社區里有很多這個組件文件放在了中,樣式奇丑,請原諒 /——————廣告開始——————/ 最近做了表格數據轉成圖表展示的一個react組件,地址如下: https://github.com/Lyla...
摘要:不建議底圖選擇中存在兩種不同坐標體系,如下圖坐標存在明顯的偏差,火星坐標在采用坐標系的地圖上位置偏上彩色中國天地圖全球衛星地圖例如我們使用的類進行查找,返回的數據都是國際坐標,因此必須進行偏差糾正。 ArcGIS for javascript開發心得 本次實例中采用ArcGIS for javascript3.24版本,由于版本3與4在API等存在較大區別,就不一一列舉,詳細區別看官方...
摘要:本場是一個基于的個人天氣預報項目,就是興趣所致,做來玩玩。本項目會采用高德地圖,可視化庫和相關的技術來開發本項目。本場你將學到如下內容學會制作自己的天氣預報學會使用部分高德地圖的學會使用的部分相關的一些技術。有興趣的請到查看效果圖如下 本場 Chat 是一個基于 Vue 的個人天氣預報項目,就是興趣所致,做來玩玩。順便擴展一下知識面。 本項目會采用高德地圖 API,Echarts 可視...
閱讀 2727·2021-11-22 15:22
閱讀 1630·2021-11-22 14:56
閱讀 3615·2021-09-22 15:12
閱讀 2402·2021-09-02 15:41
閱讀 2122·2021-08-27 16:26
閱讀 1112·2019-08-30 15:55
閱讀 2137·2019-08-29 17:30
閱讀 665·2019-08-29 16:26