| 
									
										
										
										
											2012-03-06 21:45:48 -08:00
										 |  |  | ///////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | //  Rect
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2012-07-08 21:56:52 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Rect constructor | 
					
						
							|  |  |  |  * @constructor | 
					
						
							|  |  |  |  * @augments Kinetic.Shape | 
					
						
							|  |  |  |  * @param {Object} config | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-07-03 12:07:27 -07:00
										 |  |  | Kinetic.Rect = Kinetic.Shape.extend({ | 
					
						
							|  |  |  |     init: function(config) { | 
					
						
							|  |  |  |         this.setDefaultAttrs({ | 
					
						
							|  |  |  |             width: 0, | 
					
						
							|  |  |  |             height: 0, | 
					
						
							|  |  |  |             cornerRadius: 0 | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         this.shapeType = "Rect"; | 
					
						
							| 
									
										
										
										
											2012-07-26 22:58:38 -07:00
										 |  |  |         config.drawFunc = this.drawFunc; | 
					
						
							| 
									
										
										
										
											2012-07-03 12:07:27 -07:00
										 |  |  |         // call super constructor
 | 
					
						
							|  |  |  |         this._super(config); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2012-07-26 22:58:38 -07:00
										 |  |  |     drawFunc: function(context) { | 
					
						
							|  |  |  |         context.beginPath(); | 
					
						
							|  |  |  |         if(this.attrs.cornerRadius === 0) { | 
					
						
							|  |  |  |             // simple rect - don't bother doing all that complicated maths stuff.
 | 
					
						
							|  |  |  |             context.rect(0, 0, this.attrs.width, this.attrs.height); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							|  |  |  |             // arcTo would be nicer, but browser support is patchy (Opera)
 | 
					
						
							|  |  |  |             context.moveTo(this.attrs.cornerRadius, 0); | 
					
						
							|  |  |  |             context.lineTo(this.attrs.width - this.attrs.cornerRadius, 0); | 
					
						
							|  |  |  |             context.arc(this.attrs.width - this.attrs.cornerRadius, this.attrs.cornerRadius, this.attrs.cornerRadius, Math.PI * 3 / 2, 0, false); | 
					
						
							|  |  |  |             context.lineTo(this.attrs.width, this.attrs.height - this.attrs.cornerRadius); | 
					
						
							|  |  |  |             context.arc(this.attrs.width - this.attrs.cornerRadius, this.attrs.height - this.attrs.cornerRadius, this.attrs.cornerRadius, 0, Math.PI / 2, false); | 
					
						
							|  |  |  |             context.lineTo(this.attrs.cornerRadius, this.attrs.height); | 
					
						
							|  |  |  |             context.arc(this.attrs.cornerRadius, this.attrs.height - this.attrs.cornerRadius, this.attrs.cornerRadius, Math.PI / 2, Math.PI, false); | 
					
						
							|  |  |  |             context.lineTo(0, this.attrs.cornerRadius); | 
					
						
							|  |  |  |             context.arc(this.attrs.cornerRadius, this.attrs.cornerRadius, this.attrs.cornerRadius, Math.PI, Math.PI * 3 / 2, false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         context.closePath(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.fill(context); | 
					
						
							|  |  |  |         this.stroke(context); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2012-03-06 21:45:48 -08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * set width and height | 
					
						
							| 
									
										
										
										
											2012-07-08 21:56:52 -07:00
										 |  |  |      * @name setSize | 
					
						
							|  |  |  |      * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-03-06 21:45:48 -08:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2012-05-26 16:37:37 -07:00
										 |  |  |     setSize: function() { | 
					
						
							| 
									
										
										
										
											2012-07-03 22:08:59 -07:00
										 |  |  |         var size = Kinetic.Type._getSize(Array.prototype.slice.call(arguments)); | 
					
						
							| 
									
										
										
										
											2012-05-28 23:46:40 -07:00
										 |  |  |         this.setAttrs(size); | 
					
						
							| 
									
										
										
										
											2012-03-31 00:08:50 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * return rect size | 
					
						
							| 
									
										
										
										
											2012-07-08 21:56:52 -07:00
										 |  |  |      * @name getSize | 
					
						
							|  |  |  |      * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-03-31 00:08:50 -07:00
										 |  |  |      */ | 
					
						
							|  |  |  |     getSize: function() { | 
					
						
							|  |  |  |         return { | 
					
						
							| 
									
										
										
										
											2012-04-05 23:48:58 -07:00
										 |  |  |             width: this.attrs.width, | 
					
						
							|  |  |  |             height: this.attrs.height | 
					
						
							| 
									
										
										
										
											2012-03-31 00:08:50 -07:00
										 |  |  |         }; | 
					
						
							| 
									
										
										
										
											2012-06-10 00:02:16 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-07-03 12:07:27 -07:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-03 12:07:27 -07:00
										 |  |  | // add getters setters
 | 
					
						
							|  |  |  | Kinetic.Node.addGettersSetters(Kinetic.Rect, ['width', 'height', 'cornerRadius']); | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * set width | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name setWidth | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  * @param {Number} width | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * set height | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name setHeight | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  * @param {Number} height | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * set corner radius | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name setCornerRadius | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  * @param {Number} radius | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * get width | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name getWidth | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * get height | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name getHeight | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * get corner radius | 
					
						
							| 
									
										
										
										
											2012-06-14 02:19:51 -07:00
										 |  |  |  * @name getCornerRadius | 
					
						
							|  |  |  |  * @methodOf Kinetic.Rect.prototype | 
					
						
							| 
									
										
										
										
											2012-06-10 13:07:09 -07:00
										 |  |  |  */ |