Added fps unlocker

This commit is contained in:
Observer KRypt0n_ 2022-01-02 19:44:12 +02:00
parent 9a2666b8b3
commit d90f339eb1
No known key found for this signature in database
GPG key ID: DC5D4EC1303465DA
6 changed files with 81 additions and 11 deletions

View file

@ -2,6 +2,7 @@
import { _ } from 'svelte-i18n'; import { _ } from 'svelte-i18n';
export let active: boolean = false; export let active: boolean = false;
export let disabled: boolean = false;
export let prop: string = ''; export let prop: string = '';
export let lang: string = ''; export let lang: string = '';
@ -27,7 +28,7 @@
} }
</script> </script>
<div class="checkbox" class:checkbox-active={active}> <div class="checkbox" class:checkbox-active={active} class:checkbox-disabled={disabled}>
<span <span
class:hint--bottom={tooltip !== ''} class:hint--bottom={tooltip !== ''}
class:hint--medium={tooltip !== ''} class:hint--medium={tooltip !== ''}

View file

@ -3,6 +3,7 @@
import { _, locale, locales } from 'svelte-i18n'; import { _, locale, locales } from 'svelte-i18n';
import Configs from './ts/Configs'; import Configs from './ts/Configs';
import FPSUnlock from './ts/FPSUnlock';
import Checkbox from './components/Checkbox.svelte'; import Checkbox from './components/Checkbox.svelte';
import SelectionBox from './components/SelectionBox.svelte'; import SelectionBox from './components/SelectionBox.svelte';
@ -102,7 +103,8 @@
}; };
let dxvkRecommendable = true, let dxvkRecommendable = true,
runnersRecommendable = true; runnersRecommendable = true,
fpsUnlockerAvailable = true;
// Auto theme switcher // Auto theme switcher
Configs.get('theme').then((theme) => switchTheme(theme as string)); Configs.get('theme').then((theme) => switchTheme(theme as string));
@ -168,6 +170,15 @@
lang="settings.enhancements.items.fps_unlocker.title" lang="settings.enhancements.items.fps_unlocker.title"
tooltip="settings.enhancements.items.fps_unlocker.tooltip" tooltip="settings.enhancements.items.fps_unlocker.tooltip"
prop="fps_unlocker" prop="fps_unlocker"
disabled={!fpsUnlockerAvailable}
valueChanged={async (checked) => {
if (checked && !await FPSUnlock.installed())
{
fpsUnlockerAvailable = false;
FPSUnlock.install().then(() => fpsUnlockerAvailable = true);
}
}}
/> />
<Checkbox <Checkbox

View file

@ -144,6 +144,18 @@ class Paths
{ {
return new Promise(async (resolve) => resolve(`${await this.gameDataDir}/StreamingAssets/Audio/GeneratedSoundBanks/Windows`)); return new Promise(async (resolve) => resolve(`${await this.gameDataDir}/StreamingAssets/Audio/GeneratedSoundBanks/Windows`));
} }
/**
* FPS Unlock directory
*
* @default "~/.local/share/anime-game-launcher/game/drive_c/Program Files/fpsunlock"
*
* @returns "[constants.paths.prefix.current]/drive_c/Program Files/fpsunlock"
*/
public static get fpsunlockDir(): Promise<string>
{
return new Promise(async (resolve) => resolve(`${await this.prefix.current}/drive_c/Program Files/fpsunlock`));
}
} }
export default class constants export default class constants
@ -175,7 +187,11 @@ export default class constants
`log-upload-os.${this.placeholders.lowercase.company}.com`, `log-upload-os.${this.placeholders.lowercase.company}.com`,
'overseauspider.yuanshen.com' 'overseauspider.yuanshen.com'
], ],
winetricks: 'https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks' winetricks: 'https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks',
fpsunlock: {
unlocker: `https://github.com/34736384/${this.placeholders.lowercase.first}-fps-unlock/releases/download/v1.4.2/unlockfps.exe`,
bat: 'https://dev.kaifa.ch/Maroxy/an-anime-game-aur/raw/branch/fpsunlock/fpsunlock.bat'
}
}; };
// TODO: cache drops at that dates instead of the 7 days period // TODO: cache drops at that dates instead of the 7 days period

46
src/ts/FPSUnlock.ts Normal file
View file

@ -0,0 +1,46 @@
import constants from './Constants';
import Downloader from './core/Downloader';
import Process from './neutralino/Process';
declare const Neutralino;
export default class FPSUnlock
{
/**
* Check if the FPS Unlock installed
*/
public static installed(): Promise<boolean>
{
return new Promise(async (resolve) => {
Neutralino.filesystem.getStats(await constants.paths.fpsunlockDir)
.then(() => resolve(true))
.catch(() => resolve(false));
});
}
/**
* Install FPS unlocker
*/
public static install(): Promise<void>
{
return new Promise(async (resolve) => {
const fpsunlockDir = await constants.paths.fpsunlockDir;
await Neutralino.filesystem.createDirectory(fpsunlockDir);
Downloader.download(constants.uri.fpsunlock.unlocker, `${fpsunlockDir}/unlockfps.exe`).then((stream) => {
stream.finish(async () => {
const fpsunlockBat = `${await constants.paths.gameDir}/unlockfps.bat`;
Downloader.download(constants.uri.fpsunlock.bat, fpsunlockBat).then((stream) => {
stream.finish(async () => {
// sed -i 's/start ..\/GI_FPSUnlocker\/unlockfps.exe \%\*/start ..\/fpsunlock\/unlockfps.exe \%\*/g' unlockfps.bat
Neutralino.os.execCommand(`sed -i 's/start ..\\/GI_FPSUnlocker\\/unlockfps.exe \\%\\*/start ..\\/fpsunlock\\/unlockfps.exe \\%\\*/g' '${Process.addSlashes(fpsunlockBat)}'`)
.then(() => resolve());
});
});
});
});
});
}
};

View file

@ -11,8 +11,6 @@ import { DebugThread } from '../core/Debug';
import DXVK from '../core/DXVK'; import DXVK from '../core/DXVK';
import IPC from '../core/IPC'; import IPC from '../core/IPC';
declare const Neutralino;
export default class State export default class State
{ {
public launcher: Launcher; public launcher: Launcher;
@ -157,7 +155,7 @@ export default class State
break; break;
case 'patch-unavailable': case 'patch-unavailable':
// todo some warning message // TODO: some warning message
this.launchButton.textContent = 'Patch unavailable'; this.launchButton.textContent = 'Patch unavailable';
break; break;

View file

@ -114,15 +114,13 @@ export default (): Promise<void> => {
else console.warn(`GPU ${LauncherLib.getConfig('gpu')} not found. Launching on the default GPU`); else console.warn(`GPU ${LauncherLib.getConfig('gpu')} not found. Launching on the default GPU`);
}*/ }*/
// let command = `${wineExeutable} ${LauncherLib.getConfig('fpsunlock') ? 'fpsunlock.bat' : 'launcher.bat'}`; let command = `'${Process.addSlashes(wineExeutable)}' ${await Configs.get('fps_unlocker') ? 'unlockfps.bat' : 'launcher.bat'}`;
/** /**
* Gamemode integration * Gamemode integration
*/ */
/*if (LauncherLib.getConfig('gamemode')) if (await Configs.get('gamemode'))
command = `gamemoderun ${command}`;*/ command = `gamemoderun ${command}`;
const command = `'${Process.addSlashes(wineExeutable)}' launcher.bat`;
console.log({ console.log({
WINEPREFIX: await constants.paths.prefix.current, WINEPREFIX: await constants.paths.prefix.current,