Есть ли способ динамически построить SVG с использованием спрайтов в амхартах 4?
Пример: снимок экрана
Существует 20 различных типов, которые представлены цветами.
Каждый вывод может содержать множество типов.
Таким образом, пример может быть, что булавка имеет 3 типа и будет состоять из 3 цветов.
У меня есть путь SVG, который является кругом.
С помощью обычных JS и SVG я могу создать путь для каждого типа и изменить цвет обводки, strokedasharray и strokedashoffset.
В результате получается красивый круг с 3 цветами.
Однако, кажется, это невозможно сделать с амхартами 4.
Для начала, strokedashoffset даже не поддерживается для спрайта. Зачем вам поддерживать поддержку strokedasharray, а затем игнорировать strokedashoffet?!
Вторая проблема - выяснить, как передавать данные в спрайт.
Это пример объекта данных, который я передаю классу mapImageSeries.
[{
amount: 3,
client: undefined,
colorsArr: {0: "#FFB783", 1: "#FD9797", 2: "#77A538"},
dashArray: "500,1000",
dashOffset: 1500,
divided: 500,
global: true,
groupId: "minZoom-1",
hcenter: "middle",
id: "250",
latitude: 50.53398,
legendNr: 8,
longitude: 9.68581,
name: "Fulda",
offsetsArr: {0: 0, 1: 500, 2: 1000},
scale: 0.5,
title: "Fulda",
typeIds: (3) ["4", "18", "21"],
typeMarker: " type-21 type-18 type-4",
vcenter: "bottom",
zoomLevel: 5
}]
Кажется невозможным передать цвета спрайту.
var svgPath = 'M291,530C159,530,52,423,52,291S159,52,291,52s239,107,239,239c0,131.5-106.3,238.3-237.7,239'
var mainPin1 = single.createChild(am4core.Sprite)
mainPin1.strokeWidth = 100
mainPin1.fill = am4core.color('#fff')
mainPin1.stroke = am4core.color('#ff0000')
mainPin1.propertyFields.strokeDasharray = 'dashArray'
mainPin1.propertyFields.strokeDashoffset = 'dashOffset'
mainPin1.path = svgPath
mainPin1.scale = 0.04
mainPin1.propertyFields.horizontalCenter = 'hcenter'
mainPin1.propertyFields.verticalCenter = 'vbottom'