使用GeoWebCache的主要目的是其独立安装版能够发布arcgis的切片。我们知道,使用openlayer是调用geoserver最方便的方法,那么在发布完arcgis的切片后,怎么用arcgis API来调用呢?

1、重写TiledMapServiceLayer的方式。

不断寻找,终于找到了一个arcgis官网的加载geoserver的wmts的例子,而geoserver和GeoWebCache是支持wmts的。所以这个方法是可行的。我将这个例子改了一下,最后调用成功。

例子如下:

 function creatGeoWebCacheObject() {

     //地图

     dojo.declare("GeoWebCacheLayer", esri.layers.TiledMapServiceLayer, {

         constructor: function () {

             this.spatialReference = new esri.SpatialReference({ wkid: 4326 });

             this.initialExtent = this.fullExtent =

                   new esri.geometry.Extent(116, 40, 118, 41, this.spatialReference);

             this.tileInfo = new esri.layers.TileInfo({

                 "rows": 256,

                 "cols": 256,

                 "compressionQuality": 0,

                 "origin": { "x": -180, "y": 90 },

                 "spatialReference": { "wkid": 4326 },

                 "lods": [{ "level": 0, "resolution": 0.703125, "scale": 295497593.05875 },

                              { "level": 1, "resolution": 0.3515625, "scale": 147748796.529375 },

                              { "level": 2, "resolution": 0.17578125, "scale": 73874398.264688 },

                              { "level": 3, "resolution": 0.087890625, "scale": 36937199.132344 },

                              { "level": 4, "resolution": 0.0439453125, "scale": 18468599.566172 },

                              { "level": 5, "resolution": 0.02197265625, "scale": 9234299.783086 },

                              { "level": 6, "resolution": 0.010986328125, "scale": 4617149.891543 },

                              { "level": 7, "resolution": 0.0054931640625, "scale": 2308574.945771 },

                              { "level": 8, "resolution": 0.00274658203125, "scale": 1154287.472886 },

                              { "level": 9, "resolution": 0.001373291015625, "scale": 577143.736443 },

                              { "level": 10, "resolution": 0.0006866455078125, "scale": 288571.86822143558 },

                              { "level": 11, "resolution": 0.00034332275390625, "scale": 144285.93411071779 },

                              { "level": 12, "resolution": 0.000171661376953125, "scale": 72142.967055358895 },

                              { "level": 13, "resolution": 8.58306884765625e-005, "scale": 36071.483527679447 },

                              { "level": 14, "resolution": 4.291534423828125e-005, "scale": 18035.741763839724 },

                              { "level": 15, "resolution": 2.1457672119140625e-005, "scale": 9017.8708819198619 },

                              { "level": 16, "resolution": 1.0728836059570313e-005, "scale": 4508.9354409599309 },

                              { "level": 17, "resolution": 5.3644180297851563e-006, "scale": 2254.4677204799655 }]

             });

             this.loaded = true;

             this.onLoad(this);

         },

         getTileUrl: function (level, row, col) {

             var levelMap = "";

             levelMap = "http://localhost:8090/geoserver/gwc/service/wmts" + "?SERVICE=WMTS&VERSION=1.0.0&REQUEST=GetTile"

                 + "&LAYER=Maps:beijing" + "&STYLE=_null" + "&FORMAT=image/png" + "&TILEMATRIXSET=EPSG:4326"

                 + "&TILEMATRIX=EPSG:4326:" + level + "&TILEROW=" + row + "&TILECOL=" + col;

             return levelMap;

         }

     });

 }

2、主要修改地方

这个函数中主要修改几个地方,这些大部分都可以从wmts文件中获取,在点击getcapabilities document后会获取一个wmts文件,打开该文件,可以在对应的layer中获取对应的参数。

 

fullExtent:就是图层发布的extent,后面跟坐标系。

 

Origin:原点,世界地图用-180,90。一般在geoserver中发布的地图也是这个。但是如果是发布的Arcgis切片,可以在Arcgis server中发布的服务中看到,打开服务地址,json中的地图可以直接来用。另外在切片文件的conf.xml文件中也有相关配置。

Lods:这个是地图level和比例尺、像素之间的关系,与原点之间的配合可以使getTileUrl时获取正确的级别、行列号对应关系。Arcgis可以直接从json中获取,geoserver和GeoWebCache发布的服务可以根据坐标系直接用对应的lods。

EPSG:坐标系统编码。值得注意的是:在发布的Arcgis切片中,你的EPSG后面并不是4326这样正规的编码,一般是4326_beijing这样的编码。具体可参考发布的gwc中的显示。

 

其他配置在wmts或者Arcgis服务配置文件中都可以找到或者获取提示。

这另外我的GeoWebCache一开始没有装好,wmts不支持,后来卸掉tomcat重装了一下,配置好java环境,终于搞定。

主要参考文章:

https://developers.arcgis.com/javascript/jssamples/layers_wmts.html

Arcgis js API使用wmts方式加载GeoWebCache中的切片地图(转载)的更多相关文章

  1. arcgis api for JavaScript _加载三维图层(scene layer)

    arcgis api for JavaScript _加载三维图层(scene layer) arcgis api for JavaScript  4.x 版本增加对三维的支持. 关于三维图层(sce ...

  2. js异步执行 按需加载 三种方式

    js异步执行 按需加载 三种方式 第一种:函数引用 将所需加载方法放在匿名函数中传入 //第一种 函数引用 function loadScript(url,callback){ //创建一个js va ...

  3. javascript Date 日期格式化 formatDate, require.js 模块 支持全局js引入 / amd方式加载

    * 引入AMD加载方式: require.js CDN https://cdn.bootcss.com/require.js/2.3.5/require.js *  创建模块文件./js/util/d ...

  4. 《ArcGIS Runtime SDK for Android开发笔记》——(13)、图层扩展方式加载Google地图

    1.前言 http://mt2.google.cn/vt/lyrs=m@225000000&hl=zh-CN&gl=cn&x=420&y=193&z=9& ...

  5. geoserver图层属性查询及查询结果转换为arcgis js api能使用的格式

    一个项目使用了ArcGIS JS API开发GIS展示层,但GIS服务使用了Geoserver,这时加载Geoserver数据和查询数据就和之前完全不一样了,以下介绍下我使用ArcGIS JS API ...

  6. ArcGIS JS API使用PrintTask打印地图问题解决汇总

    环境:来源于工作过程,使用的API是  arcgis js 3.*  3系API,4.*暂时没测试: 1.数据与打印服务跨域情况下,不能打印问题. 一般情况下,我们发布的数据服务和打印服务是在一台服务 ...

  7. MVC Ajax Helper或jQuery异步方式加载部分视图

    Model: namespace MvcApplication1.Models { public class Team { public string Preletter { get; set; } ...

  8. 基于ArcGIS JS API的在线专题地图实现

    0 引言     专题地图是突出而深入的表示一种或几种要素或现象,即按照地图主题的要求,集中表示与主题有关内容的地图.专题地图的专题要素多种多样,分类方法也多种多样,根据专题地图表现数据的特点可分为定 ...

  9. 能否使用require('.json')的方式加载大量JSON文件?

    Node.js中推崇非阻塞I/O,但是require一个模块时却是同步调用的,这会带来性能上的开销,但并不是每次require都很耗时,因为在require成功之后会缓存起来,在此加载时直接从缓存读取 ...

随机推荐

  1. 剑指offer之有序二维数组查找

    大多数人注意到元素是行列有序的,会马上想到对每行(或列)进行二分查找,每行(或列)需要logN时间,N行(或列)共需要NlogN时间,很容易写出如下代码 1 2 3 4 5 6 7 8 9 10 11 ...

  2. 【转载】linux环境下为firefox/chrome浏览器安装flash player

    本文转载自 http://blog.sina.com.cn/s/blog_6ad624380102v1xf.html     firefox安装flash player的方法: 先到adobe网站上下 ...

  3. IE7&IE8不支持rgba的方法

    使用滤镜功能 filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#BF000000,endColorstr=#BF0000 ...

  4. vi命令

    VI命令可以说是Unix/Linux世界里最常用的编辑文件的命令了,但是因为它的命令集众多,很多人都不习惯使用它,其实您只需要掌握基本命令,然后加以灵活运用,就会发现它的优势,并会逐渐喜欢使用这种方法 ...

  5. java几种常用设计模式简单示例

    1.单例设计模式 所谓单例设计模式简单说就是无论程序如何运行,采用单例设计模式的类(Singleton类)永远只会有一个实例化对象产生.具体实现步骤如下: (1) 将采用单例设计模式的类的构造方法私有 ...

  6. 12C 连接方式和 Oracle Easy Connect Naming method

    1.12C 连接方式 PDB is not an instance, so using SID in the connection string will not work. When the dat ...

  7. ASP.NET MVC---自定义HtmlHelper方法

    HtmlHelper方法是ASP.NET MVC中非常强大的特性,有了这个特性,我们就能更加随心所欲的定制自己的页面. 自定义自己的HtmlHelper方法通常有三种, 像是: 一.Razor语法 采 ...

  8. web前端性能优化指南

    web前端性能优化指南 web前端性能优化指南 概述 1. PC优化手段在Mobile侧同样适用2. 在Mobile侧我们提出三秒种渲染完成首屏指标3. 基于第二点,首屏加载3秒完成或使用Loadin ...

  9. PAT (Advanced Level) 1018. Public Bike Management (30)

    先找出可能在最短路上的边,图变成了一个DAG,然后在新图上DFS求答案就可以了. #include<iostream> #include<cstring> #include&l ...

  10. Java Restful框架:Jersey入门示例(官方例子)

    本文主要介绍了Java Restful框架Jersey入门例子(来源于官方网站https://jersey.java.net/),废话不多说进入正题. 在Jersey官方示例中(https://jer ...