Skip to content

krechagames/assets-management

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

assets-management

Load and store assets (also for Starling). Manager assets in your project. Load and store any type of asset, prepare loaded file to use in IAssetsStorage class (create own storage like StarlingStorage).

Full description and manual here: http://blog.krecha-games.com/assets-management/

example (native flash)

This is the most simpliest use of AssetsManager. In this example we use external assets manifest assets.xml (below) to describe which file you want to load and what type are they.

//storage assets
var storage:IAssetsStorage = new AssetsStorage();

//load assets
var loader:AssetsLoader = new AssetsLoader(storage);
loader.addEventListener(Event.COMPLETE, loadAssetsCompleteHandler, false, 0, true);

//(optional) load assets.xml with assets manifest
var config:AssetsConfig = new AssetsConfig("config", "./assets/assets.xml", null);
config.addEventListener(Event.COMPLETE, loadConfigCompleteHandler, false, 0, true);
config.load();

//1. Load assets.xml complete, load assets from manifest
function loadConfigCompleteHandler(event:Event):void {
  loadAssets(config.list);
}

//2. Load assets list. List can be pass manually or load from assets.xml
function loadAssets(list:Vector.<IAsset>):void {
  loader.load(list);
}

//3. Load assets complete, do whatever you want to do with. AssetsLoader's job is done!
function loadAssetsCompleteHandler(event:Event):void {
	var bg:Bitmap = ImageAsset(storage.getAsset("bg")).castBitmap;

	var logotype:Bitmap = ImageAsset(storage.getAsset("logotype")).castBitmap;

	var music:Sound = SoundAsset(storage.getAsset("music")).castSound;
}

//Dispose all objects
function dispose():void {
	config.dispose();
	config.removeEventListener(Event.COMPLETE, loadConfigCompleteHandler);
	config = null;

	loader.removeEventListener(Event.COMPLETE, loadAssetsCompleteHandler);
	loader = null;

	storage.dispose();
	storage = null;
}
<?xml version="1.0" encoding="utf-8" ?>
<data>
    <group name="common">
        <asset id="db" url="assets/data/db.csv" type="text" />
        <asset id="lang" url="assets/data/lang.xml" type="text" />
        <asset id="music" url="assets/sounds/music.mp3" type="sound" />
    </group>

    <group name="x1">
        <asset id="bg" url="assets/textures/[email protected]" type="image" />
        <asset id="logotype" url="assets/textures/[email protected]" type="image" />

        <asset id="atlas" url="assets/textures/[email protected]" type="image" />
        <asset id="atlas_xml" url="assets/textures/[email protected]" type="text" />

        <asset id="compressed_texture" url="assets/textures/[email protected]" type="raw" />
    </group>

    <group name="x2">
        <asset id="bg" url="assets/textures/[email protected]" type="image" />
        <asset id="logotype" url="assets/textures/[email protected]" type="image" />

        <asset id="atlas" url="assets/textures/[email protected]" type="image" />
        <asset id="atlas_xml" url="assets/textures/[email protected]" type="text" />

        <asset id="compressed_texture" url="assets/textures/[email protected]" type="raw" />
    </group>
</data>

example (Starling)

You can use any type of assets storage! Just what you need is to create class that implements IAssetsStorage (or extends AssetsStorage class which is the basic implementation of IAssetsStorage). Example of this approach is StarlingStorage class. Features of this storage is few new methods which prepering textures to use. More info here: http://bit.ly/11l7Ul2

Prepare loader and config like in above example:

//storage assets
var storage:StarlingStorage = new StarlingStorage();

//load assets
var loader:AssetsLoader = new AssetsLoader(storage);
loader.addEventListener(Event.COMPLETE, loadAssetsCompleteHandler, false, 0, true);
loader.load(Vector.<IAsset>([ /* assets from manifest or pass manually */  ]));

//3a. Load assets complete, do whatever you want to do with. AssetsLoader's job is done!
function loadAssetsCompleteHandler(event:Event):void {
  var img:Image = new Image(storage.getTexture("atlasName", "textureName"));

  var tf:TextField = new TextField(100, 100, "text", storage.getBitmapFont("fontName"));

  var sound:SoundAsset = SoundAsset(storage.getAsset("music")).castSound;
}

About

Load and store assets (also for Starling)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published