aboutsummaryrefslogtreecommitdiff
path: root/src/physac.c
diff options
context:
space:
mode:
authorRay <raysan5@gmail.com>2016-03-23 16:39:24 +0100
committerRay <raysan5@gmail.com>2016-03-23 16:39:24 +0100
commitdb3dd9d200f0c70538960c61ce43c00bfd4a2182 (patch)
tree2850c0cbd1ec53e25cf70fd951518efd636b2066 /src/physac.c
parent269b120104f468df5f0f00ac3a173770aa5bf09f (diff)
parent60223a358b691c2769c362597c49e124b045209c (diff)
downloadraylib-db3dd9d200f0c70538960c61ce43c00bfd4a2182.tar.gz
raylib-db3dd9d200f0c70538960c61ce43c00bfd4a2182.zip
Merge pull request #104 from victorfisac/develop
Physac redesign complete
Diffstat (limited to 'src/physac.c')
-rw-r--r--src/physac.c49
1 files changed, 26 insertions, 23 deletions
diff --git a/src/physac.c b/src/physac.c
index 718a06bb..e3f956ba 100644
--- a/src/physac.c
+++ b/src/physac.c
@@ -2,7 +2,7 @@
*
* [physac] raylib physics module - Basic functions to apply physics to 2D objects
*
-* Copyright (c) 2015 Victor Fisac and Ramon Santamaria
+* Copyright (c) 2016 Victor Fisac and Ramon Santamaria
*
* This software is provided "as-is", without any express or implied warranty. In no event
* will the authors be held liable for any damages arising from the use of this software.
@@ -75,10 +75,7 @@ void InitPhysics(Vector2 gravity)
void UpdatePhysics()
{
// Reset all physic objects is grounded state
- for (int i = 0; i < physicObjectsCount; i++)
- {
- if (physicObjects[i]->rigidbody.enabled) physicObjects[i]->rigidbody.isGrounded = false;
- }
+ for (int i = 0; i < physicObjectsCount; i++) physicObjects[i]->rigidbody.isGrounded = false;
for (int steps = 0; steps < PHYSICS_STEPS; steps++)
{
@@ -537,26 +534,32 @@ void ApplyForceAtPosition(Vector2 position, float force, float radius)
{
for(int i = 0; i < physicObjectsCount; i++)
{
- // Calculate direction and distance between force and physic object pposition
- Vector2 distance = (Vector2){ physicObjects[i]->transform.position.x - position.x, physicObjects[i]->transform.position.y - position.y };
-
- if(physicObjects[i]->collider.type == COLLIDER_RECTANGLE)
+ if(physicObjects[i]->rigidbody.enabled)
{
- distance.x += physicObjects[i]->transform.scale.x/2;
- distance.y += physicObjects[i]->transform.scale.y/2;
- }
-
- float distanceLength = Vector2Length(distance);
-
- // Check if physic object is in force range
- if(distanceLength <= radius)
- {
- // Normalize force direction
- distance.x /= distanceLength;
- distance.y /= -distanceLength;
+ // Calculate direction and distance between force and physic object pposition
+ Vector2 distance = (Vector2){ physicObjects[i]->transform.position.x - position.x, physicObjects[i]->transform.position.y - position.y };
+
+ if(physicObjects[i]->collider.type == COLLIDER_RECTANGLE)
+ {
+ distance.x += physicObjects[i]->transform.scale.x/2;
+ distance.y += physicObjects[i]->transform.scale.y/2;
+ }
+
+ float distanceLength = Vector2Length(distance);
- // Apply force to the physic object
- ApplyForce(physicObjects[i], (Vector2){ distance.x*force, distance.y*force });
+ // Check if physic object is in force range
+ if(distanceLength <= radius)
+ {
+ // Normalize force direction
+ distance.x /= distanceLength;
+ distance.y /= -distanceLength;
+
+ // Calculate final force
+ Vector2 finalForce = { distance.x*force, distance.y*force };
+
+ // Apply force to the physic object
+ ApplyForce(physicObjects[i], finalForce);
+ }
}
}
}