arcgis三維球中載入2000坐標系出現錯誤(The tiling scheme of this layer is not supported by SceneView)

来源:https://www.cnblogs.com/cehui0303/archive/2019/08/23/11401202.html
-Advertisement-
Play Games

ArcGIS Javascript Api三維球中載入2000坐標系底圖,切片規則不一致的問題,The tiling scheme of this layer is not supported by SceneView。 ...


      目前我們國家測繪地理信息的坐標體系基準是國家2000坐標系CGCS2000.各類地圖組件如OpenLayers、Mapbox、Cesuim和ArcGIS Javascrip等都主要是支持WGS84(wkid=4326)和墨卡托投影坐標系(wkid=102100)兩種,對CGCS2000坐標系基本上都不支持。特別是在三維地球展示中基本上都是以WGS84球面坐標系載入,因為三維球是個球,當然是要載入球面坐標系了。(但我知道以前科瀾三維是平面的!)所以三維地球都載入不了國內的2000坐標系,要載入也是通過擴展和定製WebTileLayer類進行特殊處理。

    ArcGIS Javascript Api 4.*系列一直在朝著二三維一體化的方向發展,其開發商ESRI一直專攻GIS領域,而且是全球頭部GIS軟體平臺,特別是隨著ArcGIS 10.1後,其軟體產品迭代更新的速度極快。三維產品也是其重點發展對象之一。在今年中旬發佈的ArcGIS Javascript Api 4.12版本,不僅性能提升,增加了一些牛逼的功能,更重要的是支持CGCS2000坐標系!!!支持CGCS2000坐標系!!!支持CGCS2000坐標系!!!重要的事情說三遍!

     這正是一個喜大普奔的事情,可能是因為ESRI的三維軟體開發團隊在北京的緣故吧,愛國註意情懷和中國市場總得發揮點作用。但我看到這個信息後,一直想試試,因為我對他支持2000坐標系還是存有疑惑,載入應該沒那麼容易!咱天朝的標準規範永遠是跟著參考國際標準,但必須在上面進行小幅修改,開發人員蛋疼的事情太多了!

 1         
 2         var arcgisUrl = 'http://myserver.net/hserver/rest/services/imageserver2000/MapServer';
 3 
 4         Layer.fromArcGISServerUrl({
 5           url: arcgisUrl
 6          
 7         }).then(function(layer){
 8 
 9             var customBasemap = new Basemap({
10                 baseLayers: [layer],
11                 title: "ArcGIS REST Service",
12                 id: "切片"
13             });
14             
15             var map = new Map({
16                 //basemap: "topo-vector"
17                 basemap:customBasemap
18               });
19 
20             var view = new SceneView({
21                 container: "viewDiv",
22                 map: map,
23                 spatialReference: {
24                     "wkid": 4490,
25                     "latestWkid": 4490
26                 }
27             });
28         });

 

上述代碼就是我想用我自己的影像地圖作為三維球的底圖,滿懷期待,但最後還是出現我預料中的事情,沒有那麼簡單!

球出來了,提示“The tiling scheme of this layer is not supported by SceneView”,當時沒註意看這個信息,以為是坐標系統還是繼續不支持,但官方明明說了支持2000坐標系啊,不能夠啊!

 

繼續發揮Chrome強大的調試功能,在SceneViewer.js文件中調試出三塊關鍵代碼行數,checkIfTileInfoSupportedForViewSR,makeGCSWithTileSize,ompatibleWith。經過調試和研究發現,2000坐標系確實是支持的,但是切片規則(Tiling Scheme)必須跟esri規定的要一樣。

 

天地圖切片規則

級別

比例尺

解析度(/像素)

7

4617149.9776692898246525792559     

0.010986328125

8

2308574.9888346449123262896279     

0.0054931640625

9

1154287.494417322456163144814

0.00274658203125

10

577143.74720866122808157240698

0.001373291015625

11

288571.87360433061404078620349

0.0006866455078125

12

144285.93680216530702039310175

0.00034332275390625

13

72142.968401082653510196550873

0.000171661376953125

14

36071.484200541326755098275436

0.0000858306884765625

15

18035.742100270663377549137718

0.00004291534423828125

16

9017.871050135331688774568859

0.000021457672119140625

17

4508.9355250676658443872844296

0.0000107288360595703125

18

2254.4677625338329221936422148

0.00000536441802978515625

19

1127.2338812669164610968211074

0.000002682209014892578125

20

563.61694063345823054841055369

0.0000013411045074462890625

esri腳本代碼里第一級解析度固定了 res[0] = 0.703125,下麵以及都是一半的比例尺進行處理。下麵是兩個切片規則的比較。

                  

        arcgis javascript api 規定的切片規則                                                                                               天地圖服務切片規則

 

可以看出我的服務的切片規則和arcgis的恰好錯開一個層級,我懷疑是因為我們是從0級開始算,arcgis是從第1級開始算導致的吧。但仔細看看其實兩個瓦片規則的解析度還是有細微的差別的。

 

 

 

q.prototype.compatibleWith = function(a) {
    if (! (a instanceof q)) {
        if (q._checkUnsupported(a)) return ! 1;
        a = new q(a)
    }
    if (!a.spatialReference.equals(this.spatialReference) || a.pixelSize[0] !== this.pixelSize[0] || a.pixelSize[1] !== this.pixelSize[1]) return ! 1;
    var c = Math.min(this.levels.length, a.levels.length) - 1,
    f = this.levels[c].resolution,
    b = .5 * f;
    if (!e.floatEqualAbsolute(a.origin[0], this.origin[0], b) || !e.floatEqualAbsolute(a.origin[1], this.origin[1], b)) return ! 1;
    b = .5 * f / Math.pow(2, c) / Math.max(this.pixelSize[0], this.pixelSize[1]) * 12;
    return e.floatEqualAbsolute(f, a.levels[c].resolution, b)
}

  

問題如何處理呢?我的服務是用的已有的緩存切片進行發佈的啊!下一步就是操作ArcGIS Server 的信息了,強制去掉一個層級,讓其從第1級開始算瓦片吧,這樣我猜應該能載入了吧。

請聽下會demo彙報......


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 個人博客主題美化 選擇主題 Hexo預設的主題是landscape,推薦以下主題: 1. "snippet" 2. "Hiero" 3. "JSimple" 4. "BlueLake" 詳見:https://github.com/search?q=hexo theme 應用主題 1. 下載主題 2. ...
  • 一.準備環境 1.安裝node.js 簡介 因為hexo是基於node.js的,所以node.js是必須要裝的,安裝也特別簡單,去 "官網" 下載適合自己windows的版本。安裝過程一直下一步就行了,什麼也不用選,在網上查資料的時候,看到有說要在Custom Setup這一步記得選 Add to ...
  • nodes.js詳細安裝 "Node.js" 本章節我們將向大家介紹在window和Linux上安裝Node.js的方法。 本安裝教程以Node.js v4.4.3 LTS(長期支持版本)版本為例。 Node.js安裝包及源碼下載地址為:https://nodejs.org/en/download/ ...
  • H5對自定義屬性的規定和添加獲取自定義屬性的方法 元素屬性那麼多,如何區分是自帶的屬性還是預設的屬性呢? H5規定自帶的屬性有個data- 首碼,如data-index="1",那麼,如何設置和獲取屬性值呢,請看下文。 <script> var divele = document.querySele ...
  • tab欄切換製作 先上圖 要求1:預設狀態,第一個選項卡被選中,展示第一個選項卡的內容 策略:第一個選項卡預設有被選中的樣式,第一個選項卡對應的display: block,其他的dispaly設為none 要求2: 選項卡模塊:被點擊的變為紅底白字,其他的變為白底紅字 策略:排他思想,每次點擊一個 ...
  • WebSocket 是 HTML5 新增的協議,它的目的是在瀏覽器和伺服器之間建立一個不受限的雙向通信的通道,比如說,伺服器可以在任意時刻發送消息給瀏覽器。 為什麼傳統的 HTTP 協議不能做到 WebSocket 實現的功能?這是因為 HTTP 協議是一個請求-響應協議,請求必須先由瀏覽器發給服務 ...
  • 由來 "推薦在這裡閱讀" js操作二進位數據三兄弟 ArrayBuffer對象, TypeArray視圖和DataView視圖 它們都以數組的語法處理二進位數據,所以統稱為二進位數組 ::: tip 二進位數組並不是真正的數組,而是類似數組的對象 ::: 設計的目的 與WebGL項目有關,WebGL ...
  • 在電腦編程中,排序演算法是最常用的演算法之一,本文介紹了幾種常見的排序演算法以及它們之間的差異和複雜度。 冒泡排序 冒泡排序應該是最簡單的排序演算法了,在所有講解電腦編程和數據結構的課程中,無一例外都會拿冒泡排序作為開篇來講解排序的原理。冒泡排序理解起來也很容易,就是兩個嵌套迴圈遍曆數組,對數組中的元素 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...