Ответ в том, что ActionScript 3 более строг в отношении типов, чем в ActionScript 1. Для Bitmap.perlinNoise требуется смещение, представляющее собой массив объектов Point.В Java это будет то же самое, что и
List<Point> points = new ArrayList<Point>()
, и то же самое, что и
List<Object> points = new ArrayList<Object>()
. В ActionScript я изменил параметризованный тип с Object на flash.geom.Point.Также первый элемент массива никогда не был определен.Чтобы ликвидировать анимацию, я сохранил второе смещение и также переопределил его как flash.geom.Point.Рабочий код, таким образом, выглядит следующим образом:
function createLiquidFlow(target)
target.counter = 1;
target.pt = new flash.geom.Point(0, 0);
target.mpoint = new flash.geom.Point(0, 0);
// target.myBitmap = new flash.display.BitmapData(target._width, target._height, false, 0);
target.myBitmap = new flash.display.BitmapData(target.width, target.height, false, 0 );
target.myDispl = new flash.filters.DisplacementMapFilter(target.myBitmap, target.mpoint, 10, 2, 10, 15, "clamp");
target.myList = new Array();
target.myList.push(target.myDispl);
target.filters = target.myList;
target.addEventListener(
Event.ENTER_FRAME,
function (e:Event)
{
var myFilterList = target.filters;
var offset = new Array();
offset[0] = new Point(0, 0);
offset[1] = new Point(target.counter, target.counter / 2);
target.myBitmap.perlinNoise(45, 6, 3, 50, true, false, 7, true, offset);
myFilterList.mapBitmap = target.myBitmap;
target.filters = myFilterList;
++target.counter;
});
// Arguments to PerlinNoise function
// baseX:Number — Frequency to use in the x direction. For example, to generate a noise that is sized for a 64 x 128 image, pass 64 for the baseX value.
// baseY:Number — Frequency to use in the y direction. For example, to generate a noise that is sized for a 64 x 128 image, pass 128 for the baseY value.
// numOctaves:uint — Number of octaves or individual noise functions to combine to create this noise. Larger numbers of octaves create images with greater detail. Larger numbers of octaves also require more processing time.
// randomSeed:int — The random seed number to use. If you keep all other parameters the same, you can generate different pseudo-random results by varying the random seed value. The Perlin noise function is a mapping function, not a true random-number generation function, so it creates the same results each time from the same random seed.
// stitch:Boolean — A Boolean value. If the value is true, the method attempts to smooth the transition edges of the image to create seamless textures for tiling as a bitmap fill.
// fractalNoise:Boolean — A Boolean value. If the value is true, the method generates fractal noise; otherwise, it generates turbulence. An image with turbulence has visible discontinuities in the gradient that can make it better approximate sharper visual effects like flames and ocean waves.
// channelOptions:uint (default = 7) — A number that can be a combination of any of the four color channel values (BitmapDataChannel.RED, BitmapDataChannel.BLUE, BitmapDataChannel.GREEN, and BitmapDataChannel.ALPHA). You can use the logical OR operator (|) to combine channel values.
// grayScale:Boolean (default = false) — A Boolean value. If the value is true, a grayscale image is created by setting each of the red, green, and blue color channels to identical values. The alpha channel value is not affected if this value is set to true.
//offsets:Array (default = null) — An array of points that correspond to x and y offsets for each octave. By manipulating the offset values you can smoothly scroll the layers of a perlinNoise image. Each point in the offset array affects a specific octave noise function.
}
createLiquidFlow( movieClipLiquid )