Browse Source

Merge pull request #4845 from bamless/log-zoom

[examples] use logarithmic zoom scaling in 2d camera examples
pull/4850/head
Ray 2 weeks ago
committed by GitHub
parent
commit
add4da8fb3
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
2 changed files with 10 additions and 8 deletions
  1. +3
    -1
      examples/core/core_2d_camera.c
  2. +7
    -7
      examples/core/core_2d_camera_mouse_zoom.c

+ 3
- 1
examples/core/core_2d_camera.c View File

@ -14,6 +14,7 @@
********************************************************************************************/ ********************************************************************************************/
#include "raylib.h" #include "raylib.h"
#include <math.h>
#define MAX_BUILDINGS 100 #define MAX_BUILDINGS 100
@ -81,7 +82,8 @@ int main(void)
else if (camera.rotation < -40) camera.rotation = -40; else if (camera.rotation < -40) camera.rotation = -40;
// Camera zoom controls // Camera zoom controls
camera.zoom += ((float)GetMouseWheelMove()*0.05f);
// Uses log scaling to provide consistent zoom speed
camera.zoom = expf(logf(camera.zoom) + ((float)GetMouseWheelMove()*0.1f));
if (camera.zoom > 3.0f) camera.zoom = 3.0f; if (camera.zoom > 3.0f) camera.zoom = 3.0f;
else if (camera.zoom < 0.1f) camera.zoom = 0.1f; else if (camera.zoom < 0.1f) camera.zoom = 0.1f;

+ 7
- 7
examples/core/core_2d_camera_mouse_zoom.c View File

@ -73,9 +73,9 @@ int main ()
camera.target = mouseWorldPos; camera.target = mouseWorldPos;
// Zoom increment // Zoom increment
kt">float scaleFactor = 1.0f + (0.25f*fabsf(wheel));
">if (wheel < 0) scaleFactor = 1.0f/scaleFactor;
camera.zoom = Clamp(camera.zoomo">*scaleFactor, 0.125f, 64.0f);
o">// Uses log scaling to provide consistent zoom speed
t">float scale = 0.2f*wheel;
camera.zoom = Clamp(expf(logf(camera.zoomp">)+scale), 0.125f, 64.0f);
} }
} }
else else
@ -96,10 +96,10 @@ int main ()
if (IsMouseButtonDown(MOUSE_BUTTON_RIGHT)) if (IsMouseButtonDown(MOUSE_BUTTON_RIGHT))
{ {
// Zoom increment // Zoom increment
// Uses log scaling to provide consistent zoom speed
float deltaX = GetMouseDelta().x; float deltaX = GetMouseDelta().x;
float scaleFactor = 1.0f + (0.01f*fabsf(deltaX));
if (deltaX < 0) scaleFactor = 1.0f/scaleFactor;
camera.zoom = Clamp(camera.zoom*scaleFactor, 0.125f, 64.0f);
float scale = 0.005f*deltaX;
camera.zoom = Clamp(expf(logf(camera.zoom)+scale), 0.125f, 64.0f);
} }
} }
//---------------------------------------------------------------------------------- //----------------------------------------------------------------------------------
@ -143,4 +143,4 @@ int main ()
CloseWindow(); // Close window and OpenGL context CloseWindow(); // Close window and OpenGL context
//-------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------
return 0; return 0;
}
}

Loading…
Cancel
Save