-
Notifications
You must be signed in to change notification settings - Fork 65
Running the game client on Linux
While the OpenFusion server supports both Windows and Linux (and other Unix-like systems), the game client natively supports only Windows because of the NPAPI Unity Web Player plugin needed to run the game. Nevertheless, the client runs very well in Wine if configured properly.
Due to the plethora of Wine prefix managers that people use (in addition to the option of just configuring your Wine prefix by hand), there's a number of ways you could set the game up. Regardless of which you prefer, for OpenFusion there's a handful of dependencies you need to satisfy, which are common to all of them:
- Electron (
OpenFusionClient.exe
) needsallfonts
to run - It also needs to be run with the following arguments:
--no-sandbox --disable-gpu
- Using DXVK instead of
wined3d
is highly recommended to avoid graphical glitches like mission indicator rings not rendering
Here's a few possible ways to install OpenFusion through Wine:
This is the preferred and most user friendly way to set up OpenFusionClient on Linux.
Bottles is meant to be installed through Flatpak. Follow the instructions to set Flatpak up, and then install Bottles from Flathub.
If you get stuck at any part, the official Bottles documentation might be useful.
TIP: You can show hidden folders like .var
by hitting Ctrl-H in your file manager.
Once you have Bottles installed, you can proceed with setting up a bottle for OpenFusion:
- Hit the + button to create a new bottle. Name it OpenFusion and make it a Gaming environment.
- Open the bottle, click on Dependencies and click on
allfonts
to install that dependency. - In that bottle's Details view (its primary view), click on the three dots button on the top right and click Browse Files. This will open the bottle's Wine prefix in your desktop environment's file manager. The path will be something like
~/.var/app/com.usebottles.bottles/data/bottles/bottles/OpenFusion/drive_c/
- Download and extract the latest zip of the client into
users/$USER/
in the bottle. - At this point, if Bottles hasn't already detected the
OpenFusionClient.exe
you've extracted into the bottle, you can manually add it by clicking the Add Shortcuts... button in the Programs section of the Details view. - There should now be an OpenFusionClient entry. Click on the three dots on the right side of the entry, click Change Launch Options, copy
--no-sandbox --disable-gpu
into Command Arguments and hit Save. - You should now be able to run that entry and the game should work without issue.
DXVK is already set up in Bottles by default, so you don't have to worry about that.
Optionally, if your in-game mouse sensitivity is too high:
- Go back into the top-level view in Bottles, click on the Hamburger menu in the top right, an select Preferences.
- In the Runners tab, install the latest version of GE Wine.
- Go back into your OpenFusion bottle, and in Settings, under Components, change your Runner to your version of
wine-ge
.
Wine-ge supports raw input, which should prevent unwanted mouse acceleration.
If you want to be able to run the game from your application menu without opening Bottles, follow these instructions.
You might want to rename the OpenFusionClient entry to just "OpenFusion" or "FusionFall" before making the desktop entry.
If you want to manually rename or delete an existing desktop entry, you can find it in ~/.local/share/applications
.
If you have a 1440p or even higher resolution monitor, the game will bug out in fullscreen because it just wasn't meant to be run at resolutions that high. This happens on Windows as well, but on Linux we can work around the problem using Gamescope.
- Install the Flatpak version of Gamescope with:
sudo flatpak install com.valvesoftware.Steam.Utility.gamescope
- Restart Bottles
- In your bottle's Settings, under Display, enable Gamescope and configure it to upscale a Game Resolution of 1920x1080 to a Window Resolution of 2560x1440 or whichever resolution you want.
- Now the game will always start in fullscreen.
- The only awkward part is that you will now always have to press the in-game fullscreen button to get it to upscale from 1080p instead of from the default Window size of 720p.
- You can disable this at any time by disabling Gamescope for your bottle.
If you want to monitor your FPS while playing, you can enable Mangohud:
- Install the Flatpak version of Mangohud with:
sudo flatpak install org.freedesktop.Platform.VulkanLayer.MangoHud
- Restart Bottles
- In your bottle's Settings, in the Performance section, enable Monitor Performance.
- You can disable this at any point and re-launch the game.
On most Windows systems the game runs poorly, usually below 60 FPS, but we've observed it running really well on some high-end Linux systems. Let us know if the game runs really well for you in this configuration, as we need more data points to be sure there's a connection.
Lutris is another prefix manager you could use if you prefer it.
TODO: Detailed instructions
Quick notes:
- Much of the installation is similar to Bottles, but a bit lower-level.
- The default Wine version doesn't seem to work well, but
lutris-GE-Proton
should. - There isn't a user-friendly wrapper around Winetricks, so you'll have to run it directly from Lutris to install
allfonts
, and it doesn't show any window or progress bar while installing them, nor does it indicate when it's done(!). You might want to track its progress through a process manager likehtop
. - A Lutris install script could be written in the future to automate all this.
This is for advanced users who know what they're doing and prefer to manage their prefixes by hand.
I'll assume that if you're doing it this way you already understand most of this already, so these commands are approximate and not meant to be copy-pasted. In short:
- Install
wine
andwinetricks
through your distribution's package manager. - The default Wine prefix is located in
~/.wine
. This can be controlled by setting theWINEPREFIX
environment variable for each command. - You can easily install DXVK using Winetricks
WINEPREFIX=/path/to/pfx winetricks dxvk
- The same goes for
allfonts
WINEPREFIX=/path/to/pfx winetricks allfonts
- Run the client
WINEPREFIX=/path/to/pfx wine OpenFusionClient.exe --no-sandbox --disable-gpu