arcgis for js 添加自定义叠加图片到地图坐标点上

在使用arcgis for js开发地图绘制图层时,可以通过相关api实现添加图标到某个坐标点,那么如果现在有一个需要添加一个小图叠大图的需求,又或者是自定义绘制图标,如何实现?

1、简单地绘制一个图标到底图图层上面

typescript 复制代码
const graphicsLayer = new GraphicsLayer();
const graphic = new Graphic();
const point = new Point({
	x,
	y,
	spatialReference: 4546, // 假设坐标系为4546
});
const pointSymbol = new PictureMarkerSymbol({
	url: "./test_icon.svg", // 图标相对路径
 	height: 22,
	width: 22,
	yoffset: 10, // 偏移量
});
graphic.geometry = point;
graphic.symbol = pointSymbol;
graphicsLayer.add(graphic);
map.add(graphicsLayer);

我们发现,这样子只能添加一个特定的图片到该坐标点,假设我需要在这个点上面大图叠加一个小图标,如何实现呢?

翻阅了资料,关于叠加自定义图层api版本不一致也很难实现,偶然发现url可以渲染base64图片。那我直接绘制生成base64图片再添加到图层上面,不就可以实现需求了?

实践一下:

2、使用canvas绘制生成base64图片

typescript 复制代码
function createCustomIcon() {
  return new Promise((resolve, reject) => {
  	let url:string = "";
    const canvas = document.createElement("canvas");
    // 获取 Canvas 的 2D 上下文
    const ctx = canvas.getContext("2d");
    if (!ctx) return;
    canvas.width = 40;
    canvas.height = 40;
    // 绘制 SVG 图标到 Canvas
    const img = new Image();
    const innerImg = new Image();
    img.src = './img.svg'; // 外层图
    innerImg.src = './inner_img.svg'; // 叠加内层图
    innerImg.onload = function () {
       ctx.drawImage(img, 0, 0, 40, 40); // 外层图
       ctx.drawImage(innerImg, 10, 6, 20, 20); // 叠加图
       url = canvas.toDataURL(); // 生成 Canvas 的 Data URL
       resolve(url);
    };
  });
}

现在已经绘制生成了一个图片,直接访问url是否正确显示,根据这个方法可以绘制任意你想绘制的图片。

现在将混合的图片添加到图层上面:

3、将自定义叠加图添加到图层上面

typescript 复制代码
const url = await createCustomBase64();
// 和步骤1 一样,就是将图片路径修改一下
const pointSymbol = new PictureMarkerSymbol({
	url, // canvas绘制生成的图片URL
 	height: 22,
	width: 22,
	yoffset: 10, // 偏移量
});
// ...

效果图:

这是由两个小图标组合的图,可以根据需求改变innerImg或者img实现多个不同组合图标,并且添加到图层上面。

当然,也可以使用canvas随意绘制自定义图形添加到图层。

相关推荐
by__csdn2 小时前
微前端架构:从理论到实践的全面解析
前端·javascript·vue.js·架构·typescript·vue·ecmascript
破z晓10 小时前
若依(vue版)集成ArcGIS
前端·vue.js·arcgis
Hao_Harrision10 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| RandomChoicePicker(标签生成)
前端·typescript·react·vite7·tailwildcss
Hao_Harrision11 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| FAQ Collapse(问题解答折叠面板)
前端·typescript·react·vite7·tailwildcss
by__csdn11 小时前
javascript 性能优化实战:垃圾回收优化
java·开发语言·javascript·jvm·vue.js·性能优化·typescript
by__csdn11 小时前
JavaScript性能优化:减少重绘和回流(Reflow和Repaint)
开发语言·前端·javascript·vue.js·性能优化·typescript·vue
凯小默12 小时前
【TypeScript+Vue3+Vite+Vue-router+Vuex+Mock 进行 WEB 前端项目实战】学习笔记共 89 篇(完结)
typescript·echarts·mock·vue3·vite·vuex·vue-router
深兰科技12 小时前
坦桑尼亚与新加坡代表团到访深兰科技,促进AI在多领域的应用落地
java·人工智能·typescript·scala·perl·ai大模型·深兰科技
今天不要写bug21 小时前
vue项目基于vue-cropper实现图片裁剪与图片压缩
前端·javascript·vue.js·typescript
ttod_qzstudio1 天前
Vue 3 + TypeScript 严格模式下的 Performance.now() 实践:构建高性能前端应用
typescript·performance