При создании two.js объекта, вот детали:Создание динамических переменных Two.js привлечь отдельного события CLICK
var circle1 = two.makeCircle(676,326,25);
circle1.noStroke().fill = getRandomColor();
circle1.domElement = document.querySelector('#two-' + circle1.id);
$(circle1.domElement)
.css('cursor', 'pointer')
.click(function(e) {
circle1.fill = getNonMainRandomColor(getRandomColor());
});
я пытался сохранить все необходимые параметры в массиве, как, например:
[x position, y position, radius, color]
Так что у меня функция
function showCircles(array) {
for(var i = 0; i < array.length; i++) {
var rotato = two.makeCircle(array[i][0],array[i][1],array[i][2]);
rotato.noStroke().fill = array[i][3];
rotato.domElement = document.querySelector('#two-' + rotato.id);
$(rotato.domElement).css('cursor', 'pointer').click(function(e) {rotato.fill = getNonMainRandomColor(getRandomColor());});
}
}
Проблема с последним в том, что линии
rotato.domElement = document.querySelector('#two-' + rotato.id);
$(rotato.domElement).css('cursor', 'pointer').click(function(e) {rotato.fill = getNonMainRandomColor(getRandomColor());});
требуют новой переменной каждый раз, когда его увольняют, таким образом, выход представляет собой группу из кругов, которые при нажатии по отдельности, только последний меняет цвет из-за настройки, которые У меня есть то, что вызвано var rotato
, которое должно быть новым для каждого круга и итерации.
Как сделать переменную динамической или есть лучшее решение этой проблемы?
В этот момент API изменился так клики не работает. В этом примере показано, как работают события click с помощью команды two.js: http://jonobr1.github.io/two.js/examples/svg-events.html – jonobr1