| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  | # Blender.Ipo module and the Ipo PyType object | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | The Blender.Ipo submodule | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | This module provides access to the Ipo Data in Blender. An Ipo is composed of several Ipocurves. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A datatype is defined : IpoCurve type. The member functions of this data type are given below. | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Example:: | 
					
						
							|  |  |  |   import Blender | 
					
						
							|  |  |  |   ob = Blender.Ipo.Get('ipo')    # retreives an ipo object | 
					
						
							| 
									
										
										
										
											2003-07-22 00:27:03 +00:00
										 |  |  |   ob.setName('ipo1') | 
					
						
							|  |  |  |   print ob.name | 
					
						
							|  |  |  |   print ipo.getRctf() | 
					
						
							|  |  |  |   ipo.setRctf(1,2,3,4) | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-05 06:25:49 +00:00
										 |  |  | def New (type, name): | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  |   """
 | 
					
						
							|  |  |  |   Creates a new Ipo. | 
					
						
							| 
									
										
										
										
											2004-03-05 06:25:49 +00:00
										 |  |  |   @type type: string | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  |   @type name: string | 
					
						
							| 
									
										
										
										
											2004-03-05 06:25:49 +00:00
										 |  |  |   @param type: The Ipo's blocktype. Depends on the object the ipo will be linked to. \
 | 
					
						
							|  |  |  |   Currently supported types are Object, Camera, World, Material. | 
					
						
							|  |  |  |   @param name: The name for this Ipo. | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  |   @rtype: Blender Ipo | 
					
						
							|  |  |  |   @return: The created Ipo. | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def Get (name = None): | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  |   Get the Ipo from Blender. | 
					
						
							|  |  |  |   @type name: string | 
					
						
							|  |  |  |   @param name: The name of the requested Ipo, or nothing. | 
					
						
							|  |  |  |   @rtype: Blender Ipo or a list of Blender Ipos | 
					
						
							|  |  |  |   @return: It depends on the 'name' parameter: | 
					
						
							|  |  |  |       - (name): The Ipo with the given name; | 
					
						
							|  |  |  |       - ():     A list with all Ipos in the current scene. | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Ipo: | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  |   The Ipo object | 
					
						
							|  |  |  |   ============== | 
					
						
							|  |  |  |   This object gives access to generic data from all objects in Blender. | 
					
						
							| 
									
										
										
										
											2003-07-10 00:28:03 +00:00
										 |  |  |   This object has no attribute. | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  |   """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getName(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the name of the Ipo. | 
					
						
							|  |  |  | 		@rtype: string | 
					
						
							|  |  |  | 		@return: the name of the Ipo. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2003-10-27 21:50:36 +00:00
										 |  |  |   def getCurves(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets all the IpoCurves of the Ipo. | 
					
						
							| 
									
										
										
										
											2004-03-05 05:50:50 +00:00
										 |  |  | 		@rtype: list of IpoCurves | 
					
						
							| 
									
										
										
										
											2003-10-27 21:50:36 +00:00
										 |  |  | 		@return: A list (possibly void) containing all the IpoCurves associated to the Ipo object. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2003-10-26 21:22:24 +00:00
										 |  |  |   def getCurve(curvename): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Returns the IpoCurve with the given name. | 
					
						
							|  |  |  | 		The possible values for curvename are R,G,B,SpecR,SpecG,SpecB,MirR,MirG,MirB,Ref,Alpha,Emit,Amb,Spec,Hard,SpTra,Ang,Mode,HaSize,OfsX,OfsY,OfsZ,SizeX,SizeY,SizeZ,TexR,TexG,TexB,DefVar,Col,Nor,Var(Material Ipo) | 
					
						
							|  |  |  | 		HorR,HorG,HorB,ZenR,ZenG,ZenB,Expos,Misi,MisDi,MisSta,MisHi,StaR,StaG,StaB,StarDi,StarSi,OfsX,OfsY,OfsZ,SizeX,SizeY,SizeZ,TexR,TexG,TexB,DefVar,Col,Nor,Var (World Ipo) | 
					
						
							|  |  |  | 		LocX,LocY,LocZ,dLocX,dLocY,dLocZ,RotX,RotY,RotZ,dRotX,dRotY,dRotZ,SizeX,SizeY,SizeZ,dSizeX,dSizeY,dSizeZ,Layer,Time,ColR,ColG,ColB,ColA (Object Ipo) | 
					
						
							|  |  |  | 		Lens,ClSta,ClEnd (Camera Ipo) | 
					
						
							|  |  |  | 		@type curvename : string | 
					
						
							|  |  |  | 		@rtype: IpoCurve object | 
					
						
							|  |  |  | 		@return: the corresponding IpoCurve, or None. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2004-05-25 19:31:13 +00:00
										 |  |  |   def addCurve(curvename): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		add a new curve to the IPO object. | 
					
						
							|  |  |  | 		LocX,LocY,LocZ,dLocX,dLocY,dLocZ,RotX,RotY,RotZ,dRotX,dRotY,dRotZ,SizeX,SizeY,SizeZ,dSizeX,dSizeY,dSizeZ,Layer,Time,ColR,ColG,ColB,ColA (Object Ipo) | 
					
						
							|  |  |  | 		@type curvename : string | 
					
						
							|  |  |  | 		@rtype: IpoCurve object | 
					
						
							|  |  |  | 		@return: the corresponding IpoCurve, or None. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  |   def setName(newname): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the name of the Ipo. | 
					
						
							|  |  |  | 		@type newname: string | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getBlocktype(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the blocktype of the Ipo. | 
					
						
							|  |  |  | 		@rtype: int | 
					
						
							|  |  |  | 		@return: the blocktype of the Ipo. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |   def setBlocktype(newblocktype): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the blocktype of the Ipo. | 
					
						
							|  |  |  | 		@type newblocktype: int. This value should not be changed, unless you really know what you do... | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getRctf(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the rctf of the Ipo. | 
					
						
							|  |  |  | 		Kind of bounding box... | 
					
						
							|  |  |  | 		@rtype: list of floats | 
					
						
							|  |  |  | 		@return: the rctf of the Ipo. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |   def setRctf(newrctf): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the rctf of the Ipo. | 
					
						
							|  |  |  | 		@type newrctf: four floats . This value should not be changed, unless you really know what you do... | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getNcurves(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the number of curves of the Ipo. | 
					
						
							|  |  |  | 		@rtype: int  | 
					
						
							|  |  |  | 		@return: the number of curve of the Ipo. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  |   def getCurveBP(curvepos): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the basepoint of a curve of the ipo. | 
					
						
							|  |  |  | 		@type curvepos: int | 
					
						
							|  |  |  | 		@param curvepos: the position of the curve. | 
					
						
							|  |  |  | 		@rtype: a list of 4 floats | 
					
						
							|  |  |  | 		@return: the coordinates of the basepoint, or an error is raised. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  |   def getBeztriple(curvepos,pointpos): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets a beztriple of the Ipo. | 
					
						
							|  |  |  | 		@type curvepos: int | 
					
						
							|  |  |  | 		@param curvepos: the position of the curve in the ipo | 
					
						
							|  |  |  | 		@type pointpos: int | 
					
						
							|  |  |  | 		@param pointpos: the position of the point in the curve. | 
					
						
							|  |  |  | 		@rtype: list of 9 floats | 
					
						
							|  |  |  | 		@return: the beztriple of the Ipo, or an error is raised. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |   def setBeztriple(curvepos,pointpos,newbeztriple): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the beztriple of the Ipo. | 
					
						
							|  |  |  | 		@type curvepos: int | 
					
						
							|  |  |  | 		@param curvepos: the position of the curve in the ipo | 
					
						
							|  |  |  | 		@type pointpos: int | 
					
						
							|  |  |  | 		@param pointpos: the position of the point in the curve. | 
					
						
							|  |  |  | 		@type newbeztriple: list of 9 floats | 
					
						
							| 
									
										
										
										
											2003-07-10 00:28:03 +00:00
										 |  |  | 		@param newbeztriple: the new value for the point | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  |   def getCurvecurval(curvepos): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the current value of a curve of the Ipo. | 
					
						
							| 
									
										
										
										
											2003-12-17 14:15:14 +00:00
										 |  |  | 		@type curvepos: int or string | 
					
						
							|  |  |  | 		@param curvepos: the position of the curve in the ipo or the name of the curve | 
					
						
							| 
									
										
										
										
											2003-07-10 00:23:11 +00:00
										 |  |  | 		@rtype: float | 
					
						
							|  |  |  | 		@return: the current value of the selected curve of the Ipo. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2003-08-01 19:47:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   def EvaluateCurveOn(curvepos,time): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the current value of a curve of the Ipo. | 
					
						
							|  |  |  | 		@type curvepos: int | 
					
						
							|  |  |  | 		@param curvepos: the position of the curve in the ipo | 
					
						
							|  |  |  | 		@type time: float | 
					
						
							|  |  |  | 		@param time: the position of the curve in the ipo | 
					
						
							|  |  |  | 		@rtype: float | 
					
						
							|  |  |  | 		@return: the current value of the selected curve of the Ipo at the given time. | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IpoCurve: | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  |   The IpoCurve object | 
					
						
							|  |  |  |   =================== | 
					
						
							|  |  |  |   This object gives access to generic data from all ipocurves objects in Blender. | 
					
						
							| 
									
										
										
										
											2004-03-25 06:18:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   Important Notes for Rotation Curves:\n | 
					
						
							|  |  |  |   For the rotation IpoCurves, the y values for points are in units of 10 degrees.  example:  45.0 degrees is stored as 4.50 degrees.  These are the same numbers you see in the Transform Properties pupmenu ( NKey ) in the IPO Curve Editor window.  Positive rotations are in a counter-clockwise direction, just like in math class. | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  |   @cvar name: The Curve Data name. | 
					
						
							|  |  |  |   @cvar bezierPoints : The list of the Bezier points. | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def setExtrapolation(extrapolationtype): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the extrapolation type  of the curve. | 
					
						
							|  |  |  | 		@type extrapolationtype: string | 
					
						
							|  |  |  | 		@param extrapolationtype: the extrapolatrion type of the curve. Can be Constant, Extrapolation, Cyclic or Cyclic_extrapolation. | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |   def getExtrapolation(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the extrapolation type  of the curve. | 
					
						
							|  |  |  | 		@rtype: string | 
					
						
							|  |  |  | 		@return: the extrapolation type  of the curve.Can be Constant, Extrapolation, Cyclic or Cyclic_extrapolation. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def setInterpolation(interpolationtype): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Sets the interpolation type  of the curve. | 
					
						
							|  |  |  | 		@type interpolationtype: string | 
					
						
							|  |  |  | 		@param interpolationtype: the interpolatrion type of the curve. Can be Constant, Bezier, or Linear. | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |   def getInterpolation(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Gets the interpolation type  of the curve. | 
					
						
							|  |  |  | 		@rtype: string | 
					
						
							|  |  |  | 		@return: the interpolation type  of the curve.Can be Constant, Bezier, or Linear. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  |   def addBezier(coordlist): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Adds a Bezier point to a curve. | 
					
						
							|  |  |  | 		@type coordlist: tuple of (at least) 2 floats | 
					
						
							|  |  |  | 		@param coordlist: the x and y coordinates of the new Bezier point. | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def Recalc(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Recomputes the curent value of the curve. | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getName(): | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2004-04-02 20:26:58 +00:00
										 |  |  | 		Returns the name of the ipo curve. This name can be : LocX,LocY,LocZ,dLocX,dLocY,dLocZ,RotX,RotY,RotZ,dRotX,dRotY,dRotZ,SizeX,SizeY,SizeZ,dSizeX,dSizeY,dSizeZ,Layer,Time,ColR,ColG,ColB,ColA,QuatX,QuatY,QuatZ or QuatW. Currently only works with object and action IPO's.. | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | 		@rtype: string | 
					
						
							|  |  |  | 		@return: the name of the ipo curve. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getPoints(): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 		Returns all the points of the ipo curve. | 
					
						
							| 
									
										
										
										
											2004-03-05 05:50:50 +00:00
										 |  |  | 		@rtype: list of BezTriples | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | 		@return: the points of the ipo curve. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-06 21:13:12 +00:00
										 |  |  |   def evaluate( time ): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |                 Compute the value of the IpoCurve at a particular time. | 
					
						
							|  |  |  | 		@type time: float | 
					
						
							|  |  |  | 		@param time: value along the X axis | 
					
						
							|  |  |  | 		@rtype: float | 
					
						
							|  |  |  | 		@return: the Y value of the curve at the given time | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | class BezTriple: | 
					
						
							|  |  |  |   """
 | 
					
						
							|  |  |  |   The BezTriple object | 
					
						
							|  |  |  |   ==================== | 
					
						
							| 
									
										
										
										
											2004-04-07 22:42:02 +00:00
										 |  |  |   This object gives access to generic data from all beztriple objects in Blender.  If an attribute is listed as being 'read-only' that means you cannot write to it.  Use the set*() methods instead. | 
					
						
							|  |  |  |   @cvar pt : a list of the [x,y] coordinates for knot point of this BezTriple.  read-only. | 
					
						
							|  |  |  |   @cvar vec : a list of the 3 points [ handle, knot, handle ] that comprise a BezTriple.  See the getTriple() method for an example of the format.  read-only. | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  |   """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def getPoints(): | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2004-04-07 22:42:02 +00:00
										 |  |  | 		Returns the xy coordinates of the Bezier knot point. | 
					
						
							| 
									
										
										
										
											2004-03-05 05:50:50 +00:00
										 |  |  | 		@rtype: list of floats | 
					
						
							|  |  |  | 		@return: list of the x and y coordinates of the Bezier point. | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def setPoints(newval): | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2004-04-07 22:42:02 +00:00
										 |  |  | 		Sets the point xy coordinates of the Bezier knot point. | 
					
						
							|  |  |  | 		@type newval: tuple of 2 floats | 
					
						
							| 
									
										
										
										
											2003-08-05 10:19:28 +00:00
										 |  |  | 		@param newval: the x and y coordinates of the new Bezier point. | 
					
						
							|  |  |  | 		@rtype: PyNone | 
					
						
							|  |  |  | 		@return: PyNone | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2004-04-06 21:13:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   def getTriple(): | 
					
						
							|  |  |  |       """
 | 
					
						
							|  |  |  |                 Returns the x,y,z coordinates for each of the three points that make up a BezierTriple. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		The return list looks like this [ [H1x, H1y, H1z], [Px, Py, Pz], [H2x, H2y, H2z] ] . | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Example:: | 
					
						
							|  |  |  | 		  # where bt is of type BezierTriple | 
					
						
							|  |  |  | 		  #  and h1, p, and h2 are lists of 3 floats | 
					
						
							|  |  |  | 		  h1, p, h2 = bt.getTriple() | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		@rtype: list consisting of 3 lists of 3 floats | 
					
						
							|  |  |  |  		@return: handle1, knot, handle2 | 
					
						
							|  |  |  |        """
 |