snipt

Ctrl+h for KB shortcuts

ActionScript 3

Create panel that shows memory, fps, notification in browser

package  {
	
	import flash.display.Sprite;
	import flash.display.Stage;
	
	import flash.text.TextField;
	import flash.text.TextFormat;
	import flash.text.TextFieldAutoSize;
	import flash.text.TextFormatAlign;
	import flash.text.AntiAliasType;
	import flash.geom.Rectangle;
	
	import flash.events.Event;
	import flash.events.MouseEvent;
	import flash.system.System;
	import flash.utils.getTimer;
	
	import com.greensock.TweenLite;
	
	/*
	Debug Util - simple memory managment, grawl-like flash notifications, easy button setup
	Author: Chrysto Panayotov ( burnandbass[at]gmail.com )
	
	Dependencies: TweenLite ( http://tweenlite.com/ )
	
	Usage:  Debug.create(this.stage);
	this creates stats winndow on the stage, when you click it outputs more information
	
	public static functions:
	
	Debug.log( message:String ) --> Outputs the message
	Debug.error( message:String ) --> Outputs the message (in red)
	Debug.addButton(name:String, funk:Function);
	
	the this will add new button to the manager and execute the function when the button is clicked
	
	example: 		Debug.addButton("Simple Button", function():void{ trace("Hello from Debug"); });
	
	Debug.destroy()  --> removes the manager and clears all EventListeners
	
	Default: When you click on the manager it will grawl information : current memory, the maximum memory flash player reached
	and the free memory, also the stageWidth and stageHeight
	
	*/
	
	
	public class Debug extends Sprite{
		
		private static var _stage:Stage;
		
		private static var _debug:Sprite;
		private static var _debugText:TextField;
		private static var _time:Number;
		private static var _maxMemory:Number = 0;
		
		private static var _grawlHeight:Number = 0;
		private static var _created:Boolean = false;
		
		private static var _grawlOptions:Object = {
			grawlTextWidth: 350,     //width of the text field
			padding: 10,             // padding - from bottom, right and between notifications
			openTime: 0.7,           // open time
			closeTime: 0.5,         // close time
			stayTime: 4             // time in seconds that the notification stays
		}
		
		public function Debug() {
			throw new Error("Use Debug.create(this.stage) to make instance of debug panel");
		}
		
		/*
		This is how you initialize the manager, just use Debug.create(this.stage) in the main class
		*/
		public static function create(stage:Stage):void{
			if(!_created){
				_created = true;
				_stage = stage;
				_time = getTimer();
				
				createDebug();
				
				_stage.addChild(_debug);
				_debug.x = _debug.y = 5;
				_stage.addEventListener(Event.ADDED, popDebug, false, 0, true);
				_stage.addEventListener(Event.ENTER_FRAME, update);
			} else {
				Debug.error("DebugPanel is already created!");
			}
		}
		
		/*
		Outputs message on the screen 
		*/
		public static function log(message:String):void{
			grawl("log", message);
		}
		
		/*
		Outputs error on the screen
		*/
		public static function error(message:String):void{
			grawl("error", message);
		}
		
		public static function addButton(name:String, onClick:Function):void{
			var btn:Sprite = new Sprite();
			
			var format:TextFormat = new TextFormat();
			format.align = TextFormatAlign.LEFT;
			format.color = 0xFFFFFF;
			format.font = "Helvetica";
			format.size = 12;
			
			var label:TextField = new TextField();
			label.autoSize = TextFieldAutoSize.LEFT;
			label.embedFonts = false;
			label.selectable = false;
			label.defaultTextFormat = format;
			label.x = _debugText.y = 3;
			label.text = name;
			
			btn.graphics.beginFill(0x000000, 1);
			btn.graphics.drawRoundRect(0,0,label.textWidth + 12,20,10,10);
			btn.graphics.endFill();
			btn.buttonMode = true;
			btn.mouseChildren = false;
			btn.addChild(label);
			label.x = label.y = 3;
			
			btn.addEventListener(MouseEvent.CLICK, onClick);
			
			_debug.addChild(btn);
			btn.x = _debug.width + 2;
			
		}
		
		/*
		Internal function, creates the panel and the textfield
		*/
		private static function createDebug():void{
			_debug = new Sprite();
			_debug.graphics.beginFill(0x000000, 1);
			_debug.graphics.drawRoundRect(0,0,110,20,10,10);
			_debug.graphics.endFill();
			_debug.mouseChildren = true;
			
			var format:TextFormat = new TextFormat();
			format.align = TextFormatAlign.LEFT;
			format.color = 0xFFFFFF;
			format.font = "Helvetica";
			format.size = 12;
			
			_debugText = new TextField();
			_debugText.autoSize = TextFieldAutoSize.LEFT;
			_debugText.embedFonts = false;
			_debugText.selectable = false;
			_debugText.defaultTextFormat = format;
			
			_debug.addChild(_debugText);
			_debugText.x = _debugText.y = 3;
			
			_debugText.text = "";
			
			_debug.addEventListener(MouseEvent.ROLL_OVER, onDebugOver, false, 0, true);
			_debug.addEventListener(MouseEvent.ROLL_OUT, onDebugOut, false, 0, true);
			_debugText.addEventListener(MouseEvent.CLICK, onDebugClick, false, 0, true);
		}
		
		
		/*
		internal function called on every "enterFrame" event, calculates the memory and fps
		*/
		private static function update(event:Event):void{
			var memory:Number = Number((System.totalMemory / 1024 / 1024).toFixed(2));
			if(memory > _maxMemory){
				_maxMemory = memory;
			}
			var fps:Number = Number (1000 / (getTimer() - _time));
			_debugText.text = memory + " mb / " + Math.ceil(fps) + " fps";
			_time = getTimer();
		}
		
		/*
		Internal function that actually creates the grawl
		*/
		
		private static function grawl(type:String, text:String):void{
			var padding:Number = 10;
			
			var format:TextFormat = new TextFormat();
			format.align = TextFormatAlign.LEFT;
			format.color = type == "log" ? 0xFFFFFF : 0x000000;
			format.font = "Helvetica";
			format.size = 14;
			
			var grawlText:TextField = new TextField();
			grawlText.width  = _grawlOptions.grawlTextWidth;
			grawlText.multiline = true;
			grawlText.wordWrap = true;
			grawlText.autoSize = TextFieldAutoSize.LEFT;
			grawlText.embedFonts = false;
			grawlText.selectable = true;
			grawlText.defaultTextFormat = format;
			grawlText.text = text;
			
			var bg:Sprite = new Sprite();
			var bgColor:uint = type == "log" ? 0x000000 : 0xFF0000;
			bg.graphics.beginFill(bgColor, 1);
			bg.graphics.drawRoundRect(0,0, grawlText.width + padding*2, grawlText.height + padding*2, 10,10);
			bg.graphics.endFill();
			bg.addChild(grawlText);
			grawlText.x = padding;
			grawlText.y = padding;
			
			_stage.addChild(bg);
			bg.alpha = 0;
			bg.x = _stage.stageWidth - bg.width - _grawlOptions.padding;
			bg.y = _stage.stageHeight - bg.height - _grawlOptions.padding - _grawlHeight;
			_grawlHeight += bg.height + _grawlOptions.padding;
			TweenLite.to(bg, _grawlOptions.openTime, {alpha: 0.9});
			TweenLite.delayedCall(_grawlOptions.stayTime, function():void{
								  TweenLite.to(bg, _grawlOptions.closeTime, {alpha:0, onComplete:function():void{
											_stage.removeChild(bg);
											_grawlHeight -= bg.height + _grawlOptions.padding;
											   }})
								  });
			
		}
		
		/*
		Tween when you roll over the panel
		*/
		private static function onDebugOver(event:MouseEvent):void{
			TweenLite.to(_debug, 0.5, {alpha: 1});
		}
		
		/*
		Tween when you roll out the panel
		*/
		private static function onDebugOut(event:MouseEvent):void{
			TweenLite.to(_debug, 0.5, {alpha: 0.5});
		}
		
		/*
		Shows the current memory, maximum memory and fps
		*/
		private static function onDebugClick(event:MouseEvent):void{
			log("[Memory] : " + Number((System.totalMemory / 1024 / 1024).toFixed(2)) + " max: " + _maxMemory + " free: " + Number((System.freeMemory / 1024 / 1024).toFixed(2))
				+ "\n"
				+ "[Stage ] : width: " + _stage.stageWidth + " height: " + _stage.stageHeight)
			// you can extend this with custom vars, you wanna output
		}
		
		/*
		internal function , sets the panel on the top of stages display list
		*/
		private static function popDebug(event:Event):void{
			_stage.setChildIndex(_debug, _stage.numChildren-1);
		}
		
		//////////////////////////// DESTROY //////////////////////////////////////////////
		
		/*
		Destroys the manager
		*/
		
		public static function destroy():void{
			_stage.removeEventListener(Event.ADDED, popDebug);
			_stage.removeEventListener(Event.ENTER_FRAME, update)
			_debug.removeEventListener(MouseEvent.ROLL_OVER, onDebugOver);
			_debug.removeEventListener(MouseEvent.ROLL_OUT, onDebugOut);
			_debugText.removeEventListener(MouseEvent.CLICK, onDebugClick);
			
			_stage.removeChild(_debug);
			System.gc();
		}
		
	}//end	
}
https://snipt.net/embed/1c464a7de3279c1fd3570c97354520e0/
/raw/1c464a7de3279c1fd3570c97354520e0/
1c464a7de3279c1fd3570c97354520e0
as3
ActionScript 3
279
2019-08-26T04:10:10
True
False
False
/api/public/snipt/26127/
create-panel-that-shows-memory-fps-notification-in-browser
<table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><a href="#L-1"> 1</a> <a href="#L-2"> 2</a> <a href="#L-3"> 3</a> <a href="#L-4"> 4</a> <a href="#L-5"> 5</a> <a href="#L-6"> 6</a> <a href="#L-7"> 7</a> <a href="#L-8"> 8</a> <a href="#L-9"> 9</a> <a href="#L-10"> 10</a> <a href="#L-11"> 11</a> <a href="#L-12"> 12</a> <a href="#L-13"> 13</a> <a href="#L-14"> 14</a> <a href="#L-15"> 15</a> <a href="#L-16"> 16</a> <a href="#L-17"> 17</a> <a href="#L-18"> 18</a> <a href="#L-19"> 19</a> <a href="#L-20"> 20</a> <a href="#L-21"> 21</a> <a href="#L-22"> 22</a> <a href="#L-23"> 23</a> <a href="#L-24"> 24</a> <a href="#L-25"> 25</a> <a href="#L-26"> 26</a> <a href="#L-27"> 27</a> <a href="#L-28"> 28</a> <a href="#L-29"> 29</a> <a href="#L-30"> 30</a> <a href="#L-31"> 31</a> <a href="#L-32"> 32</a> <a href="#L-33"> 33</a> <a href="#L-34"> 34</a> <a href="#L-35"> 35</a> <a href="#L-36"> 36</a> <a href="#L-37"> 37</a> <a href="#L-38"> 38</a> <a href="#L-39"> 39</a> <a href="#L-40"> 40</a> <a href="#L-41"> 41</a> <a href="#L-42"> 42</a> <a href="#L-43"> 43</a> <a href="#L-44"> 44</a> <a href="#L-45"> 45</a> <a href="#L-46"> 46</a> <a href="#L-47"> 47</a> <a href="#L-48"> 48</a> <a href="#L-49"> 49</a> <a href="#L-50"> 50</a> <a href="#L-51"> 51</a> <a href="#L-52"> 52</a> <a href="#L-53"> 53</a> <a href="#L-54"> 54</a> <a href="#L-55"> 55</a> <a href="#L-56"> 56</a> <a href="#L-57"> 57</a> <a href="#L-58"> 58</a> <a href="#L-59"> 59</a> <a href="#L-60"> 60</a> <a href="#L-61"> 61</a> <a href="#L-62"> 62</a> <a href="#L-63"> 63</a> <a href="#L-64"> 64</a> <a href="#L-65"> 65</a> <a href="#L-66"> 66</a> <a href="#L-67"> 67</a> <a href="#L-68"> 68</a> <a href="#L-69"> 69</a> <a href="#L-70"> 70</a> <a href="#L-71"> 71</a> <a href="#L-72"> 72</a> <a href="#L-73"> 73</a> <a href="#L-74"> 74</a> <a href="#L-75"> 75</a> <a href="#L-76"> 76</a> <a href="#L-77"> 77</a> <a href="#L-78"> 78</a> <a href="#L-79"> 79</a> <a href="#L-80"> 80</a> <a href="#L-81"> 81</a> <a href="#L-82"> 82</a> <a href="#L-83"> 83</a> <a href="#L-84"> 84</a> <a href="#L-85"> 85</a> <a href="#L-86"> 86</a> <a href="#L-87"> 87</a> <a href="#L-88"> 88</a> <a href="#L-89"> 89</a> <a href="#L-90"> 90</a> <a href="#L-91"> 91</a> <a href="#L-92"> 92</a> <a href="#L-93"> 93</a> <a href="#L-94"> 94</a> <a href="#L-95"> 95</a> <a href="#L-96"> 96</a> <a href="#L-97"> 97</a> <a href="#L-98"> 98</a> <a href="#L-99"> 99</a> <a href="#L-100">100</a> <a href="#L-101">101</a> <a href="#L-102">102</a> <a href="#L-103">103</a> <a href="#L-104">104</a> <a href="#L-105">105</a> <a href="#L-106">106</a> <a href="#L-107">107</a> <a href="#L-108">108</a> <a href="#L-109">109</a> <a href="#L-110">110</a> <a href="#L-111">111</a> <a href="#L-112">112</a> <a href="#L-113">113</a> <a href="#L-114">114</a> <a href="#L-115">115</a> <a href="#L-116">116</a> <a href="#L-117">117</a> <a href="#L-118">118</a> <a href="#L-119">119</a> <a href="#L-120">120</a> <a href="#L-121">121</a> <a href="#L-122">122</a> <a href="#L-123">123</a> <a href="#L-124">124</a> <a href="#L-125">125</a> <a href="#L-126">126</a> <a href="#L-127">127</a> <a href="#L-128">128</a> <a href="#L-129">129</a> <a href="#L-130">130</a> <a href="#L-131">131</a> <a href="#L-132">132</a> <a href="#L-133">133</a> <a href="#L-134">134</a> <a href="#L-135">135</a> <a href="#L-136">136</a> <a href="#L-137">137</a> <a href="#L-138">138</a> <a href="#L-139">139</a> <a href="#L-140">140</a> <a href="#L-141">141</a> <a href="#L-142">142</a> <a href="#L-143">143</a> <a href="#L-144">144</a> <a href="#L-145">145</a> <a href="#L-146">146</a> <a href="#L-147">147</a> <a href="#L-148">148</a> <a href="#L-149">149</a> <a href="#L-150">150</a> <a href="#L-151">151</a> <a href="#L-152">152</a> <a href="#L-153">153</a> <a href="#L-154">154</a> <a href="#L-155">155</a> <a href="#L-156">156</a> <a href="#L-157">157</a> <a href="#L-158">158</a> <a href="#L-159">159</a> <a href="#L-160">160</a> <a href="#L-161">161</a> <a href="#L-162">162</a> <a href="#L-163">163</a> <a href="#L-164">164</a> <a href="#L-165">165</a> <a href="#L-166">166</a> <a href="#L-167">167</a> <a href="#L-168">168</a> <a href="#L-169">169</a> <a href="#L-170">170</a> <a href="#L-171">171</a> <a href="#L-172">172</a> <a href="#L-173">173</a> <a href="#L-174">174</a> <a href="#L-175">175</a> <a href="#L-176">176</a> <a href="#L-177">177</a> <a href="#L-178">178</a> <a href="#L-179">179</a> <a href="#L-180">180</a> <a href="#L-181">181</a> <a href="#L-182">182</a> <a href="#L-183">183</a> <a href="#L-184">184</a> <a href="#L-185">185</a> <a href="#L-186">186</a> <a href="#L-187">187</a> <a href="#L-188">188</a> <a href="#L-189">189</a> <a href="#L-190">190</a> <a href="#L-191">191</a> <a href="#L-192">192</a> <a href="#L-193">193</a> <a href="#L-194">194</a> <a href="#L-195">195</a> <a href="#L-196">196</a> <a href="#L-197">197</a> <a href="#L-198">198</a> <a href="#L-199">199</a> <a href="#L-200">200</a> <a href="#L-201">201</a> <a href="#L-202">202</a> <a href="#L-203">203</a> <a href="#L-204">204</a> <a href="#L-205">205</a> <a href="#L-206">206</a> <a href="#L-207">207</a> <a href="#L-208">208</a> <a href="#L-209">209</a> <a href="#L-210">210</a> <a href="#L-211">211</a> <a href="#L-212">212</a> <a href="#L-213">213</a> <a href="#L-214">214</a> <a href="#L-215">215</a> <a href="#L-216">216</a> <a href="#L-217">217</a> <a href="#L-218">218</a> <a href="#L-219">219</a> <a href="#L-220">220</a> <a href="#L-221">221</a> <a href="#L-222">222</a> <a href="#L-223">223</a> <a href="#L-224">224</a> <a href="#L-225">225</a> <a href="#L-226">226</a> <a href="#L-227">227</a> <a href="#L-228">228</a> <a href="#L-229">229</a> <a href="#L-230">230</a> <a href="#L-231">231</a> <a href="#L-232">232</a> <a href="#L-233">233</a> <a href="#L-234">234</a> <a href="#L-235">235</a> <a href="#L-236">236</a> <a href="#L-237">237</a> <a href="#L-238">238</a> <a href="#L-239">239</a> <a href="#L-240">240</a> <a href="#L-241">241</a> <a href="#L-242">242</a> <a href="#L-243">243</a> <a href="#L-244">244</a> <a href="#L-245">245</a> <a href="#L-246">246</a> <a href="#L-247">247</a> <a href="#L-248">248</a> <a href="#L-249">249</a> <a href="#L-250">250</a> <a href="#L-251">251</a> <a href="#L-252">252</a> <a href="#L-253">253</a> <a href="#L-254">254</a> <a href="#L-255">255</a> <a href="#L-256">256</a> <a href="#L-257">257</a> <a href="#L-258">258</a> <a href="#L-259">259</a> <a href="#L-260">260</a> <a href="#L-261">261</a> <a href="#L-262">262</a> <a href="#L-263">263</a> <a href="#L-264">264</a> <a href="#L-265">265</a> <a href="#L-266">266</a> <a href="#L-267">267</a> <a href="#L-268">268</a> <a href="#L-269">269</a> <a href="#L-270">270</a> <a href="#L-271">271</a> <a href="#L-272">272</a> <a href="#L-273">273</a> <a href="#L-274">274</a> <a href="#L-275">275</a> <a href="#L-276">276</a> <a href="#L-277">277</a> <a href="#L-278">278</a> <a href="#L-279">279</a></pre></div></td><td class="code"><div class="highlight"><pre><span></span><span id="L-1"><a name="L-1"></a><span class="kd">package</span> <span class="o">{</span> </span><span id="L-2"><a name="L-2"></a> </span><span id="L-3"><a name="L-3"></a> <span class="k">import</span> <span class="nn">flash.display.Sprite</span><span class="o">;</span> </span><span id="L-4"><a name="L-4"></a> <span class="k">import</span> <span class="nn">flash.display.Stage</span><span class="o">;</span> </span><span id="L-5"><a name="L-5"></a> </span><span id="L-6"><a name="L-6"></a> <span class="k">import</span> <span class="nn">flash.text.TextField</span><span class="o">;</span> </span><span id="L-7"><a name="L-7"></a> <span class="k">import</span> <span class="nn">flash.text.TextFormat</span><span class="o">;</span> </span><span id="L-8"><a name="L-8"></a> <span class="k">import</span> <span class="nn">flash.text.TextFieldAutoSize</span><span class="o">;</span> </span><span id="L-9"><a name="L-9"></a> <span class="k">import</span> <span class="nn">flash.text.TextFormatAlign</span><span class="o">;</span> </span><span id="L-10"><a name="L-10"></a> <span class="k">import</span> <span class="nn">flash.text.AntiAliasType</span><span class="o">;</span> </span><span id="L-11"><a name="L-11"></a> <span class="k">import</span> <span class="nn">flash.geom.Rectangle</span><span class="o">;</span> </span><span id="L-12"><a name="L-12"></a> </span><span id="L-13"><a name="L-13"></a> <span class="k">import</span> <span class="nn">flash.events.Event</span><span class="o">;</span> </span><span id="L-14"><a name="L-14"></a> <span class="k">import</span> <span class="nn">flash.events.MouseEvent</span><span class="o">;</span> </span><span id="L-15"><a name="L-15"></a> <span class="k">import</span> <span class="nn">flash.system.System</span><span class="o">;</span> </span><span id="L-16"><a name="L-16"></a> <span class="k">import</span> <span class="nn">flash.utils.getTimer</span><span class="o">;</span> </span><span id="L-17"><a name="L-17"></a> </span><span id="L-18"><a name="L-18"></a> <span class="k">import</span> <span class="nn">com.greensock.TweenLite</span><span class="o">;</span> </span><span id="L-19"><a name="L-19"></a> </span><span id="L-20"><a name="L-20"></a> <span class="cm">/*</span> </span><span id="L-21"><a name="L-21"></a><span class="cm"> Debug Util - simple memory managment, grawl-like flash notifications, easy button setup</span> </span><span id="L-22"><a name="L-22"></a><span class="cm"> Author: Chrysto Panayotov ( burnandbass[at]gmail.com )</span> </span><span id="L-23"><a name="L-23"></a><span class="cm"> </span> </span><span id="L-24"><a name="L-24"></a><span class="cm"> Dependencies: TweenLite ( http://tweenlite.com/ )</span> </span><span id="L-25"><a name="L-25"></a><span class="cm"> </span> </span><span id="L-26"><a name="L-26"></a><span class="cm"> Usage: Debug.create(this.stage);</span> </span><span id="L-27"><a name="L-27"></a><span class="cm"> this creates stats winndow on the stage, when you click it outputs more information</span> </span><span id="L-28"><a name="L-28"></a><span class="cm"> </span> </span><span id="L-29"><a name="L-29"></a><span class="cm"> public static functions:</span> </span><span id="L-30"><a name="L-30"></a><span class="cm"> </span> </span><span id="L-31"><a name="L-31"></a><span class="cm"> Debug.log( message:String ) --&gt; Outputs the message</span> </span><span id="L-32"><a name="L-32"></a><span class="cm"> Debug.error( message:String ) --&gt; Outputs the message (in red)</span> </span><span id="L-33"><a name="L-33"></a><span class="cm"> Debug.addButton(name:String, funk:Function);</span> </span><span id="L-34"><a name="L-34"></a><span class="cm"> </span> </span><span id="L-35"><a name="L-35"></a><span class="cm"> the this will add new button to the manager and execute the function when the button is clicked</span> </span><span id="L-36"><a name="L-36"></a><span class="cm"> </span> </span><span id="L-37"><a name="L-37"></a><span class="cm"> example: Debug.addButton(&quot;Simple Button&quot;, function():void{ trace(&quot;Hello from Debug&quot;); });</span> </span><span id="L-38"><a name="L-38"></a><span class="cm"> </span> </span><span id="L-39"><a name="L-39"></a><span class="cm"> Debug.destroy() --&gt; removes the manager and clears all EventListeners</span> </span><span id="L-40"><a name="L-40"></a><span class="cm"> </span> </span><span id="L-41"><a name="L-41"></a><span class="cm"> Default: When you click on the manager it will grawl information : current memory, the maximum memory flash player reached</span> </span><span id="L-42"><a name="L-42"></a><span class="cm"> and the free memory, also the stageWidth and stageHeight</span> </span><span id="L-43"><a name="L-43"></a><span class="cm"> </span> </span><span id="L-44"><a name="L-44"></a><span class="cm"> */</span> </span><span id="L-45"><a name="L-45"></a> </span><span id="L-46"><a name="L-46"></a> </span><span id="L-47"><a name="L-47"></a> <span class="kd">public</span> <span class="kd">class</span> <span class="n">Debug</span> <span class="kd">extends</span> <span class="n">Sprite</span><span class="o">{</span> </span><span id="L-48"><a name="L-48"></a> </span><span id="L-49"><a name="L-49"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_stage</span><span class="p">:</span><span class="kt">Stage</span><span class="o">;</span> </span><span id="L-50"><a name="L-50"></a> </span><span id="L-51"><a name="L-51"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_debug</span><span class="p">:</span><span class="kt">Sprite</span><span class="o">;</span> </span><span id="L-52"><a name="L-52"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_debugText</span><span class="p">:</span><span class="kt">TextField</span><span class="o">;</span> </span><span id="L-53"><a name="L-53"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_time</span><span class="p">:</span><span class="kt">Number</span><span class="o">;</span> </span><span id="L-54"><a name="L-54"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_maxMemory</span><span class="p">:</span><span class="kt">Number</span> <span class="o">=</span> <span class="mi">0</span><span class="o">;</span> </span><span id="L-55"><a name="L-55"></a> </span><span id="L-56"><a name="L-56"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_grawlHeight</span><span class="p">:</span><span class="kt">Number</span> <span class="o">=</span> <span class="mi">0</span><span class="o">;</span> </span><span id="L-57"><a name="L-57"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_created</span><span class="p">:</span><span class="kt">Boolean</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-58"><a name="L-58"></a> </span><span id="L-59"><a name="L-59"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">var</span> <span class="n">_grawlOptions</span><span class="p">:</span><span class="kt">Object</span> <span class="o">=</span> <span class="o">{</span> </span><span id="L-60"><a name="L-60"></a> <span class="n">grawlTextWidth</span><span class="o">:</span> <span class="mi">350</span><span class="o">,</span> <span class="c1">//width of the text field</span> </span><span id="L-61"><a name="L-61"></a> <span class="n">padding</span><span class="o">:</span> <span class="mi">10</span><span class="o">,</span> <span class="c1">// padding - from bottom, right and between notifications</span> </span><span id="L-62"><a name="L-62"></a> <span class="n">openTime</span><span class="o">:</span> <span class="mf">0.7</span><span class="o">,</span> <span class="c1">// open time</span> </span><span id="L-63"><a name="L-63"></a> <span class="n">closeTime</span><span class="o">:</span> <span class="mf">0.5</span><span class="o">,</span> <span class="c1">// close time</span> </span><span id="L-64"><a name="L-64"></a> <span class="n">stayTime</span><span class="o">:</span> <span class="mi">4</span> <span class="c1">// time in seconds that the notification stays</span> </span><span id="L-65"><a name="L-65"></a> <span class="o">}</span> </span><span id="L-66"><a name="L-66"></a> </span><span id="L-67"><a name="L-67"></a> <span class="kd">public</span> <span class="kd">function </span><span class="nf">Debug</span><span class="o">()</span> <span class="o">{</span> </span><span id="L-68"><a name="L-68"></a> <span class="k">throw</span> <span class="k">new</span> <span class="kt">Error</span><span class="o">(</span><span class="s2">&quot;Use Debug.create(this.stage) to make instance of debug panel&quot;</span><span class="o">);</span> </span><span id="L-69"><a name="L-69"></a> <span class="o">}</span> </span><span id="L-70"><a name="L-70"></a> </span><span id="L-71"><a name="L-71"></a> <span class="cm">/*</span> </span><span id="L-72"><a name="L-72"></a><span class="cm"> This is how you initialize the manager, just use Debug.create(this.stage) in the main class</span> </span><span id="L-73"><a name="L-73"></a><span class="cm"> */</span> </span><span id="L-74"><a name="L-74"></a> <span class="kd">public</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">create</span><span class="o">(</span><span class="n">stage</span><span class="o">:</span><span class="kt">Stage</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-75"><a name="L-75"></a> <span class="k">if</span><span class="o">(!</span><span class="n">_created</span><span class="o">){</span> </span><span id="L-76"><a name="L-76"></a> <span class="n">_created</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-77"><a name="L-77"></a> <span class="n">_stage</span> <span class="o">=</span> <span class="n">stage</span><span class="o">;</span> </span><span id="L-78"><a name="L-78"></a> <span class="n">_time</span> <span class="o">=</span> <span class="nf">getTimer</span><span class="o">();</span> </span><span id="L-79"><a name="L-79"></a> </span><span id="L-80"><a name="L-80"></a> <span class="n">createDebug</span><span class="o">();</span> </span><span id="L-81"><a name="L-81"></a> </span><span id="L-82"><a name="L-82"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">_debug</span><span class="o">);</span> </span><span id="L-83"><a name="L-83"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">_debug</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="mi">5</span><span class="o">;</span> </span><span id="L-84"><a name="L-84"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">Event</span><span class="o">.</span><span class="na">ADDED</span><span class="o">,</span> <span class="n">popDebug</span><span class="o">,</span> <span class="kc">false</span><span class="o">,</span> <span class="mi">0</span><span class="o">,</span> <span class="kc">true</span><span class="o">);</span> </span><span id="L-85"><a name="L-85"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">Event</span><span class="o">.</span><span class="na">ENTER_FRAME</span><span class="o">,</span> <span class="n">update</span><span class="o">);</span> </span><span id="L-86"><a name="L-86"></a> <span class="o">}</span> <span class="k">else</span> <span class="o">{</span> </span><span id="L-87"><a name="L-87"></a> <span class="n">Debug</span><span class="o">.</span><span class="na">error</span><span class="o">(</span><span class="s2">&quot;DebugPanel is already created!&quot;</span><span class="o">);</span> </span><span id="L-88"><a name="L-88"></a> <span class="o">}</span> </span><span id="L-89"><a name="L-89"></a> <span class="o">}</span> </span><span id="L-90"><a name="L-90"></a> </span><span id="L-91"><a name="L-91"></a> <span class="cm">/*</span> </span><span id="L-92"><a name="L-92"></a><span class="cm"> Outputs message on the screen </span> </span><span id="L-93"><a name="L-93"></a><span class="cm"> */</span> </span><span id="L-94"><a name="L-94"></a> <span class="kd">public</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">log</span><span class="o">(</span><span class="n">message</span><span class="o">:</span><span class="kt">String</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-95"><a name="L-95"></a> <span class="n">grawl</span><span class="o">(</span><span class="s2">&quot;log&quot;</span><span class="o">,</span> <span class="n">message</span><span class="o">);</span> </span><span id="L-96"><a name="L-96"></a> <span class="o">}</span> </span><span id="L-97"><a name="L-97"></a> </span><span id="L-98"><a name="L-98"></a> <span class="cm">/*</span> </span><span id="L-99"><a name="L-99"></a><span class="cm"> Outputs error on the screen</span> </span><span id="L-100"><a name="L-100"></a><span class="cm"> */</span> </span><span id="L-101"><a name="L-101"></a> <span class="kd">public</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">error</span><span class="o">(</span><span class="n">message</span><span class="o">:</span><span class="kt">String</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-102"><a name="L-102"></a> <span class="n">grawl</span><span class="o">(</span><span class="s2">&quot;error&quot;</span><span class="o">,</span> <span class="n">message</span><span class="o">);</span> </span><span id="L-103"><a name="L-103"></a> <span class="o">}</span> </span><span id="L-104"><a name="L-104"></a> </span><span id="L-105"><a name="L-105"></a> <span class="kd">public</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">addButton</span><span class="o">(</span><span class="n">name</span><span class="o">:</span><span class="kt">String</span><span class="o">,</span> <span class="n">onClick</span><span class="o">:</span><span class="kt">Function</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-106"><a name="L-106"></a> <span class="kd">var</span> <span class="n">btn</span><span class="p">:</span><span class="kt">Sprite</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">Sprite</span><span class="o">();</span> </span><span id="L-107"><a name="L-107"></a> </span><span id="L-108"><a name="L-108"></a> <span class="kd">var</span> <span class="n">format</span><span class="p">:</span><span class="kt">TextFormat</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextFormat</span><span class="o">();</span> </span><span id="L-109"><a name="L-109"></a> <span class="n">format</span><span class="o">.</span><span class="na">align</span> <span class="o">=</span> <span class="n">TextFormatAlign</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-110"><a name="L-110"></a> <span class="n">format</span><span class="o">.</span><span class="na">color</span> <span class="o">=</span> <span class="mi">0</span><span class="n">xFFFFFF</span><span class="o">;</span> </span><span id="L-111"><a name="L-111"></a> <span class="n">format</span><span class="o">.</span><span class="na">font</span> <span class="o">=</span> <span class="s2">&quot;Helvetica&quot;</span><span class="o">;</span> </span><span id="L-112"><a name="L-112"></a> <span class="n">format</span><span class="o">.</span><span class="na">size</span> <span class="o">=</span> <span class="mi">12</span><span class="o">;</span> </span><span id="L-113"><a name="L-113"></a> </span><span id="L-114"><a name="L-114"></a> <span class="kd">var</span> <span class="n">label</span><span class="p">:</span><span class="kt">TextField</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextField</span><span class="o">();</span> </span><span id="L-115"><a name="L-115"></a> <span class="n">label</span><span class="o">.</span><span class="na">autoSize</span> <span class="o">=</span> <span class="n">TextFieldAutoSize</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-116"><a name="L-116"></a> <span class="n">label</span><span class="o">.</span><span class="na">embedFonts</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-117"><a name="L-117"></a> <span class="n">label</span><span class="o">.</span><span class="na">selectable</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-118"><a name="L-118"></a> <span class="n">label</span><span class="o">.</span><span class="na">defaultTextFormat</span> <span class="o">=</span> <span class="n">format</span><span class="o">;</span> </span><span id="L-119"><a name="L-119"></a> <span class="n">label</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">_debugText</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="mi">3</span><span class="o">;</span> </span><span id="L-120"><a name="L-120"></a> <span class="n">label</span><span class="o">.</span><span class="na">text</span> <span class="o">=</span> <span class="n">name</span><span class="o">;</span> </span><span id="L-121"><a name="L-121"></a> </span><span id="L-122"><a name="L-122"></a> <span class="n">btn</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">beginFill</span><span class="o">(</span><span class="mh">0x000000</span><span class="o">,</span> <span class="mi">1</span><span class="o">);</span> </span><span id="L-123"><a name="L-123"></a> <span class="n">btn</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">drawRoundRect</span><span class="o">(</span><span class="mi">0</span><span class="o">,</span><span class="mi">0</span><span class="o">,</span><span class="n">label</span><span class="o">.</span><span class="na">textWidth</span> <span class="o">+</span> <span class="mi">12</span><span class="o">,</span><span class="mi">20</span><span class="o">,</span><span class="mi">10</span><span class="o">,</span><span class="mi">10</span><span class="o">);</span> </span><span id="L-124"><a name="L-124"></a> <span class="n">btn</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">endFill</span><span class="o">();</span> </span><span id="L-125"><a name="L-125"></a> <span class="n">btn</span><span class="o">.</span><span class="na">buttonMode</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-126"><a name="L-126"></a> <span class="n">btn</span><span class="o">.</span><span class="na">mouseChildren</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-127"><a name="L-127"></a> <span class="n">btn</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">label</span><span class="o">);</span> </span><span id="L-128"><a name="L-128"></a> <span class="n">label</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">label</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="mi">3</span><span class="o">;</span> </span><span id="L-129"><a name="L-129"></a> </span><span id="L-130"><a name="L-130"></a> <span class="n">btn</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">CLICK</span><span class="o">,</span> <span class="n">onClick</span><span class="o">);</span> </span><span id="L-131"><a name="L-131"></a> </span><span id="L-132"><a name="L-132"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">btn</span><span class="o">);</span> </span><span id="L-133"><a name="L-133"></a> <span class="n">btn</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">_debug</span><span class="o">.</span><span class="na">width</span> <span class="o">+</span> <span class="mi">2</span><span class="o">;</span> </span><span id="L-134"><a name="L-134"></a> </span><span id="L-135"><a name="L-135"></a> <span class="o">}</span> </span><span id="L-136"><a name="L-136"></a> </span><span id="L-137"><a name="L-137"></a> <span class="cm">/*</span> </span><span id="L-138"><a name="L-138"></a><span class="cm"> Internal function, creates the panel and the textfield</span> </span><span id="L-139"><a name="L-139"></a><span class="cm"> */</span> </span><span id="L-140"><a name="L-140"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">createDebug</span><span class="o">():</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-141"><a name="L-141"></a> <span class="n">_debug</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">Sprite</span><span class="o">();</span> </span><span id="L-142"><a name="L-142"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">beginFill</span><span class="o">(</span><span class="mh">0x000000</span><span class="o">,</span> <span class="mi">1</span><span class="o">);</span> </span><span id="L-143"><a name="L-143"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">drawRoundRect</span><span class="o">(</span><span class="mi">0</span><span class="o">,</span><span class="mi">0</span><span class="o">,</span><span class="mi">110</span><span class="o">,</span><span class="mi">20</span><span class="o">,</span><span class="mi">10</span><span class="o">,</span><span class="mi">10</span><span class="o">);</span> </span><span id="L-144"><a name="L-144"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">endFill</span><span class="o">();</span> </span><span id="L-145"><a name="L-145"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">mouseChildren</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-146"><a name="L-146"></a> </span><span id="L-147"><a name="L-147"></a> <span class="kd">var</span> <span class="n">format</span><span class="p">:</span><span class="kt">TextFormat</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextFormat</span><span class="o">();</span> </span><span id="L-148"><a name="L-148"></a> <span class="n">format</span><span class="o">.</span><span class="na">align</span> <span class="o">=</span> <span class="n">TextFormatAlign</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-149"><a name="L-149"></a> <span class="n">format</span><span class="o">.</span><span class="na">color</span> <span class="o">=</span> <span class="mi">0</span><span class="n">xFFFFFF</span><span class="o">;</span> </span><span id="L-150"><a name="L-150"></a> <span class="n">format</span><span class="o">.</span><span class="na">font</span> <span class="o">=</span> <span class="s2">&quot;Helvetica&quot;</span><span class="o">;</span> </span><span id="L-151"><a name="L-151"></a> <span class="n">format</span><span class="o">.</span><span class="na">size</span> <span class="o">=</span> <span class="mi">12</span><span class="o">;</span> </span><span id="L-152"><a name="L-152"></a> </span><span id="L-153"><a name="L-153"></a> <span class="n">_debugText</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextField</span><span class="o">();</span> </span><span id="L-154"><a name="L-154"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">autoSize</span> <span class="o">=</span> <span class="n">TextFieldAutoSize</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-155"><a name="L-155"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">embedFonts</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-156"><a name="L-156"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">selectable</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-157"><a name="L-157"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">defaultTextFormat</span> <span class="o">=</span> <span class="n">format</span><span class="o">;</span> </span><span id="L-158"><a name="L-158"></a> </span><span id="L-159"><a name="L-159"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">_debugText</span><span class="o">);</span> </span><span id="L-160"><a name="L-160"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">_debugText</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="mi">3</span><span class="o">;</span> </span><span id="L-161"><a name="L-161"></a> </span><span id="L-162"><a name="L-162"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">text</span> <span class="o">=</span> <span class="s2">&quot;&quot;</span><span class="o">;</span> </span><span id="L-163"><a name="L-163"></a> </span><span id="L-164"><a name="L-164"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">ROLL_OVER</span><span class="o">,</span> <span class="n">onDebugOver</span><span class="o">,</span> <span class="kc">false</span><span class="o">,</span> <span class="mi">0</span><span class="o">,</span> <span class="kc">true</span><span class="o">);</span> </span><span id="L-165"><a name="L-165"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">ROLL_OUT</span><span class="o">,</span> <span class="n">onDebugOut</span><span class="o">,</span> <span class="kc">false</span><span class="o">,</span> <span class="mi">0</span><span class="o">,</span> <span class="kc">true</span><span class="o">);</span> </span><span id="L-166"><a name="L-166"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">addEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">CLICK</span><span class="o">,</span> <span class="n">onDebugClick</span><span class="o">,</span> <span class="kc">false</span><span class="o">,</span> <span class="mi">0</span><span class="o">,</span> <span class="kc">true</span><span class="o">);</span> </span><span id="L-167"><a name="L-167"></a> <span class="o">}</span> </span><span id="L-168"><a name="L-168"></a> </span><span id="L-169"><a name="L-169"></a> </span><span id="L-170"><a name="L-170"></a> <span class="cm">/*</span> </span><span id="L-171"><a name="L-171"></a><span class="cm"> internal function called on every &quot;enterFrame&quot; event, calculates the memory and fps</span> </span><span id="L-172"><a name="L-172"></a><span class="cm"> */</span> </span><span id="L-173"><a name="L-173"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">update</span><span class="o">(</span><span class="n">event</span><span class="o">:</span><span class="kt">Event</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-174"><a name="L-174"></a> <span class="kd">var</span> <span class="n">memory</span><span class="p">:</span><span class="kt">Number</span> <span class="o">=</span> <span class="n">Number</span><span class="o">((</span><span class="n">System</span><span class="o">.</span><span class="na">totalMemory</span> <span class="sr">/ 1024 /</span> <span class="mi">1024</span><span class="o">).</span><span class="n">toFixed</span><span class="o">(</span><span class="mi">2</span><span class="o">));</span> </span><span id="L-175"><a name="L-175"></a> <span class="k">if</span><span class="o">(</span><span class="n">memory</span> <span class="o">&gt;</span> <span class="n">_maxMemory</span><span class="o">){</span> </span><span id="L-176"><a name="L-176"></a> <span class="n">_maxMemory</span> <span class="o">=</span> <span class="n">memory</span><span class="o">;</span> </span><span id="L-177"><a name="L-177"></a> <span class="o">}</span> </span><span id="L-178"><a name="L-178"></a> <span class="kd">var</span> <span class="n">fps</span><span class="p">:</span><span class="kt">Number</span> <span class="o">=</span> <span class="n">Number</span> <span class="o">(</span><span class="mi">1000</span> <span class="o">/</span> <span class="o">(</span><span class="nf">getTimer</span><span class="o">()</span> <span class="o">-</span> <span class="n">_time</span><span class="o">));</span> </span><span id="L-179"><a name="L-179"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">text</span> <span class="o">=</span> <span class="n">memory</span> <span class="o">+</span> <span class="s2">&quot; mb / &quot;</span> <span class="o">+</span> <span class="n">Math</span><span class="o">.</span><span class="na">ceil</span><span class="o">(</span><span class="n">fps</span><span class="o">)</span> <span class="o">+</span> <span class="s2">&quot; fps&quot;</span><span class="o">;</span> </span><span id="L-180"><a name="L-180"></a> <span class="n">_time</span> <span class="o">=</span> <span class="nf">getTimer</span><span class="o">();</span> </span><span id="L-181"><a name="L-181"></a> <span class="o">}</span> </span><span id="L-182"><a name="L-182"></a> </span><span id="L-183"><a name="L-183"></a> <span class="cm">/*</span> </span><span id="L-184"><a name="L-184"></a><span class="cm"> Internal function that actually creates the grawl</span> </span><span id="L-185"><a name="L-185"></a><span class="cm"> */</span> </span><span id="L-186"><a name="L-186"></a> </span><span id="L-187"><a name="L-187"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">grawl</span><span class="o">(</span><span class="n">type</span><span class="o">:</span><span class="kt">String</span><span class="o">,</span> <span class="n">text</span><span class="o">:</span><span class="kt">String</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-188"><a name="L-188"></a> <span class="kd">var</span> <span class="n">padding</span><span class="p">:</span><span class="kt">Number</span> <span class="o">=</span> <span class="mi">10</span><span class="o">;</span> </span><span id="L-189"><a name="L-189"></a> </span><span id="L-190"><a name="L-190"></a> <span class="kd">var</span> <span class="n">format</span><span class="p">:</span><span class="kt">TextFormat</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextFormat</span><span class="o">();</span> </span><span id="L-191"><a name="L-191"></a> <span class="n">format</span><span class="o">.</span><span class="na">align</span> <span class="o">=</span> <span class="n">TextFormatAlign</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-192"><a name="L-192"></a> <span class="n">format</span><span class="o">.</span><span class="na">color</span> <span class="o">=</span> <span class="n">type</span> <span class="o">==</span> <span class="s2">&quot;log&quot;</span> <span class="o">?</span> <span class="mi">0</span><span class="n">xFFFFFF</span> <span class="o">:</span> <span class="mh">0x000000</span><span class="o">;</span> </span><span id="L-193"><a name="L-193"></a> <span class="n">format</span><span class="o">.</span><span class="na">font</span> <span class="o">=</span> <span class="s2">&quot;Helvetica&quot;</span><span class="o">;</span> </span><span id="L-194"><a name="L-194"></a> <span class="n">format</span><span class="o">.</span><span class="na">size</span> <span class="o">=</span> <span class="mi">14</span><span class="o">;</span> </span><span id="L-195"><a name="L-195"></a> </span><span id="L-196"><a name="L-196"></a> <span class="kd">var</span> <span class="n">grawlText</span><span class="p">:</span><span class="kt">TextField</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">TextField</span><span class="o">();</span> </span><span id="L-197"><a name="L-197"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">width</span> <span class="o">=</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">grawlTextWidth</span><span class="o">;</span> </span><span id="L-198"><a name="L-198"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">multiline</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-199"><a name="L-199"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">wordWrap</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-200"><a name="L-200"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">autoSize</span> <span class="o">=</span> <span class="n">TextFieldAutoSize</span><span class="o">.</span><span class="na">LEFT</span><span class="o">;</span> </span><span id="L-201"><a name="L-201"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">embedFonts</span> <span class="o">=</span> <span class="kc">false</span><span class="o">;</span> </span><span id="L-202"><a name="L-202"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">selectable</span> <span class="o">=</span> <span class="kc">true</span><span class="o">;</span> </span><span id="L-203"><a name="L-203"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">defaultTextFormat</span> <span class="o">=</span> <span class="n">format</span><span class="o">;</span> </span><span id="L-204"><a name="L-204"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">text</span> <span class="o">=</span> <span class="n">text</span><span class="o">;</span> </span><span id="L-205"><a name="L-205"></a> </span><span id="L-206"><a name="L-206"></a> <span class="kd">var</span> <span class="n">bg</span><span class="p">:</span><span class="kt">Sprite</span> <span class="o">=</span> <span class="k">new</span> <span class="kt">Sprite</span><span class="o">();</span> </span><span id="L-207"><a name="L-207"></a> <span class="kd">var</span> <span class="n">bgColor</span><span class="p">:</span><span class="kt">uint</span> <span class="o">=</span> <span class="n">type</span> <span class="o">==</span> <span class="s2">&quot;log&quot;</span> <span class="o">?</span> <span class="mh">0x000000</span> <span class="o">:</span> <span class="mi">0</span><span class="n">xFF0000</span><span class="o">;</span> </span><span id="L-208"><a name="L-208"></a> <span class="n">bg</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">beginFill</span><span class="o">(</span><span class="n">bgColor</span><span class="o">,</span> <span class="mi">1</span><span class="o">);</span> </span><span id="L-209"><a name="L-209"></a> <span class="n">bg</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">drawRoundRect</span><span class="o">(</span><span class="mi">0</span><span class="o">,</span><span class="mi">0</span><span class="o">,</span> <span class="n">grawlText</span><span class="o">.</span><span class="na">width</span> <span class="o">+</span> <span class="n">padding</span><span class="o">*</span><span class="mi">2</span><span class="o">,</span> <span class="n">grawlText</span><span class="o">.</span><span class="na">height</span> <span class="o">+</span> <span class="n">padding</span><span class="o">*</span><span class="mi">2</span><span class="o">,</span> <span class="mi">10</span><span class="o">,</span><span class="mi">10</span><span class="o">);</span> </span><span id="L-210"><a name="L-210"></a> <span class="n">bg</span><span class="o">.</span><span class="na">graphics</span><span class="o">.</span><span class="na">endFill</span><span class="o">();</span> </span><span id="L-211"><a name="L-211"></a> <span class="n">bg</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">grawlText</span><span class="o">);</span> </span><span id="L-212"><a name="L-212"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">padding</span><span class="o">;</span> </span><span id="L-213"><a name="L-213"></a> <span class="n">grawlText</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="n">padding</span><span class="o">;</span> </span><span id="L-214"><a name="L-214"></a> </span><span id="L-215"><a name="L-215"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">addChild</span><span class="o">(</span><span class="n">bg</span><span class="o">);</span> </span><span id="L-216"><a name="L-216"></a> <span class="n">bg</span><span class="o">.</span><span class="na">alpha</span> <span class="o">=</span> <span class="mi">0</span><span class="o">;</span> </span><span id="L-217"><a name="L-217"></a> <span class="n">bg</span><span class="o">.</span><span class="na">x</span> <span class="o">=</span> <span class="n">_stage</span><span class="o">.</span><span class="na">stageWidth</span> <span class="o">-</span> <span class="n">bg</span><span class="o">.</span><span class="na">width</span> <span class="o">-</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">padding</span><span class="o">;</span> </span><span id="L-218"><a name="L-218"></a> <span class="n">bg</span><span class="o">.</span><span class="na">y</span> <span class="o">=</span> <span class="n">_stage</span><span class="o">.</span><span class="na">stageHeight</span> <span class="o">-</span> <span class="n">bg</span><span class="o">.</span><span class="na">height</span> <span class="o">-</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">padding</span> <span class="o">-</span> <span class="n">_grawlHeight</span><span class="o">;</span> </span><span id="L-219"><a name="L-219"></a> <span class="n">_grawlHeight</span> <span class="o">+=</span> <span class="n">bg</span><span class="o">.</span><span class="na">height</span> <span class="o">+</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">padding</span><span class="o">;</span> </span><span id="L-220"><a name="L-220"></a> <span class="n">TweenLite</span><span class="o">.</span><span class="na">to</span><span class="o">(</span><span class="n">bg</span><span class="o">,</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">openTime</span><span class="o">,</span> <span class="o">{</span><span class="n">alpha</span><span class="o">:</span> <span class="mf">0.9</span><span class="o">});</span> </span><span id="L-221"><a name="L-221"></a> <span class="n">TweenLite</span><span class="o">.</span><span class="na">delayedCall</span><span class="o">(</span><span class="n">_grawlOptions</span><span class="o">.</span><span class="na">stayTime</span><span class="o">,</span> <span class="kd">function</span><span class="o">():</span><span class="kc">void</span><span class="o">{</span> </span><span id="L-222"><a name="L-222"></a> <span class="n">TweenLite</span><span class="o">.</span><span class="na">to</span><span class="o">(</span><span class="n">bg</span><span class="o">,</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">closeTime</span><span class="o">,</span> <span class="o">{</span><span class="n">alpha</span><span class="o">:</span><span class="mi">0</span><span class="o">,</span> <span class="n">onComplete</span><span class="o">:</span><span class="kd">function</span><span class="o">():</span><span class="kc">void</span><span class="o">{</span> </span><span id="L-223"><a name="L-223"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">removeChild</span><span class="o">(</span><span class="n">bg</span><span class="o">);</span> </span><span id="L-224"><a name="L-224"></a> <span class="n">_grawlHeight</span> <span class="o">-=</span> <span class="n">bg</span><span class="o">.</span><span class="na">height</span> <span class="o">+</span> <span class="n">_grawlOptions</span><span class="o">.</span><span class="na">padding</span><span class="o">;</span> </span><span id="L-225"><a name="L-225"></a> <span class="o">}})</span> </span><span id="L-226"><a name="L-226"></a> <span class="o">});</span> </span><span id="L-227"><a name="L-227"></a> </span><span id="L-228"><a name="L-228"></a> <span class="o">}</span> </span><span id="L-229"><a name="L-229"></a> </span><span id="L-230"><a name="L-230"></a> <span class="cm">/*</span> </span><span id="L-231"><a name="L-231"></a><span class="cm"> Tween when you roll over the panel</span> </span><span id="L-232"><a name="L-232"></a><span class="cm"> */</span> </span><span id="L-233"><a name="L-233"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">onDebugOver</span><span class="o">(</span><span class="n">event</span><span class="o">:</span><span class="kt">MouseEvent</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-234"><a name="L-234"></a> <span class="n">TweenLite</span><span class="o">.</span><span class="na">to</span><span class="o">(</span><span class="n">_debug</span><span class="o">,</span> <span class="mf">0.5</span><span class="o">,</span> <span class="o">{</span><span class="n">alpha</span><span class="o">:</span> <span class="mi">1</span><span class="o">});</span> </span><span id="L-235"><a name="L-235"></a> <span class="o">}</span> </span><span id="L-236"><a name="L-236"></a> </span><span id="L-237"><a name="L-237"></a> <span class="cm">/*</span> </span><span id="L-238"><a name="L-238"></a><span class="cm"> Tween when you roll out the panel</span> </span><span id="L-239"><a name="L-239"></a><span class="cm"> */</span> </span><span id="L-240"><a name="L-240"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">onDebugOut</span><span class="o">(</span><span class="n">event</span><span class="o">:</span><span class="kt">MouseEvent</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-241"><a name="L-241"></a> <span class="n">TweenLite</span><span class="o">.</span><span class="na">to</span><span class="o">(</span><span class="n">_debug</span><span class="o">,</span> <span class="mf">0.5</span><span class="o">,</span> <span class="o">{</span><span class="n">alpha</span><span class="o">:</span> <span class="mf">0.5</span><span class="o">});</span> </span><span id="L-242"><a name="L-242"></a> <span class="o">}</span> </span><span id="L-243"><a name="L-243"></a> </span><span id="L-244"><a name="L-244"></a> <span class="cm">/*</span> </span><span id="L-245"><a name="L-245"></a><span class="cm"> Shows the current memory, maximum memory and fps</span> </span><span id="L-246"><a name="L-246"></a><span class="cm"> */</span> </span><span id="L-247"><a name="L-247"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">onDebugClick</span><span class="o">(</span><span class="n">event</span><span class="o">:</span><span class="kt">MouseEvent</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-248"><a name="L-248"></a> <span class="n">log</span><span class="o">(</span><span class="s2">&quot;[Memory] : &quot;</span> <span class="o">+</span> <span class="n">Number</span><span class="o">((</span><span class="n">System</span><span class="o">.</span><span class="na">totalMemory</span> <span class="sr">/ 1024 / 1024).toFixed(2)) + &quot; max: &quot; + _maxMemory + &quot; free: &quot; + Number((System.freeMemory / 1024 /</span> <span class="mi">1024</span><span class="o">).</span><span class="n">toFixed</span><span class="o">(</span><span class="mi">2</span><span class="o">))</span> </span><span id="L-249"><a name="L-249"></a> <span class="o">+</span> <span class="s2">&quot;\n&quot;</span> </span><span id="L-250"><a name="L-250"></a> <span class="o">+</span> <span class="s2">&quot;[Stage ] : width: &quot;</span> <span class="o">+</span> <span class="n">_stage</span><span class="o">.</span><span class="na">stageWidth</span> <span class="o">+</span> <span class="s2">&quot; height: &quot;</span> <span class="o">+</span> <span class="n">_stage</span><span class="o">.</span><span class="na">stageHeight</span><span class="o">)</span> </span><span id="L-251"><a name="L-251"></a> <span class="c1">// you can extend this with custom vars, you wanna output</span> </span><span id="L-252"><a name="L-252"></a> <span class="o">}</span> </span><span id="L-253"><a name="L-253"></a> </span><span id="L-254"><a name="L-254"></a> <span class="cm">/*</span> </span><span id="L-255"><a name="L-255"></a><span class="cm"> internal function , sets the panel on the top of stages display list</span> </span><span id="L-256"><a name="L-256"></a><span class="cm"> */</span> </span><span id="L-257"><a name="L-257"></a> <span class="kd">private</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">popDebug</span><span class="o">(</span><span class="n">event</span><span class="o">:</span><span class="kt">Event</span><span class="o">):</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-258"><a name="L-258"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">setChildIndex</span><span class="o">(</span><span class="n">_debug</span><span class="o">,</span> <span class="n">_stage</span><span class="o">.</span><span class="na">numChildren</span><span class="o">-</span><span class="mi">1</span><span class="o">);</span> </span><span id="L-259"><a name="L-259"></a> <span class="o">}</span> </span><span id="L-260"><a name="L-260"></a> </span><span id="L-261"><a name="L-261"></a> <span class="c1">//////////////////////////// DESTROY //////////////////////////////////////////////</span> </span><span id="L-262"><a name="L-262"></a> </span><span id="L-263"><a name="L-263"></a> <span class="cm">/*</span> </span><span id="L-264"><a name="L-264"></a><span class="cm"> Destroys the manager</span> </span><span id="L-265"><a name="L-265"></a><span class="cm"> */</span> </span><span id="L-266"><a name="L-266"></a> </span><span id="L-267"><a name="L-267"></a> <span class="kd">public</span> <span class="kd">static</span> <span class="kd">function </span><span class="nf">destroy</span><span class="o">():</span><span class="kt">void</span><span class="o">{</span> </span><span id="L-268"><a name="L-268"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">removeEventListener</span><span class="o">(</span><span class="n">Event</span><span class="o">.</span><span class="na">ADDED</span><span class="o">,</span> <span class="n">popDebug</span><span class="o">);</span> </span><span id="L-269"><a name="L-269"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">removeEventListener</span><span class="o">(</span><span class="n">Event</span><span class="o">.</span><span class="na">ENTER_FRAME</span><span class="o">,</span> <span class="n">update</span><span class="o">)</span> </span><span id="L-270"><a name="L-270"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">removeEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">ROLL_OVER</span><span class="o">,</span> <span class="n">onDebugOver</span><span class="o">);</span> </span><span id="L-271"><a name="L-271"></a> <span class="n">_debug</span><span class="o">.</span><span class="na">removeEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">ROLL_OUT</span><span class="o">,</span> <span class="n">onDebugOut</span><span class="o">);</span> </span><span id="L-272"><a name="L-272"></a> <span class="n">_debugText</span><span class="o">.</span><span class="na">removeEventListener</span><span class="o">(</span><span class="n">MouseEvent</span><span class="o">.</span><span class="na">CLICK</span><span class="o">,</span> <span class="n">onDebugClick</span><span class="o">);</span> </span><span id="L-273"><a name="L-273"></a> </span><span id="L-274"><a name="L-274"></a> <span class="n">_stage</span><span class="o">.</span><span class="na">removeChild</span><span class="o">(</span><span class="n">_debug</span><span class="o">);</span> </span><span id="L-275"><a name="L-275"></a> <span class="n">System</span><span class="o">.</span><span class="na">gc</span><span class="o">();</span> </span><span id="L-276"><a name="L-276"></a> <span class="o">}</span> </span><span id="L-277"><a name="L-277"></a> </span><span id="L-278"><a name="L-278"></a> <span class="o">}//</span><span class="n">end</span> </span><span id="L-279"><a name="L-279"></a><span class="o">}</span> </span></pre></div> </td></tr></table>
grawl, log, memory, trace