cacheAsBitmap
может немного помочь, если вы установите его в классе Circle. Это не поможет, и на самом деле может повредить, если вы установите его в основном классе. Вы получите лучший импульс от cacheAsBitmap
при установке его на объект DisplayObject, чьи дочерние объекты не изменяются, поэтому он может кэшировать его один раз, а затем только транслировать этот объект на сцене. Если дочерние элементы движутся (как в случае с parent
), то он должен перерисовывать и перерисовывать этот элемент каждый кадр, и вы не получаете никакого повышения производительности. cacheAsBitmap
действительно лучше всего работает с элементами, которые имеют сложную векторную графику, которую трудно перерисовать, но редко меняют.
Я не думаю, что округление ваших значений x и y поможет, у меня никогда не было особых проблем с установкой дробного x, y. Для векторной графики это обычно довольно хорошо работает при размещении субпикселей, а для растровых изображений это обычно работает так, как я ожидал.
Я думаю, вы можете использовать анимацию, не зависящую от частоты кадров. То, как ваш код структурирован сейчас, каждый кадр показывает, что вы перемещаетесь на определенное количество градусов. Это означает, что если частота кадров заикается по какой-либо причине, вы все равно будете перемещать то же количество пикселей.
Вот направление, в котором я бы пошел:
Сначала ваш обработчик события enter frame получает несколько обновлений. getTimer()
возвращает текущее количество миллисекунд с момента запуска swf. Таким образом, запомнив lastTime
, который мы отрендерили, и вычтя currentTime
, мы сможем точно определить, сколько миллисекунд прошло с момента последнего кадра. Затем мы можем обновить наш круг, используя это время, а не произвольную скорость / расстояние.
private var lastTime:int;
private function this_enterframe(e:Event = null):void {
var currentTime:int = getTimer();
var elapsedTime:int = currentTime - lastTime;
lastTime = currentTime;
for(var i:int = 0; i<numCircles; i++)
{
getCircleAt(i).updatePosition(elapsedTime, direction)
}
}
Тогда в вашем классе Круга мы сможем вычислить, как далеко он должен был продвинуться за определенный промежуток времени (в этом случае я ввел его скорость как число радиан в секунду, в которое он должен двигаться).
Что-то вроде:
public class Circle extends MovieClip {
// Set the default speed to 10 degrees per second
public const DEFAULT_SPEED:Number = 10 * Math.PI / 180;
private var _radiansPerSecond = Circle.DEFAULT_SPEED;
private var _rotationPosition:Number = 0;
public function updatePosition(elapsedTime:int, direction:*):void {
var chng:Number = _radiansPerSecond * (elapsedTime / 1000) * (direction == RIGHT ? -1 : 1);
_rotationPosition += chng;
this.x = Math.cos(_rotationPosition) * (parentPath.width / 2);
this.y = Math.sin(_rotationPosition) * (parentPath.height / 2);
}
}
Между использованием радианов вместо градусов и динамическим вычислением того, как далеко должен двигаться круг, основываясь на времени, прошедшем с момента последнего рендеринга, я думаю, вы должны быть в состоянии уменьшить дрожание, которое вы видите.