Building BasiliskII for iOS

I’ve had numerous requests for a guide to building BasiliskII on iOS. Let me know of anything is unclear or would benefit from more details!

February 2024: Updated for building with Xcode 15.2 on macOS 14.3 to iOS 17.3. YMMV.

Building

  1. Install Xcode from Mac App Store
  2. Clone project source from GitHub
  3. Switch to the ios branch
  4. Open .xcodeproj file
  5. Set Product > Destination to point to your device
  6. Run

Optional Changes

These are changes I made that give a better experience on my specific iPad.

Adding chunky screen resolutions

I added chunky “half resolution” screen modes to increase the size of user interface elements so that buttons, menu items and so on are all around the 44pt recommended in the Apple iOS HIG.

For iPad Pro 12.9” these changes were:

[self addVideoMode:CGSizeMake(512, 496) to:videoModes]; // portrait minus keyboard
[self addVideoMode:CGSizeMake(512, 672) to:videoModes]; // portrait "full" screen
[self addVideoMode:CGSizeMake(683, 502) to:videoModes]; // landscape "full" screen

Enter those after line 61 in file B2ScreenView.mm

Disabling graphics smoothing

My personal preference is to disable filtering/smoothing on all graphics scaling, but only because I’ve dialled in resolutions that fit exactly so there will be no scaling happening anyway:

NSString *filter = kCAFilterNearest;
videoLayer.magnificationFilter = filter;
videoLayer.minificationFilter = filter;

Make this change at line 108 in file B2ScreenView.mm

Custom Keyboard Layouts

These are defined in JSON and compiled to a custom format:

Here’s one that I made, based on the British layout, for use with Deneba artWORKS/UltraPaint. To install it you should copy the file artWORKS.nfkeyboardlayout to BasiliskII’s Keyboard Layout folder using the Files app on your iPad.

Enable Split View Support

This can be enabled by changing BasiliskII-Info.plist: UIRequiresFullScreen should be false in BasiliskII-Info.plist but be wary of the following problem:

  • the very top of the screen (where you’d expect the iOS status bar to be, and where part of the System 7 menu bar is) will become unresponsive to touch due to the Slide Over indicator

This would need to be managed/avoided by the screen layout of BasiliskII, but when I attempted this it raised more issues.

However, you can still use Slide Over to position Safari, Files, etc. along the edge of your screen.


Notes

There are additional capabilities that come with the emulator integration. I go further into these, and more besides, in a additional posts listed at the bottom of the page.

Keyboard

  • Swipe up/down with two fingers to show/hide the on-screen keyboard

Settings

  • Spread 4 or 5 fingers to show the BasiliskII Settings pop-up
  • Tap outside of the BasiliskII Settings pop-up to hide it
  • Settings can also be invoked through the app menu, long press the app icon

Custom screen size

  • Pinch with 2 fingers to dynamically resize screen
  • Separate tracking for horizontal and vertical resizing
  • Double-tap for full size screen

File Sharing

A drive appears on the desktop that is mapped to the iOS file sharing folder of the app.

  • You can use Files to transfer files into or out of the emulated machine
  • Share Sheet also works for getting files into the emulated machine
  • You can organise the files into folders using the Files app

Apple Pencil

This is supported the same way as regular touch so it acts as a mouse. Drawing works well and is very responsive, even at lower Hz.

  • Palm rejection is missing
  • Pressure sensitivity is missing
  • Multi touch seems to be missing
--
Originally published: 2021-04-21
--
Enjoyed this blog post? Please buy me a coffee.
--
Comments: @gingerbeardman