在ArcGIS JS API 4.27中,PictureMarkerSymbol访问不允许的Blob,即使使用来自URL属性的base64图像可能是个Bug。为了解决这个问题,你可以尝试以下解决方法:
// 将base64图像转换为Blob对象
function dataURItoBlob(dataURI) {
var byteString = atob(dataURI.split(',')[1]);
var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
var ab = new ArrayBuffer(byteString.length);
var ia = new Uint8Array(ab);
for (var i = 0; i < byteString.length; i++) {
ia[i] = byteString.charCodeAt(i);
}
return new Blob([ab], { type: mimeString });
}
// 创建PictureMarkerSymbol时使用Blob对象
var base64Image = "data:image/png;base64,iVBORw0KG...";
var blob = dataURItoBlob(base64Image);
var symbol = new PictureMarkerSymbol(blob, 32, 32);
// 将base64图像转换为DataURL
function dataURItoDataURL(dataURI) {
return URL.createObjectURL(dataURItoBlob(dataURI));
}
// 创建PictureMarkerSymbol时使用DataURL
var base64Image = "data:image/png;base64,iVBORw0KG...";
var dataURL = dataURItoDataURL(base64Image);
var symbol = new PictureMarkerSymbol(dataURL, 32, 32);
这两种方法都将base64图像转换为Blob或DataURL,并在PictureMarkerSymbol中使用。这样可以避免访问不允许的Blob的问题。希望这可以帮助到你!