Hi All,
I am trying to use a SVG dynamically (based on attributes) as graphic in FeatureLayer with version 4.x . I have an example that uses 3.x overriding the renderer.getSymbol method.
3.x sample.
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no">
<title>FeatureLayer 3.x</title>
<link rel="stylesheet" href="https://js.arcgis.com/3.22/esri/css/esri.css">
<script src="https://js.arcgis.com/3.22/"></script>
<style>
html, body, #map {
padding: 0;
margin: 0;
height: 100%;
width: 100%;
}
</style>
<script>
require([
"esri/map",
"esri/layers/FeatureLayer",
"esri/renderers/SimpleRenderer",
"esri/symbols/PictureMarkerSymbol",
"dojo/domReady!"
],
function(
Map,
FeatureLayer,
SimpleRenderer,
PictureMarkerSymbol
) {
// THIS SHOULD BE DYNAMIC SVG BASED ON THE GRAPHIC ATTRIBUTES
var svg = ``;
var map = new Map("map", {
basemap: "hybrid",
center: [-82.44109, 35.6122],
zoom: 17
});
var featureLayer = new FeatureLayer("https://services.arcgis.com/V6ZHFr6zdgNZuVG0/arcgis/rest/services/Landscape_Trees/FeatureServer/0");
map.addLayer(featureLayer);
var renderer = new SimpleRenderer();
renderer.getSymbol = function(graphic){
var sym = new PictureMarkerSymbol(svg, 240, 50);
return sym;
}
featureLayer.setRenderer(renderer);
});
</script>
</head>
<body>
<div id="map"></div>
</body>
</html>
I would appreciate any guidance on how I can do the same in version 4.x.
Thank you so much!!,
Roel