亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

arcgis for js實現地圖截圖、地圖打印功能

 更新時間:2024年12月21日 12:13:15   作者:我不當帕魯誰當帕魯  
這篇文章主要介紹了arcgis for js實現地圖截圖、地圖打印功能,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧

地圖截圖

效果

實現

復制運行即可

要實現復雜的截圖保存可以參考 官網案例

<!DOCTYPE html>
<html lang="zn">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      #mapview {
        width: 100vw;
        height: 100vh;
      }
      * {
        margin: 0;
        padding: 0;
      }
      #btn {
        position: fixed;
        right: 30px;
        top: 10px;
        z-index: 999;
        width: 100px;
        height: 40px;
        cursor: pointer;
      }
    </style>
    <link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  />
    <script src="https://js.arcgis.com/4.23/"></script>
  </head>
  <body>
    <button id="btn">地圖截圖</button>
    <div id="mapview"></div>
    <script>
      require(['esri/Map', 'esri/views/MapView', 'esri/layers/FeatureLayer'], function (
        Map,
        MapView,
        FeatureLayer
      ) {
        // 初始化底圖
        window.map = new Map({
          basemap: 'dark-gray-vector'
        })
        // 創(chuàng)建2維視圖
        let view = new MapView({
          container: 'mapview',
          map: map,
          zoom: 11,
          center: [104.783916597735, 32.55699155692144] // 設置地圖的初始化中心點坐標
        })
        document.querySelector('#btn').addEventListener('click', function () {
          view
            .takeScreenshot({
              area: {
                x: 0,
                y: 0,
                width: view.width,
                height: view.height
              },
              format: 'png'
            })
            .then(screenshot => {
              // 直接下載
              const base64 = screenshot.dataUrl.toString() // imgSrc 就是base64哈
              const byteCharacters = atob(base64.replace(/^data:image\/(png|jpeg|jpg);base64,/, ''))
              const byteNumbers = new Array(byteCharacters.length)
              for (let i = 0; i < byteCharacters.length; i++) {
                byteNumbers[i] = byteCharacters.charCodeAt(i)
              }
              const byteArray = new Uint8Array(byteNumbers)
              const blob = new Blob([byteArray], {
                type: undefined
              })
              const aLink = document.createElement('a')
              aLink.download = '圖片名稱.jpg' //這里寫保存時的圖片名稱
              aLink.href = URL.createObjectURL(blob)
              aLink.setAttribute('crossOrigin', 'anonymous')
              aLink.click()
            })
        })
      })
    </script>
  </body>
</html>

地圖打印

使用arcgis自帶的打印組件,可自選導出格式,方向等等

缺點是如果地圖上有MapImageLayer等圖層就會失效

效果

實現

<!DOCTYPE html>
<html lang="zn">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      #mapview {
        width: 100vw;
        height: 100vh;
      }
      * {
        margin: 0;
        padding: 0;
      }
      #btn {
        position: fixed;
        right: 30px;
        top: 10px;
        z-index: 999;
        width: 100px;
        height: 40px;
        cursor: pointer;
      }
    </style>
    <link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  />
    <script src="https://js.arcgis.com/4.23/"></script>
  </head>
  <body>
    <button id="btn">地圖打印</button>
    <div id="mapview"></div>
    <script>
      require([
        'esri/Map',
        'esri/views/MapView',
        'esri/layers/FeatureLayer',
        'esri/Graphic',
        'esri/widgets/Print'
      ], function (Map, MapView, FeatureLayer, Graphic, Print) {
        // 初始化底圖
        window.map = new Map({
          basemap: 'dark-gray-vector'
        })
        // 創(chuàng)建2維視圖
        let view = new MapView({
          container: 'mapview',
          map: map,
          zoom: 11,
          center: [104.783916597735, 32.55699155692144] // 設置地圖的初始化中心點坐標
        })
        document.querySelector('#btn').addEventListener('click', function () {
          const print = new Print({
            view: view,
            label: '提取',
            // 最好指定為自己的打印服務
            printServiceUrl: 'https://utility.arcgisonline.com/arcgis/rest/services/Utilities/PrintingTools/GPServer/Export%20Web%20Map%20Task'
          })
          // 將小部件添加到視圖的右下角
          view.ui.add(print, 'bottom-right')
        })
      })
    </script>
  </body>
</html>

注意

打印服務最好使用自己的arcgisServer服務, 如何開啟自行百度,當然這種事直接呼叫公司gis工程師咯

到此這篇關于arcgis for js實現地圖截圖、地圖打印的文章就介紹到這了,更多相關arcgis for js地圖截圖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • js貪吃蛇游戲實現思路和源碼

    js貪吃蛇游戲實現思路和源碼

    這篇文章主要為大家介紹了js貪吃蛇游戲實現思路,并分享貪吃蛇游戲源碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-04-04
  • JavaScript鼠標移動事件以及實戰(zhàn)案例

    JavaScript鼠標移動事件以及實戰(zhàn)案例

    在學習JS中我對鼠標移動事件進行了一些總結,需要的可以作參考,下面這篇文章主要給大家介紹了關于JavaScript鼠標移動事件以及實戰(zhàn)案例的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • 常用的JavaScript驗證正則表達式匯總

    常用的JavaScript驗證正則表達式匯總

    這篇文章主要是對常用的JavaScript驗證正則表達式進行了詳細的匯總介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • 關于Javascript中defer和async的區(qū)別總結

    關于Javascript中defer和async的區(qū)別總結

    相信看過javascript高級程序設計的人,在javascript高級程序設計里,應該看到了介紹了有關defer和async的區(qū)別,可是比較淺顯,而且也說得不是很清楚。下面我們來通過這篇文章來詳細了解下dfer和async的區(qū)別。
    2016-09-09
  • electron如何使用typescript

    electron如何使用typescript

    引入 TypeScript 到 Electron 項目可以幫助你捕捉錯誤并在編寫代碼時提供更好的自動完成和文檔,這篇文章主要介紹了electron使用typescript的步驟,需要的朋友可以參考下
    2024-04-04
  • JavaScript超詳細實現網頁輪播圖

    JavaScript超詳細實現網頁輪播圖

    這篇文章主要介紹了JavaScript超詳細實現網頁輪播圖,我們經常會看到各種輪播圖的效果,它們到底是怎樣實現的呢?今天我們就一起來看一下具體實現方法吧
    2021-12-12
  • JS實現多選框的操作

    JS實現多選框的操作

    這篇文章主要為大家詳細介紹了JS實現多選框的操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • JS 實現導航欄懸停效果(續(xù)2)

    JS 實現導航欄懸停效果(續(xù)2)

    發(fā)現原來的方法還有是有幾個問題:首先Js代碼冗余,導航條上的Tab是用js實現跳轉而不是超鏈接,還有導航條本身用fixed定位,但沒有被設置為水平居中,而是在JS中更改left值使其居中
    2013-09-09
  • vue 自定義指令directive的使用場景

    vue 自定義指令directive的使用場景

    這篇文章主要詳細介紹了vue 自定義指令directive的使用場景,文中有詳細的代碼示例,感興趣的小伙伴歡迎閱讀
    2023-04-04
  • TypeScript新特性之using關鍵字的使用方法

    TypeScript新特性之using關鍵字的使用方法

    TypeScript 5.2版本中新添加了using關鍵字,目前該關鍵字的提案也進入了ECMAScript的Stage 3,也就是說很快就會進入JavaScript語言本身中,using和const, let和var一樣都是用于變量聲明的,那么它到底有什么與眾不同的地方呢,本文給大家介紹的非常詳細
    2023-11-11

最新評論