mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-09 08:31:33 +11:00
Compress combo rom (#615)
GitHub pages, for whatever reason, doesn't compress the combo ROM and instead serves it uncompressed. Therefore, we explicitly compress it using the highest compression level at build time and explicitly decompress it. Previously we would download 14.69MB, now we download 7.84MB. Approximately 50% savings.
This commit is contained in:
commit
8ddc55284c
1
justfile
1
justfile
|
@ -110,6 +110,7 @@ build-site: build-combo-rom-site build-site-mgba-wrapper build-book
|
||||||
cp book/book website/build/book -r
|
cp book/book website/build/book -r
|
||||||
cp website/app/build website/build/mgba -r
|
cp website/app/build website/build/mgba -r
|
||||||
cp examples/target/examples/combo.gba website/build/assets/combo.gba
|
cp examples/target/examples/combo.gba website/build/assets/combo.gba
|
||||||
|
gzip -9 -c website/build/assets/combo.gba > website/build/assets/combo.gba.gz
|
||||||
|
|
||||||
_run-tool +tool:
|
_run-tool +tool:
|
||||||
(cd tools && cargo build)
|
(cd tools && cargo build)
|
||||||
|
|
|
@ -41,6 +41,19 @@ export interface MgbaHandle {
|
||||||
buttonRelease: (key: GbaKey) => void;
|
buttonRelease: (key: GbaKey) => void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const downloadGame = async (gameUrl: string): Promise<ArrayBuffer> => {
|
||||||
|
const game = await fetch(gameUrl);
|
||||||
|
|
||||||
|
if (gameUrl.endsWith(".gz")) {
|
||||||
|
const decompressedStream = (await game.blob())
|
||||||
|
.stream()
|
||||||
|
.pipeThrough(new DecompressionStream("gzip"));
|
||||||
|
return await new Response(decompressedStream).arrayBuffer();
|
||||||
|
} else {
|
||||||
|
return await game.arrayBuffer();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
export const Mgba = forwardRef<MgbaHandle, MgbaProps>(
|
export const Mgba = forwardRef<MgbaHandle, MgbaProps>(
|
||||||
({ gameUrl, volume, controls, paused }, ref) => {
|
({ gameUrl, volume, controls, paused }, ref) => {
|
||||||
const canvas = useRef(null);
|
const canvas = useRef(null);
|
||||||
|
@ -52,9 +65,7 @@ export const Mgba = forwardRef<MgbaHandle, MgbaProps>(
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (state !== MgbaState.Initialised) return;
|
if (state !== MgbaState.Initialised) return;
|
||||||
(async () => {
|
(async () => {
|
||||||
const game = await fetch(gameUrl);
|
const gameData = await downloadGame(gameUrl);
|
||||||
const gameData = await game.arrayBuffer();
|
|
||||||
|
|
||||||
const gameSplit = gameUrl.split("/");
|
const gameSplit = gameUrl.split("/");
|
||||||
const gameBaseName = gameSplit[gameSplit.length - 1];
|
const gameBaseName = gameSplit[gameSplit.length - 1];
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,6 @@ export const useFrameSkip = (mgbaModule: MutableRefObject<mGBAEmulator>) => {
|
||||||
const raf = (time: DOMHighResTimeStamp) => {
|
const raf = (time: DOMHighResTimeStamp) => {
|
||||||
if (previous) {
|
if (previous) {
|
||||||
const delta = time - previous;
|
const delta = time - previous;
|
||||||
console.log(delta);
|
|
||||||
|
|
||||||
smoothedFrameTime = (smoothedFrameTime * 3 + delta) / 4;
|
smoothedFrameTime = (smoothedFrameTime * 3 + delta) / 4;
|
||||||
|
|
||||||
|
|
|
@ -155,7 +155,7 @@
|
||||||
<iframe
|
<iframe
|
||||||
id="gameFrame"
|
id="gameFrame"
|
||||||
onload="this.contentWindow.focus()"
|
onload="this.contentWindow.focus()"
|
||||||
src="mgba/index.html#/assets/combo.gba"
|
src="mgba/index.html#/assets/combo.gba.gz"
|
||||||
></iframe>
|
></iframe>
|
||||||
<div class="imageWrapper"><img src="assets/right.png" /></div>
|
<div class="imageWrapper"><img src="assets/right.png" /></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue