diff --git a/sim/fakes/_sim.py b/sim/fakes/_sim.py
index 95f801b930dc7339d7fcf1fb094fa868aa8185d4..269e88fa80bae9120292d7d76f5aca2ce415ad3e 100644
--- a/sim/fakes/_sim.py
+++ b/sim/fakes/_sim.py
@@ -25,6 +25,7 @@ background = pygame.image.load(bgpath)
 
 OLED_SIZE = int(os.environ["SIM_OLED_SIZE"])
 OLED_ASPECT = float(os.environ["SIM_OLED_ASPECT"])
+OLED_SCALE = float(os.environ["SIM_OLED_SCALE"])
 
 
 class Input:
@@ -415,11 +416,11 @@ class Simulation:
         center_x = screen_w // 2
         center_y = screen_h // 2
         if FULL_SCREEN:
-            off_x = center_x - (screen_h * OLED_ASPECT // 2)
-            off_y = center_y - (screen_h // 2)
-            new = pygame.transform.scale(
-                self._oled_surface, (screen_h * OLED_ASPECT, screen_h)
-            )
+            size_x = screen_h * OLED_ASPECT * OLED_SCALE
+            size_y = screen_h * OLED_SCALE
+            off_x = center_x - (size_x // 2)
+            off_y = center_y - (size_y // 2)
+            new = pygame.transform.scale(self._oled_surface, (size_x, size_y))
             full.blit(new, (off_x, off_y))
         else:
             off_x = center_x - (OLED_SIZE // 2)
diff --git a/sim/run.py b/sim/run.py
index 4bbff6f351a34ad6dbbb44217afa999d29cde674..d6875b238424cd2a6c3b2a7b7c563eee8ad1cfe9 100644
--- a/sim/run.py
+++ b/sim/run.py
@@ -117,12 +117,14 @@ def sim_main():
     )
     parser.add_argument("--oled-size", dest="oled_size", default=240)
     parser.add_argument("--oled-aspect", dest="oled_aspect", default=1)
+    parser.add_argument("--oled-scale", dest="oled_scale", default=1)
     parser.add_argument("override_app", nargs="?")
     args = parser.parse_args()
 
     os.environ["SIM_FULL_SCREEN"] = "1" if args.full_screen else "0"
     os.environ["SIM_OLED_SIZE"] = str(args.oled_size)
     os.environ["SIM_OLED_ASPECT"] = str(args.oled_aspect)
+    os.environ["SIM_OLED_SCALE"] = str(args.oled_scale)
     import _sim
 
     _sim.SCREENSHOT = args.screenshot