|
@@ -261,7 +261,7 @@ export function addGenerateWhere(item) {
|
|
|
return where;
|
|
|
}
|
|
|
|
|
|
-//人口公共设施企业点位图
|
|
|
+//撒点通用方法
|
|
|
export function addMultiImagePoints(layerID, params, imgurl, size = '80px') {
|
|
|
if (params?.data) {
|
|
|
params.data = params.data.map((item) => {
|
|
@@ -292,14 +292,11 @@ export function addSingleImagePoint(layerID, params, size = '50px') {
|
|
|
addMyGraph({
|
|
|
is_clear: false,
|
|
|
is_goto: false,
|
|
|
- type: 'points',
|
|
|
- data: [
|
|
|
- {
|
|
|
- ...params,
|
|
|
- mapz: 3,
|
|
|
- },
|
|
|
- ],
|
|
|
- attributes: null,
|
|
|
+ type: 'point',
|
|
|
+ data: [params.mapx, params.mapy, 3],
|
|
|
+ attributes: {
|
|
|
+ ...params
|
|
|
+ },
|
|
|
symbol: {
|
|
|
type: 'picture-marker',
|
|
|
url: params.imgurl || '',
|
|
@@ -603,6 +600,7 @@ export function viewComplete() {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+//定位区后,所属区内各分类撒点
|
|
|
export function handleRiskPoints(bol,district) {
|
|
|
if(bol){
|
|
|
removeMapLayers("jkzx-points")
|
|
@@ -691,6 +689,7 @@ export function handleRiskPoints(bol,district) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+//全国-病例撒点
|
|
|
export function handleChinaCasePoint(bol) {
|
|
|
if(bol){
|
|
|
removeMapLayers("china-case-point")
|
|
@@ -713,3 +712,318 @@ export function handleChinaCasePoint(bol) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+//处置进展-病例撒点
|
|
|
+export function handleCasePoint(bol) {
|
|
|
+ const eventInteractionStore = useEventInteractionStore();
|
|
|
+ eventInteractionStore.isCaseShow = bol
|
|
|
+ if(bol){
|
|
|
+ removeMapLayers("case-point")
|
|
|
+ addSingleImagePoint(
|
|
|
+ 'case-point',
|
|
|
+ {
|
|
|
+ attributes: {
|
|
|
+ ...analogData["病例_发病就诊过程"].features[0].properties,
|
|
|
+ },
|
|
|
+ mapx: -11391.153275823075,
|
|
|
+ mapy: -8666.594500441925,
|
|
|
+ is_goto: true,
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ imgurl: "images/sadian/病例.png"
|
|
|
+ },
|
|
|
+ "120px"
|
|
|
+ );
|
|
|
+ }else {
|
|
|
+ removeMapLayers("case-point")
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+//处置进展-病例相关撒点
|
|
|
+export function handleCaseRelPoints(bol) {
|
|
|
+ if(bol){
|
|
|
+ removeMapLayers("case-rel-point")
|
|
|
+
|
|
|
+ //处置单位
|
|
|
+ addSingleImagePoint(
|
|
|
+ 'case-rel-point',
|
|
|
+ {
|
|
|
+ attributes: {
|
|
|
+ "单位" : "上海市疾病预防控制中心",
|
|
|
+ "地址" : "闵行区申虹路1399号",
|
|
|
+ "bdlng" : 121.320368,
|
|
|
+ "bdlat" : 31.224148,
|
|
|
+ "shanghai_x" : -15027.741936,
|
|
|
+ "shanghai_y" : -1729.709243
|
|
|
+ },
|
|
|
+ mapx: -15027.741936,
|
|
|
+ mapy: -1729.709243,
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ imgurl: "images/sadian/处置单位.png"
|
|
|
+ },
|
|
|
+ "80px"
|
|
|
+ );
|
|
|
+ //配合单位
|
|
|
+ addSingleImagePoint(
|
|
|
+ 'case-rel-point',
|
|
|
+ {
|
|
|
+ attributes: {
|
|
|
+ "单位" : "上海市疾病预防控制中心",
|
|
|
+ "地址" : "中山西路1380号",
|
|
|
+ "bdlng" : 121.424228,
|
|
|
+ "bdlat" : 31.199643,
|
|
|
+ "shanghai_x" : -5148.250453,
|
|
|
+ "shanghai_y" : -4444.028907
|
|
|
+ },
|
|
|
+ mapx: -5148.250453,
|
|
|
+ mapy: -4444.028907,
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ imgurl: "images/sadian/配合单位.png"
|
|
|
+ },
|
|
|
+ "80px"
|
|
|
+ );
|
|
|
+ //户籍地
|
|
|
+ addSingleImagePoint(
|
|
|
+ 'case-rel-point',
|
|
|
+ {
|
|
|
+ mapx: -10197.242169896594,
|
|
|
+ mapy: -8764.560469809805,
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ imgurl: "images/sadian/病例户籍地.png"
|
|
|
+ },
|
|
|
+ "80px"
|
|
|
+ );
|
|
|
+ //居住地
|
|
|
+ addSingleImagePoint(
|
|
|
+ 'case-rel-point',
|
|
|
+ {
|
|
|
+ mapx: -10197.242169896594,
|
|
|
+ mapy: -8764.560469809805,
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ imgurl: "images/sadian/病例居住地.png"
|
|
|
+ },
|
|
|
+ "80px"
|
|
|
+ );
|
|
|
+ }else {
|
|
|
+ removeMapLayers("case-rel-point")
|
|
|
+ }
|
|
|
+ handleYjryPoints(bol)
|
|
|
+ handleYjclPoints(bol)
|
|
|
+}
|
|
|
+
|
|
|
+//应急人员
|
|
|
+export function handleYjryPoints(bol){
|
|
|
+ if(bol){
|
|
|
+ removeMapLayers("yjry-points")
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'yjry-points',
|
|
|
+ {
|
|
|
+ data: analogData["人员实时gps位置"]
|
|
|
+ .filter((el) => el.x !== null && el.y !== null).slice(0, 20)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item,
|
|
|
+ },
|
|
|
+ mapx: item.x,
|
|
|
+ mapy: item.y,
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/应急人员-备班.png",
|
|
|
+ );
|
|
|
+ }else {
|
|
|
+ removeMapLayers("yjry-points")
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+//应急车辆
|
|
|
+export function handleYjclPoints(bol){
|
|
|
+ if(bol){
|
|
|
+ removeMapLayers("yjcl-points")
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'yjcl-points',
|
|
|
+ {
|
|
|
+ data: analogData["人员实时gps位置"]
|
|
|
+ .filter((el) => el.x !== null && el.y !== null).slice(-20)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item,
|
|
|
+ },
|
|
|
+ mapx: item.x,
|
|
|
+ mapy: item.y,
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/应急车辆-值班.png",
|
|
|
+ );
|
|
|
+ }else {
|
|
|
+ removeMapLayers("yjcl-points")
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+//交通流向
|
|
|
+export function handleJtlxPoints(bol){
|
|
|
+ if(bol){
|
|
|
+ removeMapLayers("jtlx-points")
|
|
|
+
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["环线"].features
|
|
|
+ .filter((el) => el.geometry !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ rings: item.geometry.coordinates,
|
|
|
+
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ type: "polygons",
|
|
|
+ symbol: {
|
|
|
+ type: 'simple-fill',
|
|
|
+ color: [239, 132, 9, 0],
|
|
|
+ outline: {
|
|
|
+ color: [239, 132, 9, 1],
|
|
|
+ width: 1,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ );
|
|
|
+ // return
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["疾控中心"].features
|
|
|
+ .filter((el) => el.properties.shanghai_x !== null && el.properties.shanghai_y !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.properties.shanghai_x,
|
|
|
+ mapy: item.properties.shanghai_y,
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/red.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["渡口"].features
|
|
|
+ .filter((el) => el.properties.POINT_X !== null && el.properties.POINT_Y !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.properties.POINT_X,
|
|
|
+ mapy: item.properties.POINT_Y,
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/码头.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["海关"].features
|
|
|
+ .filter((el) => el.properties.shanghai_x !== null && el.properties.shanghai_y !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.properties.shanghai_x,
|
|
|
+ mapy: item.properties.shanghai_y,
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/海关.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["火车站"].features
|
|
|
+ .filter((el) => el.geometry !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.geometry.coordinates[0],
|
|
|
+ mapy: item.geometry.coordinates[1],
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/海关.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["机场"].features
|
|
|
+ .filter((el) => el.geometry !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.geometry.coordinates[0],
|
|
|
+ mapy: item.geometry.coordinates[1],
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/海关.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["汽车站"].features
|
|
|
+ .filter((el) => el.geometry !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.geometry.coordinates[0],
|
|
|
+ mapy: item.geometry.coordinates[1],
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/物流中心.png",
|
|
|
+ );
|
|
|
+ addMultiImagePoints(
|
|
|
+ 'jtlx-points',
|
|
|
+ {
|
|
|
+ data: analogData["医疗检测机构"].features
|
|
|
+ .filter((el) => el.geometry !== null)
|
|
|
+ .map((item) => {
|
|
|
+ return {
|
|
|
+ attributes: {
|
|
|
+ ...item.properties,
|
|
|
+ },
|
|
|
+ mapx: item.geometry.coordinates[0],
|
|
|
+ mapy: item.geometry.coordinates[1],
|
|
|
+ };
|
|
|
+ }),
|
|
|
+ },
|
|
|
+ // new URL(`@/assets/img/pinpoint(1).png`, import.meta.url).href,
|
|
|
+ "images/sadian/实验室.png",
|
|
|
+ );
|
|
|
+ }else {
|
|
|
+ removeMapLayers("jtlx-points")
|
|
|
+ }
|
|
|
+}
|
|
|
+
|