All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scaffold.libs_as.starling.text.BitmapChar.as Maven / Gradle / Ivy

// =================================================================================================
//
//	Starling Framework
//	Copyright 2011-2015 Gamua. All Rights Reserved.
//
//	This program is free software. You can redistribute and/or modify it
//	in accordance with the terms of the accompanying license agreement.
//
// =================================================================================================

package starling.text
{
    import flash.utils.Dictionary;

    import starling.display.Image;
    import starling.textures.Texture;

    /** A BitmapChar contains the information about one char of a bitmap font.
     *  You don't have to use this class directly in most cases. 
     *  The TextField class contains methods that handle bitmap fonts for you.    
     */ 
    public class BitmapChar
    {
        private var _texture:Texture;
        private var _charID:int;
        private var _xOffset:Number;
        private var _yOffset:Number;
        private var _xAdvance:Number;
        private var _kernings:Dictionary;
        
        /** Creates a char with a texture and its properties. */
        public function BitmapChar(id:int, texture:Texture, 
                                   xOffset:Number, yOffset:Number, xAdvance:Number)
        {
            _charID = id;
            _texture = texture;
            _xOffset = xOffset;
            _yOffset = yOffset;
            _xAdvance = xAdvance;
            _kernings = null;
        }
        
        /** Adds kerning information relative to a specific other character ID. */
        public function addKerning(charID:int, amount:Number):void
        {
            if (_kernings == null)
                _kernings = new Dictionary();
            
            _kernings[charID] = amount;
        }
        
        /** Retrieve kerning information relative to the given character ID. */
        public function getKerning(charID:int):Number
        {
            if (_kernings == null || _kernings[charID] == undefined) return 0.0;
            else return _kernings[charID];
        }
        
        /** Creates an image of the char. */
        public function createImage():Image
        {
            return new Image(_texture);
        }
        
        /** The unicode ID of the char. */
        public function get charID():int { return _charID; }
        
        /** The number of points to move the char in x direction on character arrangement. */
        public function get xOffset():Number { return _xOffset; }
        
        /** The number of points to move the char in y direction on character arrangement. */
        public function get yOffset():Number { return _yOffset; }
        
        /** The number of points the cursor has to be moved to the right for the next char. */
        public function get xAdvance():Number { return _xAdvance; }
        
        /** The texture of the character. */
        public function get texture():Texture { return _texture; }
        
        /** The width of the character in points. */
        public function get width():Number { return _texture.width; }
        
        /** The height of the character in points. */
        public function get height():Number { return _texture.height; }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy