2022-03-26 22:18:26 -04:00
|
|
|
package funkin.util;
|
|
|
|
|
2023-01-02 17:40:53 -05:00
|
|
|
import flixel.util.FlxSignal.FlxTypedSignal;
|
|
|
|
|
2023-11-23 19:48:28 -05:00
|
|
|
using StringTools;
|
|
|
|
|
2023-11-07 04:04:22 -05:00
|
|
|
/**
|
|
|
|
* Utilities for operating on the current window, such as changing the title.
|
|
|
|
*/
|
2023-03-01 20:27:29 -05:00
|
|
|
#if (cpp && windows)
|
2023-01-22 19:55:30 -05:00
|
|
|
@:cppFileCode('
|
|
|
|
#include <iostream>
|
|
|
|
#include <windows.h>
|
|
|
|
#include <psapi.h>
|
|
|
|
')
|
|
|
|
#end
|
2022-03-26 22:18:26 -04:00
|
|
|
class WindowUtil
|
|
|
|
{
|
2023-06-25 12:36:21 -04:00
|
|
|
/**
|
|
|
|
* Runs platform-specific code to open a URL in a web browser.
|
|
|
|
* @param targetUrl The URL to open.
|
|
|
|
*/
|
2023-11-22 19:17:35 -05:00
|
|
|
public static function openURL(targetUrl:String):Void
|
2023-01-22 19:55:30 -05:00
|
|
|
{
|
|
|
|
#if CAN_OPEN_LINKS
|
|
|
|
#if linux
|
2024-05-13 16:16:49 -04:00
|
|
|
Sys.command('/usr/bin/xdg-open $targetUrl &');
|
2023-01-22 19:55:30 -05:00
|
|
|
#else
|
2023-06-25 12:36:21 -04:00
|
|
|
// This should work on Windows and HTML5.
|
2023-01-22 19:55:30 -05:00
|
|
|
FlxG.openURL(targetUrl);
|
|
|
|
#end
|
|
|
|
#else
|
2023-06-25 12:36:21 -04:00
|
|
|
throw 'Cannot open URLs on this platform.';
|
2023-01-22 19:55:30 -05:00
|
|
|
#end
|
|
|
|
}
|
2023-01-02 17:40:53 -05:00
|
|
|
|
2023-11-22 19:17:35 -05:00
|
|
|
/**
|
|
|
|
* Runs platform-specific code to open a path in the file explorer.
|
|
|
|
* @param targetPath The path to open.
|
|
|
|
*/
|
|
|
|
public static function openFolder(targetPath:String):Void
|
|
|
|
{
|
|
|
|
#if CAN_OPEN_LINKS
|
|
|
|
#if windows
|
2024-03-16 22:20:22 -04:00
|
|
|
Sys.command('explorer', [targetPath.replace('/', '\\')]);
|
2023-11-22 19:17:35 -05:00
|
|
|
#elseif mac
|
|
|
|
Sys.command('open', [targetPath]);
|
|
|
|
#elseif linux
|
|
|
|
Sys.command('open', [targetPath]);
|
|
|
|
#end
|
|
|
|
#else
|
|
|
|
throw 'Cannot open URLs on this platform.';
|
|
|
|
#end
|
|
|
|
}
|
|
|
|
|
2023-11-23 19:54:34 -05:00
|
|
|
/**
|
|
|
|
* Runs platform-specific code to open a file explorer and select a specific file.
|
|
|
|
* @param targetPath The path of the file to select.
|
|
|
|
*/
|
|
|
|
public static function openSelectFile(targetPath:String):Void
|
|
|
|
{
|
|
|
|
#if CAN_OPEN_LINKS
|
|
|
|
#if windows
|
2024-03-16 22:20:22 -04:00
|
|
|
Sys.command('explorer', ['/select,' + targetPath.replace('/', '\\')]);
|
2023-11-23 19:54:34 -05:00
|
|
|
#elseif mac
|
2024-03-16 22:20:22 -04:00
|
|
|
Sys.command('open', ['-R', targetPath]);
|
2023-11-23 19:54:34 -05:00
|
|
|
#elseif linux
|
|
|
|
// TODO: unsure of the linux equivalent to opening a folder and then "selecting" a file.
|
|
|
|
Sys.command('open', [targetPath]);
|
|
|
|
#end
|
|
|
|
#else
|
|
|
|
throw 'Cannot open URLs on this platform.';
|
|
|
|
#end
|
|
|
|
}
|
|
|
|
|
2023-01-22 19:55:30 -05:00
|
|
|
/**
|
|
|
|
* Dispatched when the game window is closed.
|
|
|
|
*/
|
|
|
|
public static final windowExit:FlxTypedSignal<Int->Void> = new FlxTypedSignal<Int->Void>();
|
2023-01-02 17:40:53 -05:00
|
|
|
|
2023-06-25 12:36:21 -04:00
|
|
|
/**
|
|
|
|
* Wires up FlxSignals that happen based on window activity.
|
|
|
|
* For example, we can run a callback when the window is closed.
|
|
|
|
*/
|
2024-03-16 22:20:22 -04:00
|
|
|
public static function initWindowEvents():Void
|
2023-01-22 19:55:30 -05:00
|
|
|
{
|
|
|
|
// onUpdate is called every frame just before rendering.
|
2023-01-02 17:40:53 -05:00
|
|
|
|
2023-01-22 19:55:30 -05:00
|
|
|
// onExit is called when the game window is closed.
|
2023-03-01 20:27:29 -05:00
|
|
|
openfl.Lib.current.stage.application.onExit.add(function(exitCode:Int) {
|
2023-01-22 19:55:30 -05:00
|
|
|
windowExit.dispatch(exitCode);
|
|
|
|
});
|
2024-04-30 00:40:42 -04:00
|
|
|
|
|
|
|
openfl.Lib.current.stage.addEventListener(openfl.events.KeyboardEvent.KEY_DOWN, (e:openfl.events.KeyboardEvent) -> {
|
2024-06-09 02:22:03 -04:00
|
|
|
for (key in PlayerSettings.player1.controls.getKeysForAction(WINDOW_FULLSCREEN))
|
2024-04-30 00:40:42 -04:00
|
|
|
{
|
|
|
|
if (e.keyCode == key)
|
|
|
|
{
|
|
|
|
openfl.Lib.application.window.fullscreen = !openfl.Lib.application.window.fullscreen;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2023-01-22 19:55:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Turns off that annoying "Report to Microsoft" dialog that pops up when the game crashes.
|
|
|
|
*/
|
2024-03-16 22:20:22 -04:00
|
|
|
public static function disableCrashHandler():Void
|
2023-01-22 19:55:30 -05:00
|
|
|
{
|
2023-03-01 20:27:29 -05:00
|
|
|
#if (cpp && windows)
|
2023-01-22 19:55:30 -05:00
|
|
|
untyped __cpp__('SetErrorMode(SEM_FAILCRITICALERRORS | SEM_NOGPFAULTERRORBOX);');
|
|
|
|
#else
|
|
|
|
// Do nothing.
|
|
|
|
#end
|
|
|
|
}
|
2023-06-22 01:41:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the title of the application window.
|
|
|
|
* @param value The title to use.
|
|
|
|
*/
|
|
|
|
public static function setWindowTitle(value:String):Void
|
|
|
|
{
|
|
|
|
lime.app.Application.current.window.title = value;
|
|
|
|
}
|
2022-03-26 22:18:26 -04:00
|
|
|
}
|