shithub: zelda3

Download patch

ref: 5efb2cacb879f4005a21a7e73947ee6fcb7a596d
parent: 49cc686ed4e90acd09936f1a5eaf3870d110172c
author: Snesrev <snesrev@protonmail.com>
date: Mon Sep 12 15:30:37 EDT 2022

Change "Zoom" to "Scale" #81

--- a/config.c
+++ b/config.c
@@ -33,7 +33,7 @@
   _(SDLK_1), _(SDLK_2), _(SDLK_3), _(SDLK_4), _(SDLK_5), _(SDLK_6), _(SDLK_7), _(SDLK_8), _(SDLK_9), _(SDLK_0), _(SDLK_MINUS), _(SDLK_EQUALS), _(SDLK_BACKSPACE), N, N, N, N, N, N, N,
   // Replay Ref State
   C(SDLK_1), C(SDLK_2), C(SDLK_3), C(SDLK_4), C(SDLK_5), C(SDLK_6), C(SDLK_7), C(SDLK_8), C(SDLK_9), C(SDLK_0), C(SDLK_MINUS), C(SDLK_EQUALS), C(SDLK_BACKSPACE), N, N, N, N, N, N, N,
-  // CheatLife, CheatKeys, CheatEquipment, ClearKeyLog, StopReplay, Fullscreen, Reset, Pause, PauseDimmed, Turbo, ZoomIn, ZoomOut, DisplayPerf, ToggleRenderer
+  // CheatLife, CheatKeys, CheatEquipment, ClearKeyLog, StopReplay, Fullscreen, Reset, Pause, PauseDimmed, Turbo, WindowBigger, WindowSmaller, DisplayPerf, ToggleRenderer
   _(SDLK_w), _(SDLK_o), S(SDLK_w), _(SDLK_k), _(SDLK_l), A(SDLK_RETURN), _(SDLK_e), S(SDLK_p), _(SDLK_p), _(SDLK_t), N, N, _(SDLK_f), _(SDLK_r),
 };
 #undef _
@@ -52,7 +52,7 @@
 static const KeyNameId kKeyNameId[] = {
   M(Controls), M(Load), M(Save), M(Replay), M(LoadRef), M(ReplayRef),
   S(CheatLife), S(CheatKeys), S(CheatEquipment), S(ClearKeyLog), S(StopReplay), S(Fullscreen), S(Reset),
-  S(Pause), S(PauseDimmed), S(Turbo), S(ZoomIn), S(ZoomOut), S(DisplayPerf), S(ToggleRenderer),
+  S(Pause), S(PauseDimmed), S(Turbo), S(WindowBigger), S(WindowSmaller), S(DisplayPerf), S(ToggleRenderer),
 };
 #undef S
 #undef M
@@ -219,8 +219,8 @@
     } else if (StringEqualsNoCase(key, "Fullscreen")) {
       g_config.fullscreen = (uint8)strtol(value, (char**)NULL, 10);
       return true;
-    } else if (StringEqualsNoCase(key, "Zoom")) {
-      g_config.zoom = (uint8)strtol(value, (char**)NULL, 10);
+    } else if (StringEqualsNoCase(key, "WindowScale")) {
+      g_config.window_scale = (uint8)strtol(value, (char**)NULL, 10);
       return true;
     }
   } else if (section == 2) {
--- a/config.h
+++ b/config.h
@@ -25,8 +25,8 @@
   kKeys_Pause,
   kKeys_PauseDimmed,
   kKeys_Turbo,
-  kKeys_ZoomIn,
-  kKeys_ZoomOut,
+  kKeys_WindowBigger,
+  kKeys_WindowSmaller,
   kKeys_DisplayPerf,
   kKeys_ToggleRenderer,
   kKeys_Total,
@@ -37,7 +37,7 @@
   bool new_renderer;
   bool ignore_aspect_ratio;
   uint8 fullscreen;
-  uint8 zoom;
+  uint8 window_scale;
   uint16 audio_freq;
   uint8 audio_channels;
   uint16 audio_samples;
--- a/main.c
+++ b/main.c
@@ -46,8 +46,8 @@
   kRenderWidth = 256 * 2,
   kRenderHeight = 224 * 2,
   kDefaultFullscreen = 0,
-  kDefaultZoom = 2,
-  kMaxZoom = 10,
+  kDefaultWindowScale = 2,
+  kMaxWindowScale = 10,
   kDefaultFreq = 44100,
   kDefaultChannels = 2,
   kDefaultSamples = 2048,
@@ -59,7 +59,7 @@
 static SDL_Window *g_window;
 static SDL_Renderer *g_renderer;
 static uint8 g_paused, g_turbo = true, g_cursor = true;
-static uint8 g_current_zoom;
+static uint8 g_current_window_scale;
 static int g_samples_per_block;
 static uint8 g_gamepad_buttons;
 static int g_input1_state;
@@ -84,10 +84,10 @@
 }
 
 
-void DoZoom(int zoom_step) {
+void ChangeWindowScale(int scale_step) {
   int screen = SDL_GetWindowDisplayIndex(g_window);
   if (screen < 0) screen = 0;
-  int max_zoom = kMaxZoom;
+  int max_scale = kMaxWindowScale;
   SDL_Rect bounds;
   int bt = -1, bl, bb, br;
   // note this takes into effect Windows display scaling, i.e., resolution is divided by scale factor
@@ -98,15 +98,15 @@
       bl = br = bb = 1;
       bt = 31;
     }
-    // Allow a zoom level slightly above the max that fits on screen
-    int mw = (bounds.w - bl - br + (kRenderWidth / kDefaultZoom) / 4) / (kRenderWidth / kDefaultZoom);
-    int mh = (bounds.h - bt - bb + (kRenderHeight / kDefaultZoom) / 4) / (kRenderHeight / kDefaultZoom);
-    max_zoom = IntMin(mw, mh);
+    // Allow a scale level slightly above the max that fits on screen
+    int mw = (bounds.w - bl - br + (kRenderWidth / kDefaultWindowScale) / 4) / (kRenderWidth / kDefaultWindowScale);
+    int mh = (bounds.h - bt - bb + (kRenderHeight / kDefaultWindowScale) / 4) / (kRenderHeight / kDefaultWindowScale);
+    max_scale = IntMin(mw, mh);
   }
-  int new_zoom = IntMax(IntMin(g_current_zoom + zoom_step, max_zoom), 1);
-  g_current_zoom = new_zoom;
-  int w = new_zoom * (kRenderWidth / kDefaultZoom);
-  int h = new_zoom * (kRenderHeight / kDefaultZoom);
+  int new_scale = IntMax(IntMin(g_current_window_scale + scale_step, max_scale), 1);
+  g_current_window_scale = new_scale;
+  int w = new_scale * (kRenderWidth / kDefaultWindowScale);
+  int h = new_scale * (kRenderHeight / kDefaultWindowScale);
   
   //SDL_RenderSetLogicalSize(g_renderer, w, h);
   SDL_SetWindowSize(g_window, w, h);
@@ -186,14 +186,14 @@
   else if (g_config.fullscreen == 2)
     g_win_flags ^= SDL_WINDOW_FULLSCREEN;
 
-  // Window zoom (0=50%, 1=100%, 2=200%, 3=300%, etc.)
-  g_current_zoom = g_config.zoom == 0 ? 1 : IntMin(g_config.zoom * 2, kMaxZoom);
+  // Window scale (0=50%, 1=100%, 2=200%, 3=300%, etc.)
+  g_current_window_scale = g_config.window_scale == 0 ? 1 : IntMin(g_config.window_scale * 2, kMaxWindowScale);
 
   // audio_freq: Use common sampling rates (see user config file. values higher than 48000 are not supported.)
   if (g_config.audio_freq < 11025 || g_config.audio_freq > 48000)
     g_config.audio_freq = kDefaultFreq;
   
-  // Currently, the SPC/DSP implementation only supports up to stereo.
+  // Currently, the SPC/DSP implementation �only supports up to stereo.
   if (g_config.audio_channels < 1 || g_config.audio_channels > 2)
     g_config.audio_channels = kDefaultChannels;
   
@@ -207,8 +207,8 @@
     return 1;
   }
 
-  int window_width = g_current_zoom * (kRenderWidth / kDefaultZoom);
-  int window_height = g_current_zoom * (kRenderHeight / kDefaultZoom);
+  int window_width = g_current_window_scale * (kRenderWidth / kDefaultWindowScale);
+  int window_height = g_current_window_scale * (kRenderHeight / kDefaultWindowScale);
   SDL_Window* window = SDL_CreateWindow(kWindowTitle, SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, window_width, window_height, g_win_flags);
   if(window == NULL) {
     printf("Failed to create window: %s\n", SDL_GetError());
@@ -306,7 +306,7 @@
         break;
       case SDL_MOUSEWHEEL:
         if (((g_win_flags & SDL_WINDOW_FULLSCREEN_DESKTOP) == 0 || (g_win_flags & SDL_WINDOW_FULLSCREEN) == 0) && event.wheel.y != 0 && SDL_GetModState() & KMOD_CTRL)
-          DoZoom(event.wheel.y > 0 ? 1 : -1);
+          ChangeWindowScale(event.wheel.y > 0 ? 1 : -1);
         break;
       case SDL_MOUSEBUTTONDOWN:
         if (event.button.button == SDL_BUTTON_LEFT && event.button.state == SDL_PRESSED && event.button.clicks == 2) {
@@ -549,8 +549,8 @@
       }
       break;
     case kKeys_Turbo: g_turbo = !g_turbo; break;
-    case kKeys_ZoomIn: DoZoom(1); break;
-    case kKeys_ZoomOut: DoZoom(-1); break;
+    case kKeys_WindowBigger: ChangeWindowScale(1); break;
+    case kKeys_WindowSmaller: ChangeWindowScale(-1); break;
     case kKeys_DisplayPerf: g_display_perf ^= 1; break;
     case kKeys_ToggleRenderer: g_ppu_render_flags ^= kPpuRenderFlags_NewRenderer; break;
     default: assert(0);
--- a/zelda3.ini
+++ b/zelda3.ini
@@ -7,8 +7,8 @@
 [Graphics]
 # Fullscreen mode (0=windowed, 1=desktop fullscreen, 2=fullscreen w/mode change)
 Fullscreen = 0
-# Window zoom (0=50%, 1=100%, 2=200%, 3=300%, etc.)
-Zoom = 2
+# Window scale (0=50%, 1=100%, 2=200%, 3=300%, etc.)
+WindowScale = 2
 NewRenderer = 1
 EnhancedMode7 = 1
 IgnoreAspectRatio = 0
@@ -45,8 +45,8 @@
 Pause = Shift+p
 PauseDimmed = p
 Turbo = t
-ZoomIn = Ctrl+Up
-ZoomOut = Ctrl+Down
+WindowBigger = Ctrl+Up
+WindowSmaller = Ctrl+Down
 
 Load =      F1,     F2,     F3,     F4,     F5,     F6,     F7,     F8,     F9,     F10
 Save = Shift+F1,Shift+F2,Shift+F3,Shift+F4,Shift+F5,Shift+F6,Shift+F7,Shift+F8,Shift+F9,Shift+F10