FBNeo/README-SDL.md
BeWorld eb7523ccac SDL2: update
- Add Pause when lost focus on window and limit usage of CPU
- Update Readme.SDL
- SDL2 GUI : Add game genre information
- SDL2 GUI : Reorganization of game information (genre, number of players, etc.)
- SDL2 GUI : limit CPU usage
- SDL2 GUI : add gamepad name (when found in console)
2020-12-17 09:01:52 +01:00

3.8 KiB

FinalBurn Neo for SDL1.2/2

Differences between SDL1.2 and SDL2 versions

The SDL2 port is the recommended version as it has the following features over the SDL1.2 port:

  • A better renderer
  • OSD - shows when fast-forwarding and when FPS display is enabled via F12
  • Game selection menu which also replicates the rom scanning functionality of the Windows version of FBNeo. Handy for cabinets!
  • A lot more testing

Compiling

SDL1.2

Assuming you have a working GCC (Mingw and GCC under ubuntu 18.04 have been tested) you can just install libsdl 1.2 and type:

make sdl

And out will pop an fbneo executable.

SDL2

Assuming you have a working GCC (Mingw and GCC under ubuntu 18.04 have been tested) you can just install libsdl 2 and libsdl2-image and type:

'make sdl2'

and out will pop an fbneo executable.

SDL2 + CRT mode switching

Linux now supports modeswitching for CRT monitors using https://github.com/antonioginer/switchres (which is the switchres code of GroovyMAME extracted by its author as a library for emulators that wish to implement resolution switching). In order to get this to work, you need to:

Current known limitations:

  • the SDL2 backend doesn't support rom interlace. Although switchres can compute an interlace resolution, FBNeo isn't yet passing that flag.
  • Vertical screens are not detected, so vertical games will always be rendered as horizontal
  • in-game resolution switching is not yet supported
  • if the monitor's refresh rate is too different from the game refresh rate, no mechanism comes to smooth the video output, so tearing can happen.

Running

SDL1.2

  • First run

run the fbneo executable and an fbneo.ini will be created. You will need to edit this to point to your rom directories. You can also edit any of the other otions in the ini file as needed

  • subsiquent runs

type

'fbneo '

where is the name of a supported rom. For example

'fbneo sf2'

will run sf2.

SDL2

'-cd' used when running a neocd game. You'll have to look in the code to work out where the the CD images should be placed

'-joy' enable joystick

'-menu' load the menu

'-novsync' disable vsync

'-integerscale' only scale to the closest integer value. This will cause a border around the games unless you are running at a resolution that is a whole multiple of the games original resolution

'-fullscreen' enable fullscreen mode

'-dat' generate dat files

'-autosave' autosave/autoload a save state when starting or exiting a game

'-nearest' enbable nearest neighbour filtering (e.g. just scale the pixels)

'-linear' enable linear filter (or is it a bilinear filter) to smooth out pixels

'-best' enable sdl2 'best' filtering, which actually makes the games look the worst

recommend command line options:

'fbneo -menu -integerscale -fullscreen -joy'

The above will give you a nicely scalend game screen and the menu for launching games.

In-game controls

'TAB' - brings up the in game menu (or game PAUSE) 'F12' - quit game. 'F1' - fast forward game. 'F11' - show FPS counter 'F6' - Screenshot 'ALT-ENTER' - Switch window/fullscreen

SDL2 in menu controls

'F1' - Rescan current roms 'F2' - enable/disable filtering 'F3' - Swap current system 'F12' - quit menu. This will return you to the game select menu if run with '-menu'. Press 'f12' again to quit 'q'/'w' - Skip to next letter 'ALT-ENTER' - Switch window/fullscreen