A place to discuss everything related to Newton Dynamics.
	Moderators: Sascha Willems, walaber
	
		
		
			
			
			 by mikeman42 » Tue Feb 22, 2011 8:57 am
by mikeman42 » Tue Feb 22, 2011 8:57 am 
			
			I have a problem which is simple enough, but unfortunately I haven't been able to sort it out. Basically, I'm making a podracing game, and I want the vehicles to stay "up" in respect to the track road(which is not always perpendicular to the Y axis though). So, my first method was to find out the angle(or dot product) between the vehicle's Y axis and the floor normal is, and correct it by applying a torque. Something like this:
torque=vehicle.ZAxis()*(Dot(vehicle.YAxis(),normal)-1)
However, this does not seem right when I start to rotate the vehicle around its Y-Axis, for steering. Anyone has any ideas on how the correct code should look like? Thanks!
(anb sorry for double posting this, I picked the wrong forum the first time around)
			
		 
		
			
			- 
				mikeman42
			
-  
- Posts: 19
- Joined: Tue May 01, 2007 6:08 pm
 
	 
	
	
		
		
			
			
			 by mikeman42 » Wed Feb 23, 2011 8:45 am
by mikeman42 » Wed Feb 23, 2011 8:45 am 
			
			Hm...nobody has anyone idea about how to fix this? It's pretty important for the game....thanks.
			
		 
		
			
			- 
				mikeman42
			
-  
- Posts: 19
- Joined: Tue May 01, 2007 6:08 pm
 
	 
	
	
		
		
			
			
			 by ledahut » Wed Feb 23, 2011 8:55 am
by ledahut » Wed Feb 23, 2011 8:55 am 
			
			However, this does not seem right when I start to rotate the vehicle around its Y-Axis, for steering
What is not right? the steering?, the torque reaction to compensate body rotation with ground?
 
		
			
			- 
				ledahut
			
-  
- Posts: 98
- Joined: Mon Jun 21, 2010 8:03 am
- Location: France
 
	 
	
	
		
		
			
			
			 by mikeman42 » Wed Feb 23, 2011 9:14 am
by mikeman42 » Wed Feb 23, 2011 9:14 am 
			
			I'll try to explain...when I don't rotate(steer) the vehicle at all, then the compensation does work as needed, rotating it only around the z-axis. However, when I start steering, the nose of the vehicle starts pointing upwards. What I would want is the vehicle to be able to rotate(indepedently) around the local z-axis(for compensation) and around the global Y-axis(for steering), but I can't figure out how to do this.
			
		 
		
			
			- 
				mikeman42
			
-  
- Posts: 19
- Joined: Tue May 01, 2007 6:08 pm
 
	 
	
	
		
		
			
			
			 by ledahut » Wed Feb 23, 2011 9:53 am
by ledahut » Wed Feb 23, 2011 9:53 am 
			
			Are you trying to create a car with hinge joint and adding torque to wheels?
Because it is not the good way to do.
			
		 
		
			
			- 
				ledahut
			
-  
- Posts: 98
- Joined: Mon Jun 21, 2010 8:03 am
- Location: France
 
	 
	
	
		
		
			
			
			 by mikeman42 » Wed Feb 23, 2011 10:07 am
by mikeman42 » Wed Feb 23, 2011 10:07 am 
			
			No, the game is in the initial stages right now. The car(hovercraft) right now is just a box, which I steer by rotating in the Y-axis. However, when it collides with walls sometimes it banks on one or the other direction, so I just want to use some torque around the z-axis to compensate and bring it back to balance.  It's the combination of rotating in the Y-axis and the compensation that does not work.
So ok, to make things simple, one question: If I have a simple body(a box) and I want it to rotate at the same time:
1)Around the global Y-axis.
2)Around its local Z-axis.
What kind of torque would I need to apply? I think I can figure it out from there.
			
		 
		
			
			- 
				mikeman42
			
-  
- Posts: 19
- Joined: Tue May 01, 2007 6:08 pm
 
	 
	
	
		
		
			
			
			 by ledahut » Wed Feb 23, 2011 10:39 am
by ledahut » Wed Feb 23, 2011 10:39 am 
			
			I think using local force would be better to you:
See this code in pascal from member Delphi
- Code: Select all
- // retrieves body's velocity at specific point in global space
 function GetPointGlobalVelocity(const body: PNewtonBody; Point: Vector): Vector;
 var
 velocity, omega: Vector;
 begin
 NewtonBodyGetVelocity(body, @velocity);
 NewtonBodyGetOmega(body, @omega);
 
 Result := AddVectors(velocity, crossProduct(omega, point));
 end;
 
 // retrieves body's velocity at specific point in local space
 function GetPointLocalVelocity(const body: PNewtonBody; Point: Vector): Vector;
 var
 bodymatrix: Tmatrix4F;
 begin
 NewtonBodyGetMatrix(body, @bodymatrix);
 Result := GetPointGlobalVelocity(body, MatrixRotateVector(Point, bodymatrix));
 Result := MatrixUNRotateVector(Result, bodymatrix);
 end;
 
 // adds force to body at a specified point in global space
 procedure AddPointGlobalForce(const body: PNewtonBody; PrevBodyMatrix: pointer; Force, Point: Vector);
 var
 GlobalForce: vector;
 bodymatrix:  Tmatrix4F;
 Torque:      vector;
 begin
 
 if PrevBodyMatrix = nil then
 NewtonBodyGetMatrix(body, @bodymatrix)
 else
 move(PrevBodyMatrix^, bodymatrix, sizeof(Tmatrix4F));
 
 GlobalForce.x := Point.x - bodymatrix[3][0];
 GlobalForce.y := Point.y - bodymatrix[3][1];
 GlobalForce.z := Point.z - bodymatrix[3][2];
 
 Torque := CrossProduct(GlobalForce, Force);
 
 NewtonBodyAddForce(body, @Force.x);
 NewtonBodyAddTorque(body, @Torque.x);
 end;
 
 
 // adds force to body at a specified point in local space
 procedure AddPointLocalForce(const body: PNewtonBody; Force, Point: Vector);
 var
 GlobalForce, GlobalPoint: Vector;
 bodymatrix: Tmatrix4F;
 begin
 NewtonBodyGetMatrix(body, @bodymatrix);
 
 GlobalForce := MatrixRotateVector(Force, bodymatrix);
 GlobalPoint := MatrixTransformVector(Point, bodymatrix);
 
 AddPointGlobalForce(body, @bodymatrix, GlobalForce, GlobalPoint);
 end;
And the explanation at
http://newtondynamics.com/wiki/index.ph ... _engine%3F(in this page symbol are wrong: 
/ backslash instead of 
- minus)
 
		
			
			- 
				ledahut
			
-  
- Posts: 98
- Joined: Mon Jun 21, 2010 8:03 am
- Location: France
 
	 
	
	
		
		
			
			
			 by mikeman42 » Wed Feb 23, 2011 12:17 pm
by mikeman42 » Wed Feb 23, 2011 12:17 pm 
			
			ledahut, that's a good idea...maybe I was wrong trying to control the vehicle using torque explicitly...I'll try using the article's approach and control it with positioned  'thrusters' instead...thanks!
			
		 
		
			
			- 
				mikeman42
			
-  
- Posts: 19
- Joined: Tue May 01, 2007 6:08 pm
 
	 
	
	
	
	Return to General Discussion
	
	Who is online
	Users browsing this forum: No registered users and 438 guests