Upgrade to ExtJS 4.0.0 - Released 04/26/2011
[extjs.git] / docs / api / Ext.draw.Surface.html
1 <!DOCTYPE html><html><head><title>Ext.draw.Surface | Ext JS 4.0 Documentation</title><script type="text/javascript" src="../ext-all.js"></script><link rel="stylesheet" href="../reset.css" type="text/css"><link rel="stylesheet" href="../scrollbars.css" type="text/css"><link rel="stylesheet" href="../docs.css" type="text/css"><link id="styleCss" rel="stylesheet" href="../style.css" type="text/css"><script type="text/javascript" src="../prettify.js"></script><link rel="stylesheet" href="../prettify.css" type="text/css"><!-- link(rel: 'stylesheet', href: req.baseURL + '/css/ext4.css', type: 'text/css')--><link rel="shortcut icon" type="image/ico" href="../favicon.ico"><!--[if IE]>
2 <style type="text/css">.head-band { display: none; }
3 .header { border: 0; top: 0; left: 0px; background: url(../header.gif) repeat-x; }
4 .doc-tab .members .member a.more { background-color: #efefef; }
5 </style><link rel="stylesheet" href="/new/css/ie.css" type="text/css"><![endif]-->
6 </head><body id="ext-body" class="iScroll"><div id="notice" class="notice">For up to date documentation and features, visit 
7 <a href="http://docs.sencha.com/ext-js/4-0">http://docs.sencha.com/ext-js/4-0</a></div><div class="wrapper"><div class="head-band"></div><div class="header"><h2><a href="../index.html">Sencha Documentation</a></h2></div><div id="search"><form><input type="text" placeholder="Search" id="search-field" autocomplete="off" name="q"></form><div id="search-box"></div></div><div id="treePanel"></div><div id="container"><script type="text/javascript">
8
9     req = {
10         liveURL: '.',
11         standAloneMode: true,
12         origDocClass: 'Ext.draw.Surface',
13         docClass: 'Ext.draw.Surface',
14         docReq: 'Ext.draw.Surface',
15         version: '4.0',
16         baseURL: '.',
17         baseDocURL: '.',
18         baseProdURL: '.'
19     };
20
21     clsInfo = {};
22
23
24
25 </script>
26
27 <script type="text/javascript" src="../search.js"></script>
28 <!--script type="text/javascript" src="/new/javascripts/app/examples.js"></script-->
29 <script type="text/javascript" src="../class_tree.js"></script>
30 <script type="text/javascript" src="../class_doc.js"></script>
31 <script type="text/javascript">
32     req.source = 'Surface.html#Ext-draw.Surface';
33     clsInfo = {"methods":["add","addEvents","addListener","addManagedListener","capture","clearListeners","clearManagedListeners","create","destroy","enableBubble","fireEvent","getGroup","getId","hasListener","observe","on","relayEvents","releaseCapture","remove","removeAll","removeListener","removeManagedListener","resumeEvents","setSize","suspendEvents","un"],"cfgs":["height","listeners","width"],"properties":["addCls","addGradient","removeCls","setStyle","setText"],"events":[],"subclasses":["Ext.draw.engine.Svg","Ext.draw.engine.Vml"]};
34     Ext.onReady(function() {
35         Ext.create('Docs.classPanel');
36     });
37 </script><div id="top-block" class="top-block"><h1 id="clsTitle" class="cls"><a href="../source/Surface.html#Ext-draw.Surface" target="_blank">Ext.draw.Surface</a></h1></div><div id="docContent"><div id="doc-overview-content"><div class="lft"><pre class="subclasses"><h4>Mixins</h4><div class="mixin"><a href="Ext.util.Observable.html" rel="Ext.util.Observable" class="cls docClass">Ext.util.Observable</a></div></pre><p>A Surface is an interface to render methods inside a draw <a href="Ext.draw.Component.html" rel="Ext.draw.Component" class="docClass">Ext.draw.Component</a>.
38 A Surface contains methods to render sprites, get bounding boxes of sprites, add
39 sprites to the canvas, initialize other graphic components, etc. One of the most used
40 methods for this class is the <code>add</code> method, to add Sprites to the surface.</p>
41
42 <p>Most of the Surface methods are abstract and they have a concrete implementation
43 in VML or SVG engines.</p>
44
45 <p>A Surface instance can be accessed as a property of a draw component. For example:</p>
46
47 <pre class="prettyprint"><code>drawComponent.surface.add({
48     type: 'circle',
49     fill: '#ffc',
50     radius: 100,
51     x: 100,
52     y: 100
53 });
54 </code></pre>
55
56 <p>The configuration object passed in the <code>add</code> method is the same as described in the <a href="Ext.draw.Sprite.html" rel="Ext.draw.Sprite" class="docClass">Ext.draw.Sprite</a>
57 class documentation.</p>
58
59 <h3>Listeners</h3>
60
61 <p>You can also add event listeners to the surface using the <code>Observable</code> listener syntax. Supported events are:</p>
62
63 <ul>
64 <li>mousedown</li>
65 <li>mouseup</li>
66 <li>mouseover</li>
67 <li>mouseout</li>
68 <li>mousemove</li>
69 <li>mouseenter</li>
70 <li>mouseleave</li>
71 <li>click</li>
72 </ul>
73
74
75 <p>For example:</p>
76
77 <pre class="prettyprint"><code>    drawComponent.surface.on({
78        'mousemove': function() {
79             console.log('moving the mouse over the surface');   
80         }
81     });
82 </code></pre>
83 <div class="members"><div class="m-cfgs"><div class="definedBy">Defined By</div><a name="configs"></a><h3 class="cfg p">Config Options</h3><h4 class="cfgGroup">Other Configs</h4><div id="config-height" class="member f ni"><a href="Ext.draw.Surface.html#config-height" rel="config-height" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-cfg-height" class="viewSource">view source</a></div><a name="height"></a><a name="config-height"></a><a href="Ext.draw.Surface.html#" rel="config-height" class="cls expand">height</a><span> : Number</span></div><div class="description"><div class="short">The height of this component in pixels (defaults to auto).
84 Note to express this dimension as a percentage or offset s...</div><div class="long"><p>The height of this component in pixels (defaults to auto).
85 <b>Note</b> to express this dimension as a percentage or offset see <a href="Ext.Component.html#anchor" rel="Ext.Component#anchor" class="docClass">Ext.Component.anchor</a>.</p>
86 </div></div></div><div id="config-listeners" class="member inherited"><a href="Ext.draw.Surface.html#config-listeners" rel="config-listeners" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-cfg-listeners" class="viewSource">view source</a></div><a name="listeners"></a><a name="config-listeners"></a><a href="Ext.draw.Surface.html#" rel="config-listeners" class="cls expand">listeners</a><span> : Object</span></div><div class="description"><div class="short">(optional) A config object containing one or more event handlers to be added to this
87 object during initialization.  T...</div><div class="long"><p>(optional) <p>A config object containing one or more event handlers to be added to this
88 object during initialization.  This should be a valid listeners config object as specified in the
89 <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a> example for attaching multiple handlers at once.</p></p>
90
91 <br><p><b><u>DOM events from ExtJs <a href="Ext.Component.html" rel="Ext.Component" class="docClass">Components</a></u></b></p>
92
93
94 <br><p>While <i>some</i> ExtJs Component classes export selected DOM events (e.g. "click", "mouseover" etc), this
95
96
97 <p>is usually only done when extra value can be added. For example the <a href="Ext.view.View.html" rel="Ext.view.View" class="docClass">DataView</a>'s
98 <b><code><a href="Ext.view.View.html#click" rel="Ext.view.View#click" class="docClass">click</a></code></b> event passing the node clicked on. To access DOM
99 events directly from a child element of a Component, we need to specify the <code>element</code> option to
100 identify the Component property to add a DOM listener to:</p>
101
102 <pre><code>new Ext.panel.Panel({
103     width: 400,
104     height: 200,
105     dockedItems: [{
106         xtype: 'toolbar'
107     }],
108     listeners: {
109         click: {
110             element: 'el', //bind to the underlying el property on the panel
111             fn: function(){ console.log('click el'); }
112         },
113         dblclick: {
114             element: 'body', //bind to the underlying body property on the panel
115             fn: function(){ console.log('dblclick body'); }
116         }
117     }
118 });
119 </code></pre>
120
121
122 <p></p></p>
123 </div></div></div><div id="config-width" class="member ni"><a href="Ext.draw.Surface.html#config-width" rel="config-width" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-cfg-width" class="viewSource">view source</a></div><a name="width"></a><a name="config-width"></a><a href="Ext.draw.Surface.html#" rel="config-width" class="cls expand">width</a><span> : Number</span></div><div class="description"><div class="short">The width of this component in pixels (defaults to auto).
124 Note to express this dimension as a percentage or offset se...</div><div class="long"><p>The width of this component in pixels (defaults to auto).
125 <b>Note</b> to express this dimension as a percentage or offset see <a href="Ext.Component.html#anchor" rel="Ext.Component#anchor" class="docClass">Ext.Component.anchor</a>.</p>
126 </div></div></div></div><div class="m-properties"><a name="properties"></a><div class="definedBy">Defined By</div><h3 class="prp p">Properties</h3><div id="property-addCls" class="member f ni"><a href="Ext.draw.Surface.html#property-addCls" rel="property-addCls" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-property-addCls" class="viewSource">view source</a></div><a name="addCls"></a><a name="property-addCls"></a><a href="Ext.draw.Surface.html#" rel="property-addCls" class="cls expand">addCls</a><span> : Object</span></div><div class="description"><div class="short">Adds one or more CSS classes to the element. Duplicate classes are automatically filtered out.
127
128 For example:
129
130      dr...</div><div class="long"><p>Adds one or more CSS classes to the element. Duplicate classes are automatically filtered out.</p>
131
132 <p>For example:</p>
133
134 <pre><code>     drawComponent.surface.addCls(sprite, 'x-visible');
135 </code></pre>
136 </div></div></div><div id="property-addGradient" class="member ni"><a href="Ext.draw.Surface.html#property-addGradient" rel="property-addGradient" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-property-addGradient" class="viewSource">view source</a></div><a name="addGradient"></a><a name="property-addGradient"></a><a href="Ext.draw.Surface.html#" rel="property-addGradient" class="cls expand">addGradient</a><span> : Object</span></div><div class="description"><div class="short">Add a gradient definition to the Surface. Note that in some surface engines, adding
137 a gradient via this method will n...</div><div class="long"><p>Add a gradient definition to the Surface. Note that in some surface engines, adding
138 a gradient via this method will not take effect if the surface has already been rendered.
139 Therefore, it is preferred to pass the gradients as an item to the surface config, rather
140 than calling this method, especially if the surface is rendered immediately (e.g. due to
141 'renderTo' in its config). For more information on how to create gradients in the Chart
142 configuration object please refer to <a href="Ext.chart.Chart.html" rel="Ext.chart.Chart" class="docClass">Ext.chart.Chart</a>.</p>
143
144 <p>The gradient object to be passed into this method is composed by:</p>
145
146 <ul>
147 <li><strong>id</strong> - string - The unique name of the gradient.</li>
148 <li><strong>angle</strong> - number, optional - The angle of the gradient in degrees.</li>
149 <li><p><strong>stops</strong> - object - An object with numbers as keys (from 0 to 100) and style objects as values.</p>
150
151 <p>  For example:</p>
152
153 <pre><code>         drawComponent.surface.addGradient({
154              id: 'gradientId',
155              angle: 45,
156              stops: {
157                  0: {
158                      color: '#555'
159                  },
160                  100: {
161                      color: '#ddd'
162                  }
163              }
164          });
165 </code></pre></li>
166 </ul>
167
168 </div></div></div><div id="property-removeCls" class="member ni"><a href="Ext.draw.Surface.html#property-removeCls" rel="property-removeCls" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-property-removeCls" class="viewSource">view source</a></div><a name="removeCls"></a><a name="property-removeCls"></a><a href="Ext.draw.Surface.html#" rel="property-removeCls" class="cls expand">removeCls</a><span> : Object</span></div><div class="description"><div class="short">Removes one or more CSS classes from the element.
169
170 For example:
171
172  drawComponent.surface.removeCls(sprite, 'x-visible'...</div><div class="long"><p>Removes one or more CSS classes from the element.</p>
173
174 <p>For example:</p>
175
176 <pre><code> drawComponent.surface.removeCls(sprite, 'x-visible');
177 </code></pre>
178 </div></div></div><div id="property-setStyle" class="member ni"><a href="Ext.draw.Surface.html#property-setStyle" rel="property-setStyle" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-property-setStyle" class="viewSource">view source</a></div><a name="setStyle"></a><a name="property-setStyle"></a><a href="Ext.draw.Surface.html#" rel="property-setStyle" class="cls expand">setStyle</a><span> : Object</span></div><div class="description"><div class="short">Sets CSS style attributes to an element.
179
180 For example:
181
182  drawComponent.surface.setStyle(sprite, {
183      'cursor': 'poi...</div><div class="long"><p>Sets CSS style attributes to an element.</p>
184
185 <p>For example:</p>
186
187 <pre><code> drawComponent.surface.setStyle(sprite, {
188      'cursor': 'pointer'
189  });
190 </code></pre>
191 </div></div></div><div id="property-setText" class="member ni"><a href="Ext.draw.Surface.html#property-setText" rel="property-setText" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-property-setText" class="viewSource">view source</a></div><a name="setText"></a><a name="property-setText"></a><a href="Ext.draw.Surface.html#" rel="property-setText" class="cls expand">setText</a><span> : Object</span></div><div class="description"><div class="short">Changes the text in the sprite element. The sprite must be a text sprite.
192 This method can also be called from Ext.dra...</div><div class="long"><p>Changes the text in the sprite element. The sprite must be a <code>text</code> sprite.
193 This method can also be called from <a href="Ext.draw.Sprite.html" rel="Ext.draw.Sprite" class="docClass">Ext.draw.Sprite</a>.</p>
194
195 <p>For example:</p>
196
197 <pre><code> var spriteGroup = drawComponent.surface.setText(sprite, 'my new text');
198 </code></pre>
199 </div></div></div></div><div class="m-methods"><a name="methods"></a><div class="definedBy">Defined By</div><h3 class="mth p">Methods</h3><div id="method-add" class="member f ni"><a href="Ext.draw.Surface.html#method-add" rel="method-add" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-add" class="viewSource">view source</a></div><a name="add"></a><a name="method-add"></a><a href="Ext.draw.Surface.html#" rel="method-add" class="cls expand">add</a> : void</div><div class="description"><div class="short">Add a Sprite to the surface. See Ext.draw.Sprite for the configuration object to be passed into this method.
200
201 For exa...</div><div class="long"><p>Add a Sprite to the surface. See <a href="Ext.draw.Sprite.html" rel="Ext.draw.Sprite" class="docClass">Ext.draw.Sprite</a> for the configuration object to be passed into this method.</p>
202
203 <p>For example:</p>
204
205 <pre><code>drawComponent.surface.add({
206     type: 'circle',
207     fill: '#ffc',
208     radius: 100,
209     x: 100,
210     y: 100
211 });
212 </code></pre>
213 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
214 </li></ul></div></div></div><div id="method-addEvents" class="member inherited"><a href="Ext.draw.Surface.html#method-addEvents" rel="method-addEvents" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-addEvents" class="viewSource">view source</a></div><a name="addEvents"></a><a name="method-addEvents"></a><a href="Ext.draw.Surface.html#" rel="method-addEvents" class="cls expand">addEvents</a>(
215 <span class="pre">Object/String o, String </span>)
216  : void</div><div class="description"><div class="short"><p>Adds the specified events to the list of events which this Observable may fire.</p>
217 </div><div class="long"><p>Adds the specified events to the list of events which this Observable may fire.</p>
218 <h3 class="pa">Parameters</h3><ul><li><span class="pre">o</span> : Object/String<div class="sub-desc"><p>Either an object with event names as properties with a value of <code>true</code>
219 or the first event name string if multiple event names are being passed as separate parameters.</p>
220 </div></li><li><span class="pre"></span> : String<div class="sub-desc"><p>[additional] Optional additional event names if multiple event names are being passed as separate parameters.
221 Usage:</p>
222
223 <pre><code>this.addEvents('storeloaded', 'storecleared');
224 </code></pre>
225
226 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
227 </li></ul></div></div></div><div id="method-addListener" class="member inherited"><a href="Ext.draw.Surface.html#method-addListener" rel="method-addListener" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-addListener" class="viewSource">view source</a></div><a name="addListener"></a><a name="method-addListener"></a><a href="Ext.draw.Surface.html#" rel="method-addListener" class="cls expand">addListener</a>(
228 <span class="pre">String eventName, Function handler, [Object scope], [Object options]</span>)
229  : void</div><div class="description"><div class="short"><p>Appends an event handler to this object.</p>
230 </div><div class="long"><p>Appends an event handler to this object.</p>
231 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The name of the event to listen for. May also be an object who's property names are event names. See</p>
232 </div></li><li><span class="pre">handler</span> : Function<div class="sub-desc"><p>The method the event invokes.</p>
233 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>(optional) The scope (<code><b>this</b></code> reference) in which the handler function is executed.
234 <b>If omitted, defaults to the object which fired the event.</b></p>
235 </div></li><li><span class="pre">options</span> : Object<div class="sub-desc"><p>(optional) An object containing handler configuration.
236 properties. This may contain any of the following properties:<ul>
237 <li><b>scope</b> : Object<div class="sub-desc">The scope (<code><b>this</b></code> reference) in which the handler function is executed.
238 <b>If omitted, defaults to the object which fired the event.</b></div></li>
239 <li><b>delay</b> : Number<div class="sub-desc">The number of milliseconds to delay the invocation of the handler after the event fires.</div></li>
240 <li><b>single</b> : Boolean<div class="sub-desc">True to add a handler to handle just the next firing of the event, and then remove itself.</div></li>
241 <li><b>buffer</b> : Number<div class="sub-desc">Causes the handler to be scheduled to run in an <a href="Ext.util.DelayedTask.html" rel="Ext.util.DelayedTask" class="docClass">Ext.util.DelayedTask</a> delayed
242 by the specified number of milliseconds. If the event fires again within that time, the original
243 handler is <em>not</em> invoked, but the new handler is scheduled in its place.</div></li>
244 <li><b>target</b> : Observable<div class="sub-desc">Only call the handler if the event was fired on the target Observable, <i>not</i>
245 if the event was bubbled up from a child Observable.</div></li>
246 <li><b>element</b> : String<div class="sub-desc"><b>This option is only valid for listeners bound to <a href="Ext.Component.html" rel="Ext.Component" class="docClass">Components</a>.</b>
247 The name of a Component property which references an element to add a listener to.</p>
248
249 <p>This option is useful during Component construction to add DOM event listeners to elements of <a href="Ext.Component.html" rel="Ext.Component" class="docClass">Components</a> which
250 will exist only after the Component is rendered. For example, to add a click listener to a Panel's body:
251 <pre><code>new Ext.panel.Panel({
252     title: 'The title',
253     listeners: {
254         click: this.handlePanelClick,
255         element: 'body'
256     }
257 });
258 </code></pre></p>
259
260
261 <p>When added in this way, the options available are the options applicable to <a href="Ext.core.Element.html#addListener" rel="Ext.core.Element#addListener" class="docClass">Ext.core.Element.addListener</a></p>
262
263
264 <p></div></li>
265 </ul><br></p>
266
267 <p>
268 <b>Combining Options</b><br>
269 Using the options argument, it is possible to combine different types of listeners:<br>
270 <br>
271 A delayed, one-time listener.
272 <pre><code>myPanel.on('hide', this.handleClick, this, {
273 single: true,
274 delay: 100
275 });</code></pre>
276 <p>
277 <b>Attaching multiple handlers in 1 call</b><br>
278 The method also allows for a single argument to be passed which is a config object containing properties
279 which specify multiple events. For example:
280 <pre><code>myGridPanel.on({
281     cellClick: this.onCellClick,
282     mouseover: this.onMouseOver,
283     mouseout: this.onMouseOut,
284     scope: this // Important. Ensure "this" is correct during handler execution
285 });
286 </code></pre>.
287 <p>
288
289 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
290 </li></ul></div></div></div><div id="method-addManagedListener" class="member inherited"><a href="Ext.draw.Surface.html#method-addManagedListener" rel="method-addManagedListener" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-addManagedListener" class="viewSource">view source</a></div><a name="addManagedListener"></a><a name="method-addManagedListener"></a><a href="Ext.draw.Surface.html#" rel="method-addManagedListener" class="cls expand">addManagedListener</a>(
291 <span class="pre">Observable/Element item, Object/String ename, Function fn, Object scope, Object opt</span>)
292  : void</div><div class="description"><div class="short"><p>Adds listeners to any Observable object (or Element) which are automatically removed when this Component
293 is destroyed.
294
295 </div><div class="long"><p>Adds listeners to any Observable object (or Element) which are automatically removed when this Component
296 is destroyed.
297
298 <h3 class="pa">Parameters</h3><ul><li><span class="pre">item</span> : Observable/Element<div class="sub-desc"><p>The item to which to add a listener/listeners.</p>
299 </div></li><li><span class="pre">ename</span> : Object/String<div class="sub-desc"><p>The event name, or an object containing event name properties.</p>
300 </div></li><li><span class="pre">fn</span> : Function<div class="sub-desc"><p>Optional. If the <code>ename</code> parameter was an event name, this
301 is the handler function.</p>
302 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>Optional. If the <code>ename</code> parameter was an event name, this
303 is the scope (<code>this</code> reference) in which the handler function is executed.</p>
304 </div></li><li><span class="pre">opt</span> : Object<div class="sub-desc"><p>Optional. If the <code>ename</code> parameter was an event name, this
305 is the <a href="Ext.util.Observable.html#addListener" rel="Ext.util.Observable#addListener" class="docClass">addListener</a> options.</p>
306 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
307 </li></ul></div></div></div><div id="method-capture" class="member inherited"><a href="Ext.draw.Surface.html#method-capture" rel="method-capture" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-capture" class="viewSource">view source</a></div><a name="capture"></a><a name="method-capture"></a><a href="Ext.draw.Surface.html#" rel="method-capture" class="cls expand">capture</a>(
308 <span class="pre">Observable o, Function fn, [Object scope]</span>)
309  : void</div><div class="description"><div class="short">Starts capture on the specified Observable. All events will be passed
310 to the supplied function with the event name + ...</div><div class="long"><p>Starts capture on the specified Observable. All events will be passed
311 to the supplied function with the event name + standard signature of the event
312 <b>before</b> the event is fired. If the supplied function returns false,
313 the event will not fire.</p>
314 <h3 class="pa">Parameters</h3><ul><li><span class="pre">o</span> : Observable<div class="sub-desc"><p>The Observable to capture events from.</p>
315 </div></li><li><span class="pre">fn</span> : Function<div class="sub-desc"><p>The function to call when an event is fired.</p>
316 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>(optional) The scope (<code>this</code> reference) in which the function is executed. Defaults to the Observable firing the event.</p>
317 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
318 </li></ul></div></div></div><div id="method-clearListeners" class="member inherited"><a href="Ext.draw.Surface.html#method-clearListeners" rel="method-clearListeners" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-clearListeners" class="viewSource">view source</a></div><a name="clearListeners"></a><a name="method-clearListeners"></a><a href="Ext.draw.Surface.html#" rel="method-clearListeners" class="cls expand">clearListeners</a> : void</div><div class="description"><div class="short"><p>Removes all listeners for this object including the managed listeners</p>
319 </div><div class="long"><p>Removes all listeners for this object including the managed listeners</p>
320 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
321 </li></ul></div></div></div><div id="method-clearManagedListeners" class="member inherited"><a href="Ext.draw.Surface.html#method-clearManagedListeners" rel="method-clearManagedListeners" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-clearManagedListeners" class="viewSource">view source</a></div><a name="clearManagedListeners"></a><a name="method-clearManagedListeners"></a><a href="Ext.draw.Surface.html#" rel="method-clearManagedListeners" class="cls expand">clearManagedListeners</a> : void</div><div class="description"><div class="short"><p>Removes all managed listeners for this object.</p>
322 </div><div class="long"><p>Removes all managed listeners for this object.</p>
323 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
324 </li></ul></div></div></div><div id="method-create" class="member ni"><a href="Ext.draw.Surface.html#method-create" rel="method-create" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-create" class="viewSource">view source</a></div><a name="create"></a><a name="method-create"></a><a href="Ext.draw.Surface.html#" rel="method-create" class="cls expand">create</a>(
325 <span class="pre">Object config, Array enginePriority</span>)
326  : void</div><div class="description"><div class="short"><p>Create and return a new concrete Surface instance appropriate for the current environment.</p>
327 </div><div class="long"><p>Create and return a new concrete Surface instance appropriate for the current environment.</p>
328 <h3 class="pa">Parameters</h3><ul><li><span class="pre">config</span> : Object<div class="sub-desc"><p>Initial configuration for the Surface instance</p>
329 </div></li><li><span class="pre">enginePriority</span> : Array<div class="sub-desc"><p>Optional order of implementations to use; the first one that is</p>
330
331 <pre><code>           available in the current environment will be used. Defaults to
332            &lt;code&gt;['Svg', 'Vml']&lt;/code&gt;.
333 </code></pre>
334 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
335 </li></ul></div></div></div><div id="method-destroy" class="member ni"><a href="Ext.draw.Surface.html#method-destroy" rel="method-destroy" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-destroy" class="viewSource">view source</a></div><a name="destroy"></a><a name="method-destroy"></a><a href="Ext.draw.Surface.html#" rel="method-destroy" class="cls expand">destroy</a> : void</div><div class="description"><div class="short">Destroys the surface. This is done by removing all components from it and
336 also removing its reference to a DOM elemen...</div><div class="long"><p>Destroys the surface. This is done by removing all components from it and
337 also removing its reference to a DOM element.</p>
338
339 <p>For example:</p>
340
341 <pre><code> drawComponent.surface.destroy();
342 </code></pre>
343 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
344 </li></ul></div></div></div><div id="method-enableBubble" class="member inherited"><a href="Ext.draw.Surface.html#method-enableBubble" rel="method-enableBubble" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-enableBubble" class="viewSource">view source</a></div><a name="enableBubble"></a><a name="method-enableBubble"></a><a href="Ext.draw.Surface.html#" rel="method-enableBubble" class="cls expand">enableBubble</a>(
345 <span class="pre">String/Array events</span>)
346  : void</div><div class="description"><div class="short">Enables events fired by this Observable to bubble up an owner hierarchy by calling
347 this.getBubbleTarget() if present....</div><div class="long"><p>Enables events fired by this Observable to bubble up an owner hierarchy by calling
348 <code>this.getBubbleTarget()</code> if present. There is no implementation in the Observable base class.</p>
349
350
351 <p>This is commonly used by Ext.Components to bubble events to owner Containers. See <a href="Ext.Component.html#getBubbleTarget" rel="Ext.Component#getBubbleTarget" class="docClass">Ext.Component.getBubbleTarget</a>. The default
352 implementation in <a href="Ext.Component.html" rel="Ext.Component" class="docClass">Ext.Component</a> returns the Component's immediate owner. But if a known target is required, this can be overridden to
353 access the required target more quickly.</p>
354
355
356 <p>Example:</p>
357
358
359 <pre><code>Ext.override(Ext.form.field.Base, {
360 //  Add functionality to Field&#39;s initComponent to enable the change event to bubble
361 initComponent : Ext.Function.createSequence(Ext.form.field.Base.prototype.initComponent, function() {
362     this.enableBubble('change');
363 }),
364
365 //  We know that we want Field&#39;s events to bubble directly to the FormPanel.
366 getBubbleTarget : function() {
367     if (!this.formPanel) {
368         this.formPanel = this.findParentByType('form');
369     }
370     return this.formPanel;
371 }
372 });
373
374 var myForm = new Ext.formPanel({
375 title: 'User Details',
376 items: [{
377     ...
378 }],
379 listeners: {
380     change: function() {
381         // Title goes red if form has been modified.
382         myForm.header.setStyle('color', 'red');
383     }
384 }
385 });
386 </code></pre>
387
388 <h3 class="pa">Parameters</h3><ul><li><span class="pre">events</span> : String/Array<div class="sub-desc"><p>The event name to bubble, or an Array of event names.</p>
389 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
390 </li></ul></div></div></div><div id="method-fireEvent" class="member inherited"><a href="Ext.draw.Surface.html#method-fireEvent" rel="method-fireEvent" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-fireEvent" class="viewSource">view source</a></div><a name="fireEvent"></a><a name="method-fireEvent"></a><a href="Ext.draw.Surface.html#" rel="method-fireEvent" class="cls expand">fireEvent</a>(
391 <span class="pre">String eventName, Object... args</span>)
392  : Boolean</div><div class="description"><div class="short">Fires the specified event with the passed parameters (minus the event name).
393
394
395 An event may be set to bubble up an Ob...</div><div class="long"><p>Fires the specified event with the passed parameters (minus the event name).</p>
396
397
398 <p>An event may be set to bubble up an Observable parent hierarchy (See <a href="Ext.Component.html#getBubbleTarget" rel="Ext.Component#getBubbleTarget" class="docClass">Ext.Component.getBubbleTarget</a>)
399 by calling <a href="Ext.draw.Surface.html#enableBubble" rel="Ext.draw.Surface#enableBubble" class="docClass">enableBubble</a>.</p>
400
401 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The name of the event to fire.</p>
402 </div></li><li><span class="pre">args</span> : Object...<div class="sub-desc"><p>Variable number of parameters are passed to handlers.</p>
403 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">Boolean</span>&nbsp; &nbsp;<p>returns false if any of the handlers return false otherwise it returns true.</p>
404 </li></ul></div></div></div><div id="method-getGroup" class="member ni"><a href="Ext.draw.Surface.html#method-getGroup" rel="method-getGroup" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-getGroup" class="viewSource">view source</a></div><a name="getGroup"></a><a name="method-getGroup"></a><a href="Ext.draw.Surface.html#" rel="method-getGroup" class="cls expand">getGroup</a>(
405 <span class="pre">String id</span>)
406  : Object</div><div class="description"><div class="short">Returns a new group or an existent group associated with the current surface.
407 The group returned is a Ext.draw.Compos...</div><div class="long"><p>Returns a new group or an existent group associated with the current surface.
408 The group returned is a <a href="Ext.draw.CompositeSprite.html" rel="Ext.draw.CompositeSprite" class="docClass">Ext.draw.CompositeSprite</a> group.</p>
409
410 <p>For example:</p>
411
412 <pre><code> var spriteGroup = drawComponent.surface.getGroup('someGroupId');
413 </code></pre>
414 <h3 class="pa">Parameters</h3><ul><li><span class="pre">id</span> : String<div class="sub-desc"><p>The unique identifier of the group.</p>
415 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">Object</span>&nbsp; &nbsp;<p>The <a href="Ext.draw.CompositeSprite.html" rel="Ext.draw.CompositeSprite" class="docClass">Ext.draw.CompositeSprite</a>.</p>
416 </li></ul></div></div></div><div id="method-getId" class="member ni"><a href="Ext.draw.Surface.html#method-getId" rel="method-getId" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-getId" class="viewSource">view source</a></div><a name="getId"></a><a name="method-getId"></a><a href="Ext.draw.Surface.html#" rel="method-getId" class="cls expand">getId</a> : void</div><div class="description"><div class="short"><p>Retrieves the id of this component.
417 Will autogenerate an id if one has not already been set.</p>
418 </div><div class="long"><p>Retrieves the id of this component.
419 Will autogenerate an id if one has not already been set.</p>
420 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
421 </li></ul></div></div></div><div id="method-hasListener" class="member inherited"><a href="Ext.draw.Surface.html#method-hasListener" rel="method-hasListener" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-hasListener" class="viewSource">view source</a></div><a name="hasListener"></a><a name="method-hasListener"></a><a href="Ext.draw.Surface.html#" rel="method-hasListener" class="cls expand">hasListener</a>(
422 <span class="pre">String eventName</span>)
423  : Boolean</div><div class="description"><div class="short"><p>Checks to see if this object has any listeners for a specified event</p>
424 </div><div class="long"><p>Checks to see if this object has any listeners for a specified event</p>
425 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The name of the event to check for</p>
426 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">Boolean</span>&nbsp; &nbsp;<p>True if the event is being listened for, else false</p>
427 </li></ul></div></div></div><div id="method-observe" class="member inherited"><a href="Ext.draw.Surface.html#method-observe" rel="method-observe" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-observe" class="viewSource">view source</a></div><a name="observe"></a><a name="method-observe"></a><a href="Ext.draw.Surface.html#" rel="method-observe" class="cls expand">observe</a>(
428 <span class="pre">Function c, Object listeners</span>)
429  : void</div><div class="description"><div class="short">Sets observability on the passed class constructor.
430
431 This makes any event fired on any instance of the passed class a...</div><div class="long"><p>Sets observability on the passed class constructor.</p>
432
433 <p>This makes any event fired on any instance of the passed class also fire a single event through
434 the <strong>class</strong> allowing for central handling of events on many instances at once.</p>
435
436 <p>Usage:</p>
437
438 <pre><code>Ext.util.Observable.observe(Ext.data.Connection);
439 Ext.data.Connection.on('beforerequest', function(con, options) {
440     console.log('Ajax request made to ' + options.url);
441 });
442 </code></pre>
443 <h3 class="pa">Parameters</h3><ul><li><span class="pre">c</span> : Function<div class="sub-desc"><p>The class constructor to make observable.</p>
444 </div></li><li><span class="pre">listeners</span> : Object<div class="sub-desc"><p>An object containing a series of listeners to add. See <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a>.</p>
445 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
446 </li></ul></div></div></div><div id="method-on" class="member inherited"><a href="Ext.draw.Surface.html#method-on" rel="method-on" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-on" class="viewSource">view source</a></div><a name="on"></a><a name="method-on"></a><a href="Ext.draw.Surface.html#" rel="method-on" class="cls expand">on</a>(
447 <span class="pre">String eventName, Function handler, [Object scope], [Object options]</span>)
448  : void</div><div class="description"><div class="short"><p>Appends an event handler to this object (shorthand for <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a>.)</p>
449 </div><div class="long"><p>Appends an event handler to this object (shorthand for <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a>.)</p>
450 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The type of event to listen for</p>
451 </div></li><li><span class="pre">handler</span> : Function<div class="sub-desc"><p>The method the event invokes</p>
452 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>(optional) The scope (<code><b>this</b></code> reference) in which the handler function is executed.
453 <b>If omitted, defaults to the object which fired the event.</b></p>
454 </div></li><li><span class="pre">options</span> : Object<div class="sub-desc"><p>(optional) An object containing handler configuration.</p>
455 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
456 </li></ul></div></div></div><div id="method-relayEvents" class="member inherited"><a href="Ext.draw.Surface.html#method-relayEvents" rel="method-relayEvents" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-relayEvents" class="viewSource">view source</a></div><a name="relayEvents"></a><a name="method-relayEvents"></a><a href="Ext.draw.Surface.html#" rel="method-relayEvents" class="cls expand">relayEvents</a>(
457 <span class="pre">Object origin, Array events, Object prefix</span>)
458  : void</div><div class="description"><div class="short"><p>Relays selected events from the specified Observable as if the events were fired by <code><b>this</b></code>.</p>
459 </div><div class="long"><p>Relays selected events from the specified Observable as if the events were fired by <code><b>this</b></code>.</p>
460 <h3 class="pa">Parameters</h3><ul><li><span class="pre">origin</span> : Object<div class="sub-desc"><p>The Observable whose events this object is to relay.</p>
461 </div></li><li><span class="pre">events</span> : Array<div class="sub-desc"><p>Array of event names to relay.</p>
462 </div></li><li><span class="pre">prefix</span> : Object<div class="sub-desc">
463 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
464 </li></ul></div></div></div><div id="method-releaseCapture" class="member inherited"><a href="Ext.draw.Surface.html#method-releaseCapture" rel="method-releaseCapture" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-releaseCapture" class="viewSource">view source</a></div><a name="releaseCapture"></a><a name="method-releaseCapture"></a><a href="Ext.draw.Surface.html#" rel="method-releaseCapture" class="cls expand">releaseCapture</a>(
465 <span class="pre">Observable o</span>)
466  : void</div><div class="description"><div class="short"><p>Removes <b>all</b> added captures from the Observable.</p>
467 </div><div class="long"><p>Removes <b>all</b> added captures from the Observable.</p>
468 <h3 class="pa">Parameters</h3><ul><li><span class="pre">o</span> : Observable<div class="sub-desc"><p>The Observable to release</p>
469 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
470 </li></ul></div></div></div><div id="method-remove" class="member ni"><a href="Ext.draw.Surface.html#method-remove" rel="method-remove" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-remove" class="viewSource">view source</a></div><a name="remove"></a><a name="method-remove"></a><a href="Ext.draw.Surface.html#" rel="method-remove" class="cls expand">remove</a>(
471 <span class="pre">Ext.draw.Sprite sprite, Boolean destroySprite</span>)
472  : Number</div><div class="description"><div class="short">Remove a given sprite from the surface, optionally destroying the sprite in the process.
473 You can also call the sprite...</div><div class="long"><p>Remove a given sprite from the surface, optionally destroying the sprite in the process.
474 You can also call the sprite own <code>remove</code> method.</p>
475
476 <p>For example:</p>
477
478 <pre><code> drawComponent.surface.remove(sprite);
479  //or...
480  sprite.remove();
481 </code></pre>
482 <h3 class="pa">Parameters</h3><ul><li><span class="pre">sprite</span> : Ext.draw.Sprite<div class="sub-desc">
483 </div></li><li><span class="pre">destroySprite</span> : Boolean<div class="sub-desc">
484 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">Number</span>&nbsp; &nbsp;<p>the sprite's new index in the list</p>
485 </li></ul></div></div></div><div id="method-removeAll" class="member ni"><a href="Ext.draw.Surface.html#method-removeAll" rel="method-removeAll" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-removeAll" class="viewSource">view source</a></div><a name="removeAll"></a><a name="method-removeAll"></a><a href="Ext.draw.Surface.html#" rel="method-removeAll" class="cls expand">removeAll</a>(
486 <span class="pre">Boolean destroySprites</span>)
487  : Number</div><div class="description"><div class="short">Remove all sprites from the surface, optionally destroying the sprites in the process.
488
489 For example:
490
491  drawComponent....</div><div class="long"><p>Remove all sprites from the surface, optionally destroying the sprites in the process.</p>
492
493 <p>For example:</p>
494
495 <pre><code> drawComponent.surface.removeAll();
496 </code></pre>
497 <h3 class="pa">Parameters</h3><ul><li><span class="pre">destroySprites</span> : Boolean<div class="sub-desc"><p>Whether to destroy all sprites when removing them.</p>
498 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">Number</span>&nbsp; &nbsp;<p>The sprite's new index in the list.</p>
499 </li></ul></div></div></div><div id="method-removeListener" class="member inherited"><a href="Ext.draw.Surface.html#method-removeListener" rel="method-removeListener" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-removeListener" class="viewSource">view source</a></div><a name="removeListener"></a><a name="method-removeListener"></a><a href="Ext.draw.Surface.html#" rel="method-removeListener" class="cls expand">removeListener</a>(
500 <span class="pre">String eventName, Function handler, [Object scope]</span>)
501  : void</div><div class="description"><div class="short"><p>Removes an event handler.</p>
502 </div><div class="long"><p>Removes an event handler.</p>
503 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The type of event the handler was associated with.</p>
504 </div></li><li><span class="pre">handler</span> : Function<div class="sub-desc"><p>The handler to remove. <b>This must be a reference to the function passed into the <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a> call.</b></p>
505 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>(optional) The scope originally specified for the handler.</p>
506 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
507 </li></ul></div></div></div><div id="method-removeManagedListener" class="member inherited"><a href="Ext.draw.Surface.html#method-removeManagedListener" rel="method-removeManagedListener" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-removeManagedListener" class="viewSource">view source</a></div><a name="removeManagedListener"></a><a name="method-removeManagedListener"></a><a href="Ext.draw.Surface.html#" rel="method-removeManagedListener" class="cls expand">removeManagedListener</a>(
508 <span class="pre">Observable|Element item, Object|String ename, Function fn, Object scope</span>)
509  : void</div><div class="description"><div class="short"><p>Removes listeners that were added by the <a href="Ext.draw.Surface.html#mon" rel="Ext.draw.Surface#mon" class="docClass">mon</a> method.</p>
510 </div><div class="long"><p>Removes listeners that were added by the <a href="Ext.draw.Surface.html#mon" rel="Ext.draw.Surface#mon" class="docClass">mon</a> method.</p>
511 <h3 class="pa">Parameters</h3><ul><li><span class="pre">item</span> : Observable|Element<div class="sub-desc"><p>The item from which to remove a listener/listeners.</p>
512 </div></li><li><span class="pre">ename</span> : Object|String<div class="sub-desc"><p>The event name, or an object containing event name properties.</p>
513 </div></li><li><span class="pre">fn</span> : Function<div class="sub-desc"><p>Optional. If the <code>ename</code> parameter was an event name, this
514 is the handler function.</p>
515 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>Optional. If the <code>ename</code> parameter was an event name, this
516 is the scope (<code>this</code> reference) in which the handler function is executed.</p>
517 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
518 </li></ul></div></div></div><div id="method-resumeEvents" class="member inherited"><a href="Ext.draw.Surface.html#method-resumeEvents" rel="method-resumeEvents" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-resumeEvents" class="viewSource">view source</a></div><a name="resumeEvents"></a><a name="method-resumeEvents"></a><a href="Ext.draw.Surface.html#" rel="method-resumeEvents" class="cls expand">resumeEvents</a> : void</div><div class="description"><div class="short">Resume firing events. (see suspendEvents)
519 If events were suspended using the queueSuspended parameter, then all
520 event...</div><div class="long"><p>Resume firing events. (see <a href="Ext.draw.Surface.html#suspendEvents" rel="Ext.draw.Surface#suspendEvents" class="docClass">suspendEvents</a>)
521 If events were suspended using the <code><b>queueSuspended</b></code> parameter, then all
522 events fired during event suspension will be sent to any listeners now.</p>
523 <h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
524 </li></ul></div></div></div><div id="method-setSize" class="member ni"><a href="Ext.draw.Surface.html#method-setSize" rel="method-setSize" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.draw.Surface.html" class="definedIn docClass">Ext.draw.Surface</a><br/><a href="../source/Surface.html#Ext-draw.Surface-method-setSize" class="viewSource">view source</a></div><a name="setSize"></a><a name="method-setSize"></a><a href="Ext.draw.Surface.html#" rel="method-setSize" class="cls expand">setSize</a>(
525 <span class="pre">Number w, Number h</span>)
526  : void</div><div class="description"><div class="short">Sets the size of the surface. Accomodates the background (if any) to fit the new size too.
527
528 For example:
529
530  drawCompon...</div><div class="long"><p>Sets the size of the surface. Accomodates the background (if any) to fit the new size too.</p>
531
532 <p>For example:</p>
533
534 <pre><code> drawComponent.surface.setSize(500, 500);
535 </code></pre>
536
537 <p>This method is generally called when also setting the size of the draw Component.</p>
538 <h3 class="pa">Parameters</h3><ul><li><span class="pre">w</span> : Number<div class="sub-desc"><p>The new width of the canvas.</p>
539 </div></li><li><span class="pre">h</span> : Number<div class="sub-desc"><p>The new height of the canvas.</p>
540 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
541 </li></ul></div></div></div><div id="method-suspendEvents" class="member inherited"><a href="Ext.draw.Surface.html#method-suspendEvents" rel="method-suspendEvents" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-suspendEvents" class="viewSource">view source</a></div><a name="suspendEvents"></a><a name="method-suspendEvents"></a><a href="Ext.draw.Surface.html#" rel="method-suspendEvents" class="cls expand">suspendEvents</a>(
542 <span class="pre">Boolean queueSuspended</span>)
543  : void</div><div class="description"><div class="short"><p>Suspend the firing of all events. (see <a href="Ext.draw.Surface.html#resumeEvents" rel="Ext.draw.Surface#resumeEvents" class="docClass">resumeEvents</a>)</p>
544 </div><div class="long"><p>Suspend the firing of all events. (see <a href="Ext.draw.Surface.html#resumeEvents" rel="Ext.draw.Surface#resumeEvents" class="docClass">resumeEvents</a>)</p>
545 <h3 class="pa">Parameters</h3><ul><li><span class="pre">queueSuspended</span> : Boolean<div class="sub-desc"><p>Pass as true to queue up suspended events to be fired
546 after the <a href="Ext.draw.Surface.html#resumeEvents" rel="Ext.draw.Surface#resumeEvents" class="docClass">resumeEvents</a> call instead of discarding all suspended events;</p>
547 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
548 </li></ul></div></div></div><div id="method-un" class="member inherited"><a href="Ext.draw.Surface.html#method-un" rel="method-un" class="expand more ar"><span>&nbsp;</span></a><div class="title"><div class="meta"><a href="Ext.util.Observable.html" class="definedIn docClass">Ext.util.Observable</a><br/><a href="../source/Observable.html#Ext-util.Observable-method-un" class="viewSource">view source</a></div><a name="un"></a><a name="method-un"></a><a href="Ext.draw.Surface.html#" rel="method-un" class="cls expand">un</a>(
549 <span class="pre">String eventName, Function handler, [Object scope]</span>)
550  : void</div><div class="description"><div class="short"><p>Removes an event handler (shorthand for <a href="Ext.draw.Surface.html#removeListener" rel="Ext.draw.Surface#removeListener" class="docClass">removeListener</a>.)</p>
551 </div><div class="long"><p>Removes an event handler (shorthand for <a href="Ext.draw.Surface.html#removeListener" rel="Ext.draw.Surface#removeListener" class="docClass">removeListener</a>.)</p>
552 <h3 class="pa">Parameters</h3><ul><li><span class="pre">eventName</span> : String<div class="sub-desc"><p>The type of event the handler was associated with.</p>
553 </div></li><li><span class="pre">handler</span> : Function<div class="sub-desc"><p>The handler to remove. <b>This must be a reference to the function passed into the <a href="Ext.draw.Surface.html#addListener" rel="Ext.draw.Surface#addListener" class="docClass">addListener</a> call.</b></p>
554 </div></li><li><span class="pre">scope</span> : Object<div class="sub-desc"><p>(optional) The scope originally specified for the handler.</p>
555 </div></li></ul><h3 class="pa">Returns</h3><ul><li><span class="pre">void</span>&nbsp; &nbsp;
556 </li></ul></div></div></div></div></div></div></div><div id="pageContent"></div></div></div></div></body></html>