推广

Cesium开发工具篇 | 01组件重写

iseeyu2年前 (2024-02-21)推广112

但是在实际的业务场景中,一般初始化范围都是某一个城市或园区的位置,如果使用 Cesium 自带的 homeButton 组件,就需要对其进行修改,使我们在点击homeButton时,相机不是定位到Cesium自带的默认位置,而是定位到我们想要的位置。我们该如何修改呢?

1)修改相机的默认矩形范围

    Cesium.Camera.DEFAULT_VIEW_RECTANGLE = Cesium.Rectangle.fromDegrees(
      110.15,
      34.54,
      110.25,
      34.56
    ); //Rectangle(west, south, east, north)

2)在 homeButton 的 viewModel 中添加监听事件

    if (viewer.homeButton) {
      viewer.homeButton.viewModel.command.beforeExecute.addEventListener(
        function (e) {
          e.cancel = true;
          //你要飞的位置
          viewer.camera.flyTo({
            destination: Cesium.Cartesian3.fromDegrees(117.16, 32.71, 15000.0),
          });
        }
      );
    }

Geocoder组件

Geocoder 是地理编码的意思,我们常用的 POI 搜索就是就是 Geocoder 的功劳。通过查看 Cesium 源码(Source/Widgets/Geocoder/GeocoderViewModel.js 第73行),我们发现Cesium 默认采用的是 Bing 地图服务来实现地理编码的功能,并且是通过 geocode 方法实现的。那么我们就可以通过覆写 geocoder 方法的方式来实现自定义的地理编码服务,下面我们重写geocode方法,将 Cesium 默认的 Bing 地图服务改为OSM地图服务。

  function OpenStreetMapNominatimGeocoder() {}
   OpenStreetMapNominatimGeocoder.prototype.geocode = function (input) {
      var url = "https://nominatim.openstreetmap.org/search";
      var resource = new Cesium.Resource({
        url: url,
        queryParameters: {
          format: "json",
          q: input,
        },
      });

      return resource.fetchJson().then(function (results) {
        var bboxDegrees;
        return results.map(function (resultObject) {
          bboxDegrees = resultObject.boundingbox;
          return {
            displayName: resultObject.display_name,
            destination: Cesium.Rectangle.fromDegrees(
              bboxDegrees[2],
              bboxDegrees[0],
              bboxDegrees[3],
              bboxDegrees[1]
            ),
          };
        });
      });
    };

    var viewer = new Cesium.Viewer("cesiumContainer", {
      geocoder: new OpenStreetMapNominatimGeocoder(),
    });

BaseLayerPicker组件

Cesium为我们提供了默认的底图、地形图的选择面板,通过修改baseLayerPicker的属性ture或false来控制显隐,通过选择面板中的底图或地形图来实现对应图层的切换与显示。Cesum 提供的默认选择面板如下图所:

这些图层都是在线的资源,如果是离线环境,或者是只显示客户提供的几个图层数据,我们该如何实现呢。要实现这个功能,首先,我们看一下 BaseLayerPicker 的主要逻辑关系图,如下图。

从上图我们可以看出,对于开发者而言,要实现不同的ImageryProvider,只需要提供不同的ProviderViewModel,比如BingMap、OSM、ArcGIS、GoogleMaps的,这样在BaseLayerPicker的UI中,就会有多个Provider供用户选择,而交互则由BaseLayerPickerViewModel类负责,用户并不需要关心内部的实现,BaseLayerPickerViewModel类已经帮我们都实现了。下面我们利用 BaseLayerPicker 的逻辑关系,实现自定义的 ImageryProvider(高德矢量图)和 TerrainPovider(ArcGIS地形),并将其显示在选择器面板中。下面为核心代码和结果截图。

    // 自定义影像图层
    var imageProviderVMs = [];
    let gaodeImageProvider = new Cesium.UrlTemplateImageryProvider({
      url:
        "http://webrd0{s}.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}",
      subdomains: ["1", "2", "3", "4"],
    });
    var gaodeVM = new Cesium.ProviderViewModel({
      name: "高德矢量",
      iconUrl: Cesium.buildModuleUrl(
        "Widgets/Images/ImageryProviders/openStreetMap.png"
      ),
      tooltip: "高德矢量 地图服务",
      creationFunction: function () {
        return gaodeImageProvider;
      },
    });
    imageProviderVMs.push(gaodeVM);
    viewer.baseLayerPicker.viewModel.imageryProviderViewModels = imageProviderVMs;

    // 自定义地形图层
    var terrainProviderVMs = [];
    var terrainProvider = new Cesium.ArcGISTiledElevationTerrainProvider({
      url:
        "https://elevation3d.arcgis.com/arcgis/rest/services/WorldElevation3D/Terrain3D/ImageServer",
      token:
        "KED1aF_I4UzXOHy3BnhwyBHU4l5oY6rO6walkmHoYqGp4XyIWUd5YZUC1ZrLAzvV40pR6gBXQayh0eFA8m6vPg..",
    });
    var arcgisVM = new Cesium.ProviderViewModel({
      name: "ArcGIS地形",
      iconUrl: Cesium.buildModuleUrl(
        "Widgets/Images/TerrainProviders/Ellipsoid.png"
      ),
      tooltip: "ArcGIS地形服务",
      creationFunction: function () {
        return terrainProvider;
      },
    });
    terrainProviderVMs.push(arcgisVM);
    viewer.baseLayerPicker.viewModel.terrainProviderViewModels = terrainProviderVMs;

获取完整代码,可查看本人 GitHub 地址https://github.com/ls870061011/cesium_training/tree/main/examples 中的3_1部分。

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57454.html

相关文章

如何用小红书打造出爆款网红产品

如何用小红书打造出爆款网红产品

为了便于理解这篇文章,先给大家讲一个概念:AISAS模式。百科词条解释是电通公司针对互联网与无线应用时代消费者生活形态的变化,而提出的一种全新的消费者行为分析模型。通俗解释是移动互联网用户的消费模式。 AISAS模式即Attention—注意,Interest—兴趣,Searc...

特斯拉:我很难,但我最赚钱

特斯拉:我很难,但我最赚钱

盈利王者的凡尔赛。马斯克最近很头大。7月19日,推特公司诉马斯克一案举行首次听证会,只因马斯克出尔反尔放弃对推特的收购承诺。推特风波还未结束,特斯拉市值一度跌近四分之一,疫情影响下上海工厂停摆近一个月,6月份,马斯克还宣布计划全球裁员10%。在此背景下,都在等着看特斯拉二季...

除了有传播动力的第一波用户,你还需要认识KOL

除了有传播动力的第一波用户,你还需要认识KOL

关键传播者中,除了那些站在山顶手握雪球,有传播动力的第一波用户,我们的产品后期还需要KOL(Key Opinion Leader,关键意见领袖)的关注。想象一下,当初,自信满满的你带着一个“能够改变世界”的想法和一帮热血的小伙伴入驻了某个众创空间或者孵化器,在经历了堪比乔布斯车库创业的无数...

我来分享SEO优化的几个重要的步骤。

我来分享SEO优化的几个重要的步骤。

SEO优化的几个重要的步骤 SEO优化其实是优化的一部分,大意就是搜索引擎优化,无论是网站内部优化,还是站外优化,都包含其中,从而提高搜索引擎上的排名,起到直接销售或者企业品牌推广的作用,保障企业通过线上服务获得足够的利润。 1.分析 SEO优化的第一步,也是该优化最重要的一步。就是将关键词需...

淘宝店铺超级店长怎么设置(淘宝的超级店长怎么使用)

淘宝店铺超级店长怎么设置(淘宝的超级店长怎么使用)

超级店长最常用的一个功能就是橱窗推荐功能了,在超级店长中设置这个功能后就可以帮助店铺主推一些产品,而具体如何设置主推已经给大家介绍了,超级店长里面还有很多功能,这里就不逐个介绍了。...

分享几个超常规营销案例(造神学)

分享几个超常规营销案例(造神学)

插曲 案例分享: 畅销书背后的邪恶手段不重要,才是最重要的,重要的是你要懂得这些营销的理念去策划这些事情。按照我们一般的,我们如何成为畅销书的作者呢?是不是一般的作家思维是我先讲课到处去分享我的思维,我认为我的文采很好,我先在家里花三年的时间来写书,花几年的时间去,其实这样...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片