SuperMap iClient for Leaflet+vue实现Web地图打印功能

 超图官网只有Openlayers示例里面有Web打印功能的代码,Leaflet其实也有Web打印的接口,可以在API文档中查看,仿照Openlayers示例写了Leaflet Web打印功能,示例代码如下:

标题

<template>
  <div class="print">
    <div class="printform">
      <el-form ref="form" :model="form" label-width="85px" size="small">
        <el-collapse>
          <el-collapse-item title="基础信息" name="1">
            <div class="container">
              <el-form-item label="布局模板" class="form-item">
                <el-select v-model="form.templateName" placeholder="模板">
                  <el-option
                    v-for="templateName in templateNames"
                    :label="templateName"
                    :value="templateName"
                    :key="templateName"
                  ></el-option>
                </el-select>
              </el-form-item>
              <el-form-item label="标题" class="form-item">
                <el-input v-model="form.tittle" size="small"></el-input>
              </el-form-item>
              <el-form-item label="副标题" class="form-item">
                <el-input v-model="form.subTittle" size="small"></el-input>
              </el-form-item>
              <el-form-item label="版权信息" class="form-item">
                <el-input v-model="form.copyright" size="small"></el-input>
              </el-form-item>
              <el-form-item label="作者" class="form-item">
                <el-input v-model="form.author" size="small"></el-input>
              </el-form-item>
            </div>
          </el-collapse-item>
          <el-collapse-item title="附图" name="2">
            <div class="container">
              <el-form-item label="比例尺" class="form-item">
                <el-input v-model.number="form.scale"></el-input>
              </el-form-item>
              <el-form-item label="中心点" class="form-item">
                <el-input v-model="form.center"></el-input>
              </el-form-item>
            </div>
          </el-collapse-item>
          <el-collapse-item title="比例尺" name="3">
            <div>
              <el-form-item label="比例尺文本" class="form-item">
                <el-input v-model="form.scaleText"></el-input>
              </el-form-item>
              <el-form-item label="样式" class="form-item">
                <el-input v-model="form.type"></el-input>
              </el-form-item>
              <el-form-item label="段数" class="form-item">
                <el-input v-model="form.intervals"></el-input>
              </el-form-item>
              <el-form-item label="单位" class="form-item">
                <el-input v-model="form.unit"></el-input>
              </el-form-item>
            </div>
          </el-collapse-item>
          <el-collapse-item title="导出选项" name="4">
            <div>
              <el-form-item label="格式" class="form-item">
                <el-input v-model="form.format"></el-input>
              </el-form-item>
              <el-form-item label="DPI" class="form-item">
                <el-input v-model.number="form.dpi"></el-input>
              </el-form-item>
              <el-form-item label="比例尺" class="form-item">
                <el-input v-model.number="form.exportScale"></el-input>
              </el-form-item>
            </div>
          </el-collapse-item>
        </el-collapse>
      </el-form>
      <el-button @click="handleprint">打印</el-button>
    </div>
    <div id="map"></div>
  </div>
</template>
  
  <script>
import L from "leaflet";
import {
  TiledMapLayer,
  WebPrintingJobService,
  WebPrintingJobParameters,
  WebPrintingJobContent,
  WebPrintingJobLayoutOptions,
  WebPrintingJobExportOptions,
  WebPrintingJobLegendOptions,
} from "@supermap/iclient-leaflet";
export default {
  name: "MapsysmanagePrint",

  data() {
    return {
      map: null,
      templateNames: [],
      form: {
        templateName: "",
        tittle: "",
        subTittle: "",
        copyright: "",
        author: "",
        scale: "",
        center: "",
        scaleText: "",
        style: "",
        intervals: "",
        unit: "",
        format: "pdf",
        dpi: "96",
        exportScale: "",
      },
      webPrintingJobService: "",
    };
  },

  mounted() {
    this.initmap();
  },

  methods: {
    toggleCollapse() {
      this.expanded = !this.expanded;
    },
    initmap() {
      var url =
        "http://localhost:8090/iserver/services/map-world/rest/maps/World";

      // 初始化地图信息
      this.map = L.map("map", {
        crs: L.CRS.EPSG4326,
        center: new L.LatLng(30.745922638363268, 104.00415658374735),
        maxZoom: 18,
        zoom: 5,
      });
      var newlayer = new TiledMapLayer(url).addTo(this.map);

      //中心点
      var center = this.map.getCenter();
      this.form.center = center.lng + "," + center.lat;
      //输出模板类型
      this.webPrintingJobService = new WebPrintingJobService(
        "http://localhost:8090/iserver/services/webprinting/rest/webprinting/v1",
        {
          withCredentials: window.isLocal,
        }
      );
      this.webPrintingJobService.getLayoutTemplates((e) => {
        this.templateNames = e.result.map((item) => item.templateName);
      });
      //比例尺
      var scale = newlayer.getScale();
      this.form.exportScale = scale;
      // //附图比例尺
      this.form.scale = scale * 2;
    },

    handleprint() {
      var params = new WebPrintingJobParameters({
        content: new WebPrintingJobContent({
          type: "WEBMAP",
          value: {
            center: {
              x: this.form.center.split(",")[0],
              y: this.form.center.split(",")[1],
            },
            level: 4,
            projection: "EPSG:4490",
            extent: {
              leftBottom: { x: -180, y: 90 },
              rightTop: { x: 180, y: 90 },
            },
            maxScale: "1:144447.927",
            baseLayer: {
              layerType: "TILE",

              name: "World",

              url: "http://localhost:8090/iserver/services/map-world/rest/maps/World",
            },
            minScale: "1:591658710.909",

            title: "china_point",

            version: "2.0.0",
          },
        }),
        layoutOptions: new WebPrintingJobLayoutOptions({
          templateName: this.form.templateName,
          title: this.form.tittle,
          subTitle: this.form.subTittle,
          author: this.form.author,
          copyright: this.form.copyright,
          scaleBarOptions: {
            scaleText: "比例尺",
          },
          littleMapOptions: {
            center: {
              x: 0,
              y: 0,
            },
            scale: 0.000000005912,
            layers: [
              {
                layerType: "TILE",
                name: "World",
                url: "http://localhost:8090/iserver/services/map-world/rest/maps/World",
              },
            ],
          },
          legendOptions: new WebPrintingJobLegendOptions({
            picAsBase64:
              "",
          }),
        }),
        exportOptions: new WebPrintingJobExportOptions({
          format: this.form.format,
          dpi: this.form.dpi,
          scale: 0.000000142857,
        }),
      });
      this.filterEmptyData(params);
      this.webPrintingJobService.createWebPrintingJob(params, (e) => {
        if (e.result && e.result[0] && e.result[0].path) {
          this.webPrintingJobService.getPrintingJob(
            e.result[0].resourceConfigID,
            (res) => {
              if (res.result && res.result.status === "FINISHED") {
                let link = document.createElement("a");
                link.href = res.result.result.downloadUrl;
                link.download = "supermap-webprinting-report.pdf";
                link.target = "_blank";
                link.click();
                // 释放内存
                window.URL.revokeObjectURL(link.href);
              }
            }
          );
        }
      });
    },
    filterEmptyData(params) {
      for (let key in params) {
        if (params[key] === undefined) {
          delete params[key];
        } else if (typeof params[key] === "object") {
          this.filterEmptyData(params[key]);
          if (JSON.stringify(params[key]) === "{}") {
            delete params[key];
          }
        }
      }
    },
  },
};
</script>
  
  <style scoped>
.print {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: row;
}
.printform {
  width: 320px; /* 调整宽度适应需求 */

  /* height: 100%; */
  background-color: #f0f0f0; /* 调整背景颜色适应需求 */
  padding: 2px; /* 调整内边距适应需求 */
  flex-grow: 1;
}
#map {
  width: 100%;
  height: 100%;
}
.form-item {
  margin-bottom: 5px;
}
.container {
  margin-top: 5px;
}
</style>
  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值