ArcGIS API For Javascript之地图输出打印

已被阅读 1680 次 | 文章分类:ArcGIS API For Javascript | 2018-05-20 16:19

ESRI提供了PringTools地理处理服务,可以将web地图的内容导出为pdf、jpeg、png或者其他格式,可以通过ArcGIS API调用该服务实现具体的打印输出功能

一:实现过程

1.启用PringTools地理处理服务,获取服务地址

2.引入打印地图的相关类库

二:登陆ArcGIS server Manager,启用地图打印服务

小白GIS

小白GIS

小白GIS

小白GIS

三:代码

                                        
<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no" />
  <title>Layer_MapImageLayer</title>
  <link rel="stylesheet" href="http://localhost:8008/3.23/esri/css/esri.css">
  <script src="http://localhost:8008/3.23/init.js"></script>   
  <script type="text/javascript">
    var map,sr,bool = false,initextent,url;
    require([
      "esri/map",
      "esri/layers/MapImage",
      "esri/layers/MapImageLayer",
      "esri/layers/ArcGISDynamicMapServiceLayer",
      "esri/geometry/Extent",
      "esri/SpatialReference",
      "esri/tasks/PrintTask",
      "esri/tasks/PrintTemplate",
      "esri/tasks/PrintParameters",
      "dojo/domReady!"],
        function (
             Map,
             MapImage,
             MapImageLayer,
             ArcGISDynamicMapServiceLayer,
             Extent,
             SpatialReference,
             PrintTask,
             PrintTemplate,
             PrintParameters) {
             sr = new SpatialReference(102100)
             map = new Map("map", {
             pan>basemap:"satellite"
             });
             var btn=document.getElementById("Btn");
             //给地图打印按钮绑定事件
             btn.onclick=function(){		
             btn.setAttribute("disabled","true");
             btn.value="正在输出...";
             	//创建地图打印对象
             var printMap = new PrintTask("http://localhost:6080/arcgis/rest/services/Utilities/PrintingTools/GPServer/Export%20Web%20Map%20Task");
             //创建地图打印模版
             var template = new PrintTemplate();
              //创建地图的打印参数,参数里面包括:模版和地图
              var params = new PrintParameters(); 
              //输出图片的空间参考
              printMap.outSpatialReference = map.SpatialReference 
              //打印图片的各种参数
              template.exportOptions = { 
                  width: 850, 
                  height: 650, 
                  dpi: 96 
              };
              //打印输出的格式
              template.format = "PDF"; 
              //输出地图的布局
              template.layout = "MAP_ONLY"; 
              PrintTemplate 
              //设置参数地图
              params.map = map; 
              //设置参数模版
              params.template = template; 
              //运行结果
              printMap.execute(params, function(result){
              if (result != null) { 
               //网页打开生成的地图
             	(function(){
             		btn.disabled=false;
             		btn.value="地图打印";
             	})()
                window.open(result.url); 
               }
               })}
          });
  </script>
  
  
</head>
<body>
  <div id="map"></div>
  <div>
   <input id="Btn" type="button" value="地图打印" />
  </div>
</body>
</html>
                                        
                                    

四:运行效果

小白GIS

小白GIS

QQ:3410192267 | 技术支持 微信:popstarqqsmall

Copyright ©2017 xiaobaigis.com . 版权所有 鲁ICP备17027716号