summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortalha <sarcxd@gmail.com>2024-10-26 18:08:24 +0500
committertalha <sarcxd@gmail.com>2024-10-26 18:08:24 +0500
commit6aefb4d7d1405b378a7e6e07037c829394b1fcfd (patch)
treed155323a918a0722b3dff822e09e49938fde344c
parent1f4aa60399ee7b0f0d4cd8c78066c54c25cf2a15 (diff)
Moved from using percentages to scaled pixel position for levels
-rw-r--r--levels/level0.txt5
-rwxr-xr-xsource/main.cpp12
2 files changed, 12 insertions, 5 deletions
diff --git a/levels/level0.txt b/levels/level0.txt
new file mode 100644
index 0000000..abc4abc
--- /dev/null
+++ b/levels/level0.txt
@@ -0,0 +1,5 @@
+//thinking of format like so
+// entity_id|width height|posx posy posz
+0|40 40|20 70 -1
+1|30 1|640 400 -2
+
diff --git a/source/main.cpp b/source/main.cpp
index 648dba6..0e38806 100755
--- a/source/main.cpp
+++ b/source/main.cpp
@@ -25,8 +25,11 @@
* - movement and deceleration when not moving in free fall
* - Jumping
* - Fixed framerate to prevent weird quirks with movement
+* - Basic camera follower
* TODO:
* - Some way to make and define levels
+* - Update camera follower for centering player in view (with limits) after
+* a few seconds (maybe like 2 seconds)
* - Level completion Object
* - Implement Broad Phase Collision for efficient collision handling
* - Efficient Quad Renderer
@@ -726,13 +729,12 @@ int main(int argc, char* argv[])
// @thinking: level object handling
// there should be a most smallest supported unit
// smallest_size: 16x16
- // object placement should be in percentages
- // bottom: y%, left: x%
- // this will allow it to scale with different resolutions
+ // object placement should be in pixels
+ // in order to scale to different resolutions it should be multiplied by
+ // scaling factor
Vec2 atom_size = {16.0f, 16.0f};
- Vec3 test_percent = Vec3{60.0f, 50.0f, -2.0f};
- Vec3 floor_position = get_world_position_from_percent(state, test_percent);
+ Vec3 floor_position = Vec3{640.0f*render_scale, 400.0f*render_scale, -2.0f};
Vec2 floor_size = atom_size*Vec2{40.0f, 1.5f};
state.floor = rect(floor_position, floor_size);