mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 08:52:06 +00:00 
			
		
		
		
	 220e34b69d
			
		
	
	
		220e34b69d
		
	
	
	
	
		
			
			Add the CanvasTextDrawingStyles mixin with the textAlign and textBaseline attributes. Update fill_text in CanvasRenderingContext2D to move the text rect by the text align and text baseline attributes. Wrote a simple HTML example to showcase the new features.
		
			
				
	
	
		
			22 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| // https://html.spec.whatwg.org/multipage/canvas.html#canvastextalign
 | |
| // enum CanvasTextAlign { "start", "end", "left", "right", "center" };
 | |
| // enum CanvasTextBaseline { "top", "hanging", "middle", "alphabetic", "ideographic", "bottom" };
 | |
| enum CanvasDirection { "ltr", "rtl", "inherit" };
 | |
| enum CanvasFontKerning { "auto", "normal", "none" };
 | |
| enum CanvasFontStretch { "ultra-condensed", "extra-condensed", "condensed", "semi-condensed", "normal", "semi-expanded", "expanded", "extra-expanded", "ultra-expanded" };
 | |
| enum CanvasFontVariantCaps { "normal", "small-caps", "all-small-caps", "petite-caps", "all-petite-caps", "unicase", "titling-caps" };
 | |
| enum CanvasTextRendering { "auto", "optimizeSpeed", "optimizeLegibility", "geometricPrecision" };
 | |
| 
 | |
| // https://html.spec.whatwg.org/multipage/canvas.html#canvastextdrawingstyles
 | |
| interface mixin CanvasTextDrawingStyles {
 | |
|     // FIXME: attribute DOMString font; // (default 10px sans-serif)
 | |
|     attribute CanvasTextAlign textAlign; // (default: "start")
 | |
|     attribute CanvasTextBaseline textBaseline; // (default: "alphabetic")
 | |
|     // FIXME: attribute CanvasDirection direction; // (default: "inherit")
 | |
|     // FIXME: attribute DOMString letterSpacing; // (default: "0px")
 | |
|     // FIXME: attribute CanvasFontKerning fontKerning; // (default: "auto")
 | |
|     // FIXME: attribute CanvasFontStretch fontStretch; // (default: "normal")
 | |
|     // FIXME: attribute CanvasFontVariantCaps fontVariantCaps; // (default: "normal")
 | |
|     // FIXME: attribute CanvasTextRendering textRendering; // (default: "auto")
 | |
|     // FIXME: attribute DOMString wordSpacing; // (default: "0px")
 | |
| };
 |