Я делаю некоторые демонстрационные веб-страницы в рамках портфеля, чтобы показать потенциальных работодателей.
Одна страница - это симуляция плазменной дуги в "плазменном шаре", которая затем поворачивается для просмотра "дуги" на 360 градусов.
Повторное редактирование дуги через каждое из вращений ТОЛЬКО работает, если я поместил "предупреждение" после каждого перерисовки и затем отменил оповещения при запуске script. Без предупреждения ничего не происходит.
Есть ли у кого-нибудь объяснение/решение? Здесь функция перерисовки:
function reDraw(yAngle) //work in progress - redraw the arc through 360 degrees to see the path
{
var xCs;
var yCs;
for(degrees=10; degrees<360; degrees+=1)//spin sphere through 360 degrees
{
context1 = document.getElementById("canvas1").getContext("2d");
context1.clearRect(0,0,600,600);
radialGrad(1,'canvas1',300,300,300,300,300,0,0,1,colour1,colour2,0,0,600,600);
firstMove=true;
for(moves=0; moves<axisMove; moves++)
{
if(firstMove)//start at centre of sphere for each re-draw
{
xCs=300;
yCs=300;
firstMove=false;
}
context1.beginPath();
context1.moveTo(xCs,yCs);
spinAngle=(degrees/180*Math.PI);
//we are spinning in the X-Z plane so resolve X-Z moves only - retrieve each positive or negative move from the axis move arrays
xCs=xCs+(zCStep[moves]*Math.sin(spinAngle))+(xCStep[moves]*Math.cos(spinAngle));
yCs=yCs+yCStep[moves];
context1.lineTo(xCs,yCs);
context1.shadowBlur=2;
context1.shadowColor="grey";
context1.strokeStyle="white";
context1.stroke();
}
alert();
}
}