arcgisjs之天地图加载封装

arcgisjs之天地图加载封装

layer.js

// // 天地图影像图层
export const tdtTdtlayer = async () => {
  let BaseTileLayer = await arcgisPackage('BaseTileLayer');
  let Request = await arcgisPackage('Request');
  let WMTSLayer = await arcgisPackage('WMTSLayer');
  let WebTileLayer = await arcgisPackage('WebTileLayer');
  console.log(mapConfig.list.tk);
  let TDT = await BaseTileLayer.createSubclass({
    properties: {
      urlTemplate: null,
    },
    spatialReference: mapConfig.centerPoint,
    title: '天地图影像地图',
    getTileUrl: function (level, row, col) {
      // let url = 'http://t' + col % 8 + '.tianditu.gov.cn/DataServer?T=img_w&tk=ec7fe0feda91baac20f7835cfdce24c5&x=' + col + '&y=' + row + '&l=' + level
      let url = `http://t${col % 8}.tianditu.gov.cn/DataServer?T=img_w&tk=${
        mapConfig.list.tk
      }&x=${col}&y=${row}&l=${level}`;
      return url;
    },
    fetchTile: function (level, row, col) {
      let url = this.getTileUrl(level, row, col);
      return Request(url, {
        responseType: 'image',
      }).then((response) => {
        let image = response.data;
        let width = this.tileInfo.size[0];
        let height = this.tileInfo.size[0];

        let canvas = document.createElement('canvas');
        let context = canvas.getContext('2d');
        canvas.width = width;
        canvas.height = height;

        context.drawImage(image, 0, 0, width, height);

        return canvas;
      });
    },
  });
  let layer = await new TDT();
  return layer;
};
// // 天地图影像标注图层cia_c
export const tdtTdtyNoteslayer = async () => {
  let BaseTileLayer = await arcgisPackage('BaseTileLayer');
  let Request = await arcgisPackage('Request');
  let TDT = await BaseTileLayer.createSubclass({
    properties: {
      urlTemplate: null,
    },
    getTileUrl: function (level, row, col) {
      let url = `http://t${col % 8}.tianditu.gov.cn/DataServer?T=cia_w&tk=${
        mapConfig.list.tk
      }&x=${col}&y=${row}&l=${level}`;
      return url;
    },
    fetchTile: function (level, row, col) {
      let url = this.getTileUrl(level, row, col);
      return Request(url, {
        responseType: 'image',
      }).then((response) => {
        let image = response.data;
        let width = this.tileInfo.size[0];
        let height = this.tileInfo.size[0];

        let canvas = document.createElement('canvas');
        let context = canvas.getContext('2d');
        canvas.width = width;
        canvas.height = height;
        context.drawImage(image, 0, 0, width, height);
        return canvas;
      });
    },
  });
  let layer = new TDT();
  return layer;
};
// // 天地图矢量图层
export const tdtTdtclayer = async () => {
  let BaseTileLayer = await arcgisPackage('BaseTileLayer');
  let Request = await arcgisPackage('Request');
  let TDT = await BaseTileLayer.createSubclass({
    properties: {
      urlTemplate: null,
    },
    getTileUrl: function (level, row, col) {
      let url =
        'http://t' +
        (col % 8) +
        `.tianditu.gov.cn/DataServer?T=vec_w&tk=${mapConfig.list.tk}&x=` +
        col +
        '&y=' +
        row +
        '&l=' +
        level;
      return url;
    },
    fetchTile: function (level, row, col) {
      let url = this.getTileUrl(level, row, col);
      return Request(url, {
        responseType: 'image',
      }).then((response) => {
        let image = response.data;
        let width = this.tileInfo.size[0];
        let height = this.tileInfo.size[0];

        let canvas = document.createElement('canvas');
        let context = canvas.getContext('2d');
        canvas.width = width;
        canvas.height = height;

        context.drawImage(image, 0, 0, width, height);

        return canvas;
      });
    },
  });
  let layer = await new TDT();
  return layer;
};
// // 天地图矢量标注图层
export const tdtTdtcNoteslayer = async () => {
  let BaseTileLayer = await arcgisPackage('BaseTileLayer');
  let Request = await arcgisPackage('Request');
  let TDT = await BaseTileLayer.createSubclass({
    properties: {
      urlTemplate: null,
    },
    getTileUrl: function (level, row, col) {
      let url =
        'http://t' +
        (col % 8) +
        `.tianditu.gov.cn/DataServer?T=cva_w&tk=${mapConfig.list.tk}&x=` +
        col +
        '&y=' +
        row +
        '&l=' +
        level;
      return url;
    },
    fetchTile: function (level, row, col) {
      let url = this.getTileUrl(level, row, col);
      return Request(url, {
        responseType: 'image',
      }).then((response) => {
        let image = response.data;
        let width = this.tileInfo.size[0];
        let height = this.tileInfo.size[0];

        let canvas = document.createElement('canvas');
        let context = canvas.getContext('2d');
        canvas.width = width;
        canvas.height = height;
        context.drawImage(image, 0, 0, width, height);
        return canvas;
      });
    },
  });
  let layer = new TDT();
  layer.id = 'ctdtNote';
  return layer;
};

// 天地图影像地图
export const tdtlayer = async () => {
  return tdtTdtlayer().then((res) => {
    return res;
  });
};
// 天地图影像标注图层
export const tdtyNoteslayer = async () => {
  return tdtTdtyNoteslayer().then((res) => {
    return res;
  });
};
// 天地图矢量图层
export const tdtclayer = async () => {
  return tdtTdtclayer().then((res) => {
    return res;
  });
};
// 天地图矢量标注图层
export const tdtcNoteslayer = async () => {
  return tdtTdtcNoteslayer().then((res) => {
    return res;
  });
};
引用
import { tdtlayer } from '/@/utils/arcgis/layers.js';
let tdtlayer = await tdtlayer().then((res) => {
          return res;
        });
map.add(tdtlayer)

  


 

钻研不易,转载请注明处处......

 

posted @ 2023-09-06 13:51  莫小龙  阅读(95)  评论(0编辑  收藏  举报