Skip to content

thededman/MAME4iOS

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MAME4iOS

Original Author: David Valdeita (Seleuco)

This is a port of MAME for iOS. The currently supported rom set version is 0.139.

It has been updated to compile and run on Xcode 7/iOS 9 by Les Bird (http://www.lesbird.com/iMame4All/iMame4All_Xcode.html), and he has graciously added support for mFi Controllers.

This repo adds support for:

  • 64-bit binary to run on modern and future iOS devices
  • Multiple mFi controllers (up to 4 with dual analog support - @DarrenBranford)
  • Builds in Xcode 8, runs on iOS 10

Installation / Sideloading

Requirements: Mac with Xcode 7

Building MAME4iOS requires a prebuilt MAME binary. It was not included in this repo due to its large size. This is done by running make at the root directory of the project. This will build the 64-bit version of the MAME binary by default and will only work for modern iOS devices (iPhone 5S and above, iPad Air and above, iPad mini 2 and above). To build the 32-bit version, use the command: make iOSARMV7=1.

Or, you can download a prebuilt binary here (64-bit) or here (32-bit).

Place the file in the root directory of the repo. Choose the appropraite build target (MAME4iOS 64-bit or MAME4iOS 32-bit).

Even if you are not in the paid Apple Developer Program, you can sideload the app using a Mac with Xcode 7/8.

  1. Open the Xcode project in xcode/MAME4iOS/MAME4iOS.xcodeproj
  2. Make sure you have the libmamearm64.a (or libmamearmv7.a) file in the root of your project (it should not be red).
  3. If you are a developer, build and run on your device
  4. If you are not a developer, open Preferences and add your Apple ID, select your Personal Team, and create an iOS Development Profile.
  5. Select the project name on the left pane and make sure your personal team is selected
  6. Hit the run button to install on your device

mFi Controller Support

Pair your mFi controller with your iOS device, and it should 'just work'.

Up to 4 mfi controllers are supported. I've tested it with 2 mfi controllers and it seems to work ok. I was running MAME4iOS on my iPhone 6 Plus with a Gamevice for iPhone 6 controller and a MadCatz C.T.R.L i controller while AirPlay-ing to my Apple TV 4 and it worked great :)

Hotkey combinations

The following hotkey combinations are supported:

  • Start game (PAUSE)
  • Insert coin (Hold L and press PAUSE)
  • Open menu (Hold R and press PAUSE)
  • Exit game (Hold X and press PAUSE)

Dual analog support

The right stick on the extended controller profile is fully supported, with support for 4 players (thank you @DarrenBranford!)

Trigger buttons

The trigger buttons are mapped to analog conrols and should be useful in assigning for pedal controls, for example.

tvOS

tvOS is not supported yet. The problem is that I can't compile the tvOS version of the MAME binary, as it needs to be linked with libc++, not libstdc++, which is what this MAME binary depends on. I'm not intimately familiar with the API differences between the two (it looks like it has to do with differing string functions), so I haven't gotten around to fixing it for tvOS. You can, however, run MAME on an iPhone or iPad and mirror the display to an Apple TV.

About

iOS port of MAME

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 95.9%
  • C++ 2.9%
  • Objective-C 0.6%
  • Java 0.3%
  • Makefile 0.2%
  • Roff 0.1%