aboutsummaryrefslogtreecommitdiff
path: root/examples/core_2d_camera.c
diff options
context:
space:
mode:
authorvictorfisac <victorfisac@gmail.com>2016-05-20 14:03:23 +0200
committervictorfisac <victorfisac@gmail.com>2016-05-20 14:03:23 +0200
commit4f1bee31654dec5f5cea2ac9d291d202df504745 (patch)
tree42a5028ebab3277a8d46bdcf3fea2990e1aa590d /examples/core_2d_camera.c
parentea7afc8ec835040d84d79ae318f7aebb9f1e189c (diff)
parentdcf5f45f687f2a534286aecd5e6471a0440b0c21 (diff)
downloadraylib-4f1bee31654dec5f5cea2ac9d291d202df504745.tar.gz
raylib-4f1bee31654dec5f5cea2ac9d291d202df504745.zip
Merge remote-tracking branch 'refs/remotes/raysan5/develop' into develop
Diffstat (limited to 'examples/core_2d_camera.c')
-rw-r--r--examples/core_2d_camera.c36
1 files changed, 27 insertions, 9 deletions
diff --git a/examples/core_2d_camera.c b/examples/core_2d_camera.c
index 71c474f0..5e6b7c6c 100644
--- a/examples/core_2d_camera.c
+++ b/examples/core_2d_camera.c
@@ -22,11 +22,14 @@ int main()
Camera2D camera;
- camera.position = (Vector2){ 0, 0 };
- camera.origin = (Vector2){ 100, 100 };
+ camera.offset = (Vector2){ 0, 0 };
+ camera.target = (Vector2){ 400, 200 };
camera.rotation = 0.0f;
camera.zoom = 1.0f;
+ Rectangle player = { 400, 200, 40, 40 };
+ camera.target = (Vector2){ player.x + 20, player.y + 20 };
+
SetTargetFPS(60);
//--------------------------------------------------------------------------------------
@@ -35,16 +38,28 @@ int main()
{
// Update
//----------------------------------------------------------------------------------
- if (IsKeyDown(KEY_RIGHT)) camera.position.x--;
- else if (IsKeyDown(KEY_LEFT)) camera.position.x++;
- else if (IsKeyDown(KEY_UP)) camera.position.y++;
- else if (IsKeyDown(KEY_DOWN)) camera.position.y--;
+ if (IsKeyDown(KEY_RIGHT)) player.x -= 2;
+ else if (IsKeyDown(KEY_LEFT)) player.x += 2;
+ else if (IsKeyDown(KEY_UP)) player.y -= 2;
+ else if (IsKeyDown(KEY_DOWN)) player.y += 2;
+
+ // Camera target follows player
+ camera.target = (Vector2){ player.x + 20, player.y + 20 };
if (IsKeyDown(KEY_R)) camera.rotation--;
else if (IsKeyDown(KEY_F)) camera.rotation++;
- if (IsKeyDown(KEY_W)) camera.zoom += 0.005f;
- if (IsKeyDown(KEY_S)) camera.zoom -= 0.005f;
+ // Camera controls
+ if (IsKeyDown(KEY_R)) camera.rotation--;
+ else if (IsKeyDown(KEY_F)) camera.rotation++;
+
+ camera.zoom += ((float)GetMouseWheelMove()*0.05f);
+
+ if (IsKeyPressed(KEY_Z))
+ {
+ camera.zoom = 1.0f;
+ camera.rotation = 0.0f;
+ }
//----------------------------------------------------------------------------------
// Draw
@@ -56,7 +71,10 @@ int main()
DrawText("2D CAMERA TEST", 20, 20, 20, GRAY);
DrawRectangle(0, 300, screenWidth, 50, GRAY);
- DrawRectangle(400, 250, 40, 40, RED);
+ DrawRectangleRec(player, RED);
+
+ DrawRectangle(camera.origin.x, 0, 1, screenHeight, GREEN);
+ DrawRectangle(0, camera.origin.y, screenWidth, 1, GREEN);
EndDrawing();
//----------------------------------------------------------------------------------