| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 | /*	Copyright (c) 2004-2012, The Dojo Foundation All Rights Reserved.	Available via Academic Free License >= 2.1 OR the modified BSD license.	see: http://dojotoolkit.org/license for details*/if(!dojo._hasResource["dojox.drawing.stencil.Text"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.dojo._hasResource["dojox.drawing.stencil.Text"] = true;dojo.provide("dojox.drawing.stencil.Text");dojox.drawing.stencil.Text = dojox.drawing.util.oo.declare(	// summary:	//		Creates a dojox.gfx Text (SVG or VML) based on data provided.	// description:	//		There are two text classes. TextBlock extends this one and	//		adds editable functionality, discovers text width etc.	//		This class displays text only. There is no line wrapping.	//		Multiple lines can be acheived by inserting \n linebreaks	//		in the text.	//	dojox.drawing.stencil._Base,	function(options){		// summary:		//		constructor.	},	{		type:"dojox.drawing.stencil.Text",		anchorType:"none",		baseRender:true,				// align: String		//	Text horizontal alignment.		//		Options: start, middle, end		align:"start",		//		// valign:String		//	Text vertical alignment		//		Options: top, middle, bottom (FIXME: bottom not supported)		valign:"top",		//		// _lineHeight: [readonly] Number		// 	The height of each line of text. Based on style information		//	and font size.		_lineHeight:1,		/*=====StencilData: {	// summary:	//		The data used to create the dojox.gfx Text	// 	x: Number	//		Left point x	// 	y: Number	//		Top point y	// 	width: ? Number	//		Optional width of Text. Not required but reccommended.	//		for auto-sizing, use TextBlock	// 	height: ? Number	//		Optional height of Text. If not provided, _lineHeight is used.	// 	text: String	//		The string content. If not provided, may auto-delete depending on defaults.},StencilPoints: [	// summary:	//		An Array of dojox.__StencilPoint objects that describe the Stencil	// 	0: Object	//		Top left point	// 	1: Object	//		Top right point	// 	2: Object	//		Bottom right point	// 	3: Object	//		Bottom left point],=====*/		typesetter: function(text){			// summary:			//		Register raw text, returning typeset form.			//		Uses function dojox.drawing.stencil.Text.typeset			//		for typesetting, if it exists.			//			if(dojox.drawing.util.typeset){				this._rawText = text;				return dojox.drawing.util.typeset.convertLaTeX(text);			}			return text;		},		setText: function(text){			// summary:			//		Setter for text.			//			// Only apply typesetting to objects that the user can modify.			// Else, it is assumed that typesetting is done elsewhere.			if(this.enabled){				text = this.typesetter(text);			}			// This only has an effect if text is null or this.created is false.			this._text = text;			this._textArray = [];			this.created && this.render(text);		},				getText: function(){			// summary:			//		Getter for text.			//			return this._rawText || this._text;		},				dataToPoints: function(/*Object*/o){			//summary:			//		Converts data to points.			o = o || this.data;			var w = o.width =="auto" ? 1 : o.width;			var h = o.height || this._lineHeight;			this.points = [				{x:o.x, y:o.y}, 				// TL				{x:o.x + w, y:o.y},				// TR				{x:o.x + w, y:o.y + h},			// BR				{x:o.x, y:o.y + h}				// BL			];			return this.points;		},		pointsToData: function(/*Array*/p){			// summary:			//		Converts points to data			p = p || this.points;			var s = p[0];			var e = p[2];			this.data = {				x: s.x,				y: s.y,				width: e.x-s.x,				height: e.y-s.y			};			return this.data;		},				render: function(/* String*/text){			// summary:			//		Renders the 'hit' object (the shape used for an expanded			//		hit area and for highlighting) and the'shape' (the actual			//		display object). Text is slightly different than other			//		implementations. Instead of calling render twice, it calls			//		_createHilite for the 'hit'			// arguments:			//		text String			//			Changes text if sent. Be sure to use the setText and			//			not to call this directly.			//			this.remove(this.shape, this.hit);			//console.log("text render, outline:", !this.annotation, this.renderHit, (!this.annotation && this.renderHit))			!this.annotation && this.renderHit && this._renderOutline();			if(text!=undefined){				this._text = text;				this._textArray = this._text.split("\n");			}						var d = this.pointsToData();			var h = this._lineHeight;			var x = d.x + this.style.text.pad*2;			var y = d.y + this._lineHeight - (this.textSize*.4);			if(this.valign=="middle"){				y -= h/2;			}			this.shape = this.container.createGroup();						/*console.log("    render ", this.type, this.id)			console.log("    render Y:", d.y, "textSize:", this.textSize, "LH:", this._lineHeight)			console.log("    render text:", y, " ... ", this._text, "enabled:", this.enabled);			console.log("    render text:", this.style.currentText);			*/			dojo.forEach(this._textArray, function(txt, i){				var tb = this.shape.createText({x: x, y: y+(h*i), text: unescape(txt), align: this.align})					.setFont(this.style.currentText)					.setFill(this.style.currentText.color);								this._setNodeAtts(tb);						}, this);						this._setNodeAtts(this.shape);					},		_renderOutline: function(){			// summary:			//		Create the hit and highlight area			//		for the Text.			//			if(this.annotation){ return; }			var d = this.pointsToData();						if(this.align=="middle"){				d.x -= d.width/2 - this.style.text.pad * 2;			}else if(this.align=="start"){				d.x += this.style.text.pad;			}else if(this.align=="end"){				d.x -= d.width - this.style.text.pad * 3;			}						if(this.valign=="middle"){				d.y -= (this._lineHeight )/2 - this.style.text.pad;			}						this.hit = this.container.createRect(d)				.setStroke(this.style.currentHit)				.setFill(this.style.currentHit.fill);				//.setFill("#ffff00");						this._setNodeAtts(this.hit);			this.hit.moveToBack();		},		makeFit: function(text, w){			var span = dojo.create('span', {innerHTML:text, id:"foo"}, document.body);			var sz = 1;			dojo.style(span, "fontSize", sz+"px");			var cnt = 30;			while(dojo.marginBox(span).w<w){				sz++;				dojo.style(span, "fontSize", sz+"px");				if(cnt--<=0) break;			}			sz--;			var box = dojo.marginBox(span);			dojo.destroy(span);						return {size:sz, box:box};		}	});dojox.drawing.register({	name:"dojox.drawing.stencil.Text"}, "stencil");}
 |