Skip to main content

Asynchronous decoding of bitmap images

When you work with bitmap images, you can asynchronously decode and load the bitmap images to improve your application's perceived performance. Decoding a bitmap image asynchronously can take the same time as decoding the image synchronously in many cases. However, the bitmap image gets decoded in a separate thread before the associated Loader object sends the COMPLETE event. Hence, you can asynchronously decode larger images after loading them.

The ImageDecodingPolicy class in the flash.system package, allows you to specify the bitmap loading scheme. The default loading scheme is synchronous.

Bitmap Decoding Policy

Bitmap Loading Scheme

Description

ImageDecodingPolicy.ON_DEMAND

Synchronous

Loaded images are decoded when the image data is accessed.

Use this policy to decode smaller images. You can also use this policy when your application does not rely on complex effects and transitions.

ImageDecodingPolicy.ON_LOAD

Asynchronous

Loaded images are decoded on load, before theCOMPLETEevent is dispatched.

Ideal for larger images (greater than 10 MP). When you are developing AIR-based mobile applications with page transitions, use this bitmap loading policy to improve your application's perceived performance.

Note: If the file being loaded is a bitmap image and the decoding policy used is ON_LOAD, the image is decoded asynchronously before the COMPLETE event is dispatched.

The following code shows the usage of the ImageDecodingPolicy class:

var loaderContext:LoaderContext = new LoaderContext();
loaderContext.imageDecodingPolicy = ImageDecodingPolicy.ON_LOAD
var loader:Loader = new Loader();
loader.load(new URLRequest("https://www.adobe.com/myimage.png"), loaderContext);

You can still use ON_DEMAND decoding with Loader.load() and Loader.loadBytes() methods. However, all the other methods that take a LoaderContext object as an argument, ignore any ImageDecodingPolicy value passed.

The following example shows the difference in decoding a bitmap image synchronously and asynchronously:

package
{
import flash.display.Loader;
import flash.display.Sprite;
import flash.events.Event;
import flash.net.URLRequest;
import flash.system.ImageDecodingPolicy;
import flash.system.LoaderContext;

public class AsyncTest extends Sprite
{
private var loaderContext:LoaderContext;
private var loader:Loader;
private var urlRequest:URLRequest;
public function AsyncTest()
{
//Load the image synchronously
loaderContext = new LoaderContext();
//Default behavior.
loaderContext.imageDecodingPolicy = ImageDecodingPolicy.ON_DEMAND;
loader = new Loader();
loadImageSync();

//Load the image asynchronously
loaderContext = new LoaderContext();
loaderContext.imageDecodingPolicy = ImageDecodingPolicy.ON_LOAD;
loader = new Loader();
loadImageASync();
}

private function loadImageASync():void{
trace("Loading image asynchronously...");
urlRequest = new URLRequest("https://www.adobe.com/myimage.png");
urlRequest.useCache = false;
loader.load(urlRequest, loaderContext);
loader.contentLoaderInfo.addEventListener
(Event.COMPLETE, onAsyncLoadComplete);
}

private function onAsyncLoadComplete(event:Event):void{
trace("Async. Image Load Complete");
}

private function loadImageSync():void{
trace("Loading image synchronously...");
urlRequest = new URLRequest("https://www.adobe.com/myimage.png");
urlRequest.useCache = false;
loader.load(urlRequest, loaderContext);
loader.contentLoaderInfo.addEventListener
(Event.COMPLETE, onSyncLoadComplete);
}

private function onSyncLoadComplete(event:Event):void{
trace("Sync. Image Load Complete");
}
}
}

For a demonstration of the effect of the different decoding policies, see Thibault Imbert: Asynchronous bitmap decoding in the Adobe Flash runtimes