首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用"fromMakiIconId“的Cesium

使用"fromMakiIconId“的Cesium
EN

Stack Overflow用户
提问于 2020-12-15 19:05:31
回答 1查看 186关注 0票数 1

我开始使用to来表示3d地图,并尝试在此3d视图之上添加兴趣点数据。我尝试过本地的png图标,它起作用了。我还意识到可以从内置资源中添加图标。我尝试了下面的代码,它工作得很好。我有一组不同的PoIs,但找不到可以将它们添加到地图上的标签。

例如,要添加一家医院,我在图标i中引用了医院。

代码语言:javascript
复制
var hospitalPin = Cesium.when(
  pinBuilder.fromMakiIconId("hospital", Cesium.Color.RED, 48),
  function (canvas) {
    return viewer.entities.add({
      name: "Hospital",
      position: Cesium.Cartesian3.fromDegrees(77.311, 32.826),
      billboard: {
        image: canvas.toDataURL(),
        verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
      },
    });
  }
);

以类似的方式,是否有任何图标In的引用,我可以使用它们在我的代码中使用它们来表示PoIs。任何帮助都是非常感谢的。

我在can库中找到了位于\Build\can\Assets\Textures\maki的源映像,我认为可以使用它。

EN

回答 1

Stack Overflow用户

发布于 2020-12-15 22:46:35

您发布的图片来自PinBuilder docs,但请查看其原始源代码:这是Cesium Sandcastle GeoJson Demo的屏幕截图。

正如您所注意到的,各个引脚的图像存储在a folder called maki中,其名称如下:

代码语言:javascript
复制
airport.png
alcohol-shop.png
america-football.png
art-gallery.png
bakery.png
bank.png
bar.png
baseball.png
...

只需将.png从图像文件名的末尾剥离,就可以了。这就是身份证。

ID:中允许使用破折号:

代码语言:javascript
复制
pinBuilder.fromMakiIconId("america-football", Cesium.Color.RED, 48)

但是,原始截图中的前几个图钉没有对应的Maki图标,它们是简单的字母或数字。您可以使用文本构建管脚,使用不同的函数,如下所示:

代码语言:javascript
复制
pinBuilder.fromText("A", Cesium.Color.RED, 48)

您也可以使用带有Unicode characters的引脚。

代码语言:javascript
复制
pinBuilder.fromText("\u267b", Cesium.Color.RED, 48)

最后,如果您有自己的自定义PNG文件,类似于Maki图标,但根据您的应用程序的需要进行自定义,您可以直接从自定义PNG文件的URL构建pin。

代码语言:javascript
复制
pinBuilder.fromUrl(url, Cesium.Color.RED, 48)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65304621

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档