ArcGIS与deckgl结合的不同模式

一、<script>标签引入的模式

<script src="./deckgl/deck.gl@8.5.0/dist.min.js"></script>

<script src="./deckgl/geo-layers@8.5.0/dist.min.js"></script>

<script src="./deckgl/arcgis@8.5.0/dist.min.js"></script>

<script src="https://dans.esrichina.com/javascript/4.23/init.js"></script>

1.1 AMD模式

<script>

require([

  "esri/Map",

  "esri/views/SceneView",

  "esri/views/3d/externalRenderers"

], (Map, SceneView, externalRenderers) => {

    deck.loadArcGISModules().then((arcGIS) => {

         const sceneView = new SceneView({

              container: "viewDiv",

              map: new Map({

                    basemap: "dark-gray-vector"

              }),

              viewingMode: "local",

              camera: {

                    position: [-73.98789805, 42.6361464, 4219.66859],

                    heading: 351.86,

                    tilt: 50.08

              }

            });

    const renderer = new arcGIS.DeckRenderer(sceneView, {

      layers: [renderLayers()]

    });

    externalRenderers.add(sceneView, renderer);

    setInterval(() => {

      renderer.deck.layers = renderLayers();

    }, 30);

    function renderLayers() {

      return [

        new deck.TripsLayer({

          id: "trips",

          data:

            "./deckgl/trips-v7.json",

          getPath: (d) => d.path,

          getTimestamps: (d) => d.timestamps,

          getColor: (d) => (d.vendor === 0 ? [253, 128, 93] : [23, 184, 190]),

          opacity: 1.0,

          widthMinPixels: 4,

          rounded: true,

          //fadeTrail:false,

          trailLength: 180,

          currentTime: (performance.now() % 20000) / 10,

          shadowEnabled: false

        }),

new deck.PolygonLayer({

id: 'buildings',

data: './deckgl/building.json',

extruded: true,

wireframe: false,

opacity: 0.5,

getPolygon: f => f.polygon,

getElevation: f => f.height,

getFillColor: [74, 80, 87],

material: {

ambient: 0.1,

diffuse: 0.6,

shininess: 32,

specularColor: [60, 64, 70]

}

})

      ];

    }

    });

});

</script>


1.2 ES Modules模式

注意:其中的arcgis api走ES Modules,deck依然走的deck.loadArcGISModules()

<script type="module">

import Map from "https://dans.esrichina.com/javascript/4.23/@arcgis/core/Map.js";

import SceneView from "https://dans.esrichina.com/javascript/4.23/@arcgis/core/views/SceneView.js";

import * as externalRenderers from "https://dans.esrichina.com/javascript/4.23/@arcgis/core/views/3d/externalRenderers.js";

deck.loadArcGISModules().then((arcGIS) => {

    //代码与1.1一致。

});


二、NPM的模式

2.1 ES Modules模式

(1) package.json

{

  "name": "arcgis-i3s",

  "version": "0.0.0",

  "license": "MIT",

  "scripts": {

    "start": "webpack-dev-server --progress --hot --open --host 0.0.0.0",

    "start-local": "webpack-dev-server --env.local --progress --hot --open"

  },

  "dependencies": {

    "@arcgis/core": "^4.22.2",

    "@deck.gl/arcgis": "^8.7.0",

    "@loaders.gl/i3s": "^3.1.5",

    "@luma.gl/core": "^8.5.10",

    "deck.gl": "^8.7.0"

  },

  "devDependencies": {

    "webpack": "^4.20.2",

    "webpack-cli": "^3.1.2",

    "webpack-dev-server": "^3.1.11"

  }

}

(2) webpack.config.js

const CONFIG = {

  mode: 'development',

  entry: {

    app: './app.js'

  },

  output: {

    library: 'App'

  }

};

// This line enables bundling against src in this repo rather than installed module

module.exports = env => (env ? require('../../webpack.config.local')(CONFIG)(env) : CONFIG);

(3) app.js

import {DeckRenderer} from '@deck.gl/arcgis';

import Map from "@arcgis/core/Map";

import SceneView from "@arcgis/core/views/SceneView";

import SceneLayer from "@arcgis/core/layers/SceneLayer";

import * as externalRenderers from '@arcgis/core/views/3d/externalRenderers';

import {SimpleMeshLayer} from '@deck.gl/mesh-layers';

import {SphereGeometry} from '@luma.gl/core';

import {Tile3DLayer} from '@deck.gl/geo-layers';

import {I3SLoader} from '@loaders.gl/i3s';

import {Tiles3DLoader} from '@loaders.gl/3d-tiles';

// Tileset entry point: Indexed 3D layer file url

const TILESET_URL =

  'https://tiles.arcgis.com/tiles/z2tnIkrLQ2BRzr6P/arcgis/rest/services/SanFrancisco_Bldgs/SceneServer/layers/0';

export async function renderToDOM(container) {

const map=new Map({

      basemap: 'dark-gray-vector'

    });

  const sceneView = new SceneView({

    container,

    //qualityProfile: 'high',

    map: map,

    environment: {

      atmosphereEnabled: false

    },

    camera: {

      // position: {x: -122.4, y: 37.78, z: 3000},

      position: {x: 106.62508, y: 26.64663742, z: 3000},

      heading: 0,

      tilt: 25

    },

    viewingMode: 'local'

  });

let scenelayer = new SceneLayer({

  // URL to the service

  url: "https://192.168.100.123/server/rest/services/Hosted/cslpk/SceneServer/layers/0"

});

//map.add(scenelayer);

  const renderer = new DeckRenderer(sceneView, {});

  externalRenderers.add(sceneView, renderer);

// Video created by the NASA Jet Propulsion Laboratory, Public domain, via Wikimedia Commons

const VIDEO_URL =

'https://upload.wikimedia.org/wikipedia/commons/transcoded/0/0a/NASA_VR-360_Astronaut_Training-_Space_Walk.webm/NASA_VR-360_Astronaut_Training-_Space_Walk.webm.1080p.webm';

const sphere = new SphereGeometry({

nlat: 50,

nlong: 50,

radius: 150

});

//console.log(sphere);

  let videoEl,video;

    /* global document */

    if (typeof document !== 'undefined') {

      videoEl = document.createElement('video');

      videoEl.crossOrigin = 'anonymous';

      videoEl.preload = 'auto';

      videoEl.loop = true;

      const source = document.createElement('source');

      source.src = VIDEO_URL;

      videoEl.append(source);

  videoEl.play();

      //setVideo(videoEl);

    }

    //return () => videoEl && videoEl.pause();


  sceneView.on('layerview-create', () => {

    renderer.deck.layers = [

      // new Tile3DLayer({

        // id: 'tile-3d-layer',

        // data: 'https://192.168.100.123/server/rest/services/slpk/osgb5G_folder/SceneServer/layers/0',

        // loader: I3SLoader

      // }),

  new SimpleMeshLayer({

  id:'video-sphere',

  data: [

{

position: [106.62508, 26.646],

angle: 0,

color: [255, 0, 0]

},

],

  texture:videoEl,

  mesh:sphere,

  getScale: [1, 1, -1],

  material: false

  }),

  new Tile3DLayer({

  id: 'tile-3d-layer1',

  //tileset json file url

  data: 'https://dans.esrichina.com/3dtiles/tileset.json',

  loader: Tiles3DLoader,

  loadOptions: {

'3d-tiles': {

isTileset: true,

}

  }

    })

    ];

  });

  return {

    remove: () => {

      sceneView.destroy();

      renderer.dispose();

    }

  };

}

三、其他方式:esri-loader、webpack-plugin 不再赘述。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容