78 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
package kha.js;
 | 
						|
 | 
						|
import js.Syntax;
 | 
						|
import haxe.io.Bytes;
 | 
						|
import js.Browser;
 | 
						|
import js.html.ImageElement;
 | 
						|
import kha.Color;
 | 
						|
import kha.Kravur;
 | 
						|
 | 
						|
@:keepInit
 | 
						|
class Font implements Resource {
 | 
						|
	public var kravur: Kravur;
 | 
						|
 | 
						|
	var images: Map<Int, Map<Int, ImageElement>> = new Map();
 | 
						|
 | 
						|
	public function new(blob: Blob) {
 | 
						|
		this.kravur = Syntax.code("new kha_js_Font.Kravur(blob);");
 | 
						|
	}
 | 
						|
 | 
						|
	public static function fromBytes(bytes: Bytes): Font {
 | 
						|
		return new Font(Blob.fromBytes(bytes));
 | 
						|
	}
 | 
						|
 | 
						|
	public function height(fontSize: Int): Float {
 | 
						|
		return kravur._get(fontSize).getHeight();
 | 
						|
	}
 | 
						|
 | 
						|
	public function width(fontSize: Int, str: String): Float {
 | 
						|
		return kravur._get(fontSize).stringWidth(str);
 | 
						|
	}
 | 
						|
 | 
						|
	public function widthOfCharacters(fontSize: Int, characters: Array<Int>, start: Int, length: Int): Float {
 | 
						|
		return kravur._get(fontSize).charactersWidth(characters, start, length);
 | 
						|
	}
 | 
						|
 | 
						|
	public function baseline(fontSize: Int): Float {
 | 
						|
		return kravur._get(fontSize).getBaselinePosition();
 | 
						|
	}
 | 
						|
 | 
						|
	public function getImage(fontSize: Int, color: Color): ImageElement {
 | 
						|
		var glyphs = kha.graphics2.Graphics.fontGlyphs;
 | 
						|
		var imageIndex = fontSize * 10000 + glyphs.length;
 | 
						|
		if (!images.exists(imageIndex)) {
 | 
						|
			images[imageIndex] = new Map();
 | 
						|
		}
 | 
						|
		if (!images[imageIndex].exists(color.value)) {
 | 
						|
			var kravur = this.kravur._get(fontSize);
 | 
						|
			var canvas = Browser.document.createCanvasElement();
 | 
						|
			canvas.width = kravur.width;
 | 
						|
			canvas.height = kravur.height;
 | 
						|
			var ctx = canvas.getContext("2d");
 | 
						|
			ctx.fillStyle = "black";
 | 
						|
			ctx.fillRect(0, 0, kravur.width, kravur.height);
 | 
						|
 | 
						|
			var imageData = ctx.getImageData(0, 0, kravur.width, kravur.height);
 | 
						|
			var bytes = cast(kravur.getTexture(), CanvasImage).bytes;
 | 
						|
			for (i in 0...bytes.length) {
 | 
						|
				imageData.data[i * 4 + 0] = color.Rb;
 | 
						|
				imageData.data[i * 4 + 1] = color.Gb;
 | 
						|
				imageData.data[i * 4 + 2] = color.Bb;
 | 
						|
				imageData.data[i * 4 + 3] = bytes.get(i);
 | 
						|
			}
 | 
						|
			ctx.putImageData(imageData, 0, 0);
 | 
						|
 | 
						|
			var img = Browser.document.createImageElement();
 | 
						|
			img.src = canvas.toDataURL("image/png");
 | 
						|
			images[imageIndex][color.value] = img;
 | 
						|
			return img;
 | 
						|
		}
 | 
						|
		return images[imageIndex][color.value];
 | 
						|
	}
 | 
						|
 | 
						|
	public function unload(): Void {
 | 
						|
		kravur = null;
 | 
						|
		images = null;
 | 
						|
	}
 | 
						|
}
 |