Skip to content

Commit

Permalink
fix scaling at least for MAME
Browse files Browse the repository at this point in the history
Turns out that a program that uses emscripten's SDL port to create a
"window" (by calling SDL_CreateWindow) gets exactly the canvas size
that they requested, and emscripten actually resets the canvas back to
this size on certain events (such as window resize).

This means that the application must request the scaled size, or
explictly resize the canvas using a different API. Since MAME accepts a
-resolution command-line argument, I can at least make it request a
window of the scaled size. It's not as efficient as letting the
browser scale the window, but it works.
  • Loading branch information
db48x committed Jul 14, 2019
1 parent ddb1c28 commit e4388d1
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 9 deletions.
5 changes: 4 additions & 1 deletion .dir-locals.el
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,7 @@
;;; For more information see (info "(emacs) Directory Variables")

((js-mode
(js2-basic-offset . 2)))
(js2-basic-offset . 2))
(js2-mode
(js2-include-browser-externs . t)))

1 change: 1 addition & 0 deletions example_macplus.html
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
PCELoader.fetchFile("PCE Config",
"examples/pce/pce-macclassic.cfg")),
PCELoader.emulatorJS("emulators/pce/pce-macplus.js")))
emulator.setScale(2);
emulator.start({ waitAfterDownloading: true });
</script>
</body>
Expand Down
22 changes: 14 additions & 8 deletions loader.js
Original file line number Diff line number Diff line change
Expand Up @@ -199,14 +199,15 @@ var Module = null;
cfgr.fileSystemKey(game),
cfgr.nativeResolution(nr[0], nr[1]),
cfgr.aspectRatio(nr[0] / nr[1]),
cfgr.scale(scale),
cfgr.sampleRate(SAMPLE_RATE)];

if ('keepAspect' in cfgr) {
cfgr.keepAspect(modulecfg.keepAspect);
config_args.push(cfgr.keepAspect(modulecfg.keepAspect));
}

if (/archive\.org$/.test(document.location.hostname)) {
cfgr.muted(!(typeof $ !== 'undefined' && $.cookie && $.cookie('unmute')));
config_args.push(cfgr.muted(!(typeof $ !== 'undefined' && $.cookie && $.cookie('unmute'))));
}

if (module && module.indexOf("dosbox") === 0) {
Expand Down Expand Up @@ -662,6 +663,10 @@ var Module = null;
return { aspectRatio: ratio };
};

BaseLoader.scale = function (scale) {
return { scale: scale };
};

BaseLoader.sampleRate = function (rate) {
return { sample_rate: rate };
};
Expand Down Expand Up @@ -742,7 +747,7 @@ var Module = null;
config.emulator_arguments = build_mame_arguments(config.muted, config.mame_driver,
config.nativeResolution, config.sample_rate,
config.peripheral, config.extra_mame_args,
config.keep_aspect);
config.keep_aspect, config.scale);
config.runner = MAMERunner;
return config;
}
Expand Down Expand Up @@ -887,15 +892,16 @@ var Module = null;
return { extra_np2_args: args };
};

var build_mame_arguments = function (muted, driver, native_resolution, sample_rate, peripheral, extra_args, keepaspect) {
var build_mame_arguments = function (muted, driver, native_resolution, sample_rate, peripheral, extra_args, keepaspect, scale) {
scale = scale || 1;
var args = [driver,
'-verbose',
'-rompath', 'emulator',
'-window',
keepaspect ? '-keepaspect' : '-nokeepaspect'];

if (native_resolution && "width" in native_resolution && "height" in native_resolution) {
args.push('-resolution', [native_resolution.width, native_resolution.height].join('x'));
args.push('-resolution', [native_resolution.width * scale, native_resolution.height * scale].join('x'));
}

if (muted) {
Expand Down Expand Up @@ -1562,7 +1568,7 @@ var Module = null;

function setup_runner() {
var runner = new game_data.runner(canvas, game_data);
resizeCanvas(canvas, 1, game_data.nativeResolution, game_data.aspectRatio);
resizeCanvas(canvas, scale, game_data.nativeResolution, game_data.aspectRatio);
runner.onStarted(function () {
splash.finished_loading = true;
splash.hide();
Expand Down Expand Up @@ -1686,8 +1692,8 @@ var Module = null;

canvas.style.width = resolution.width * scale +'px';
canvas.style.height = resolution.height * scale +'px';
canvas.width = resolution.width;
canvas.height = resolution.height;
canvas.setAttribute("width", resolution.width * scale);
canvas.setAttribute("height", resolution.height * scale);
}
};

Expand Down

0 comments on commit e4388d1

Please sign in to comment.