/APC

Arduino Pinball Controller

Primary LanguageC++GNU General Public License v3.0GPL-3.0

The Arduino Pinball Controller

Before I explain what the APC is, let's first clarify what it is not.

The APC is no commercial drop-in replacement board. It is intended for people with some basic knowledge of programming and electronics who want to expand the possibilities of their pinball machine.

As this is a private project with no commercial interest, you may use the APC at your own risk and I'm not liable for any damage that might occur to your machine while using it.
Some special machines might even not work with the APC or require additional HW. Please check the Known issues section for details.

Overview

The APC is a freely programmable controller for Williams pinball machines. It uses an Arduino Due and contains all the circuitry required to run a Williams pinball machine from System 3 to System 11c (and the compatible Data East machines):

  • Display interface for all corresponding display types
  • 24 Solenoid drivers
  • Lamp matrix drivers for 64 lamps
  • Switch matrix drivers for 64 switches + 8 non matrix switches
  • SD card interface (to store audio files, highscores and settings)
  • Audio amplifier with two channels (to play music and sound effects simultaneously / can be changed to single channel stereo)

To summarize the above it can be said that the APC does replace all CPU, power driver and sound related boards at a price of well below 100€ per board.

APC 2.0

The picture shows an APC 3.1 board with the new on-board SD-Card slot below the Arduino.
See my APC 3 video to get an impression what this board can do.

There's a table of contents of the available documentation at the end of this page.

Special features

  • Hardware extensions interface. The pinout is compatible to the Sound Overlay Solenoid Board used in games like Whirlwind, but it is upgraded a bit to support all kind of self made hardware
  • A socket for a Raspberry Pi which can be used to run PinMame on the APC board. With this you can run the original ROM code on your APC.
  • PinMameExceptions are game specific code blocks that act like a man-in-the-middle between the game HW and PinMame. That means even if your game is running in PinMame you can still introduce some changes. Take a look at my Jungle Lord video or my Comet ball saver to see how a few lines of code can change a game dramatically.

Typical examples for the use of PinMameExceptions are:

  • Pre System11 games usually use just one audio channel, so you could add a background music track. Wouldn't it be great if your Disco Fever would play old Disco music in the BG?
  • Add HW toys like a shaker motor or flashers and the necessary rules to drive them. If your game has no free solenoid drivers left, then just add the Solenoid expansion board to get 8 more. You can also use the LED expansion board to control RGB-LED stripes or just connect your own individual HW.
  • Add a ball saver. Ball savers are quite easy to realize. All you have to do is not to tell PinMame that the ball has reached the outhole, but to kick it into the plunger lane instead. Watch my Comet video to see how it can be done with just a few lines of code.

The picture below shows an APC prototype in my Pinbot.

Pic Pinbot

To see the APC in an early stage you might want take a look at my Black Knight game video

Game Software

PinMame

You can use Lisy to run PinMame on an APC board. This spares you the effort to do any game Software as you can run the old ROM code. For System 3 - 7 machines the APC can be used with the old original soundboards. That means in this case it's a plug & play solution. You might want the APC to generate the audio anyway, either because you don't have an audio board, you want to do your own sounds or you have a System 9 or 11 game. In this case it's going to require some work to set up your game with PinMame. Take a look at the PinMame Sound page to see what I mean.

With PinMame running for your game you can use the PinMameExceptions functionality of the APC to change the rules of your game even though it's running under PinMame control.
Watch my Jungle Lord video so see an example. The corresponding code can be found in PinMameExceptions.ino in the AmokPrivate branch on Github.
Another example is the ball saver I added to my Comet.

MPF

For those who want to do their own game rules without having to use C, the APC does support the Mission Pinball Framework. It can run on a PC which then controls the APC via USB.

I did a short video with some basic MPF setup to test that everything is working:

MPF runs APC

C code

If you're familiar with C you can also program the APC directly. This SW would then run on the Arduino itself with no need for an additional PC or Raspberry Pi.
For this the APC software offers an API providing the necessary commands to control a pinball machine. It's still a lot of effort to program a game completely from scratch, but you could even run your game in PinMame and only use the API to do changes or extensions to the original rules.

You don't necessarily have to do the code from scratch. There is a Base Code which covers the basics of a pinball machine and can be used as a starting point.
Furthermore there're the above mentioned PinMameExceptions which can change a game dramatically with just a few lines of code.

Hardware

The APC hardware status is mature. I have version 2.0 in use since January 2018 without anything to complain about. Since then the HW has basically stayed the same, just some features have been added and the board has been prepared for automatic assembly. You can find the schematics, BOM and layout data in the hardware section. There have been some minor HW updates which are explained in the Changelog.

The APC features an HW extensions interface which is an 8 bit bus with several enable signals. At the moment there're two extension board available, but you could use it for all kinds of additional hardware.

The first board is an LED expansion board to control WS2812 based LED-Strips with the APC. For more information about this board please refer to the APC LED expansion board section.

The following picture shows the APC in a Comet with the LED Expansion board connected to the hardware extensions interface.

APC Comet LED

A short video with this setup can be found here :

GI LEDs

The second board is a driver for 8 additional solenoids. The current version is mainly suited for use with an own power supply (e.g. for 24V shaker motors).

I use special alphanumerical displays in my Black Knight which can also be found in the HW section as well as an LED replacement for the original System7 numerical displays.

Current Status (June 2024)

The following table gives an overview about the various system generations the APC can be used with and if at least one machine of each generation has been confirmed to work with it. Additionally you can see whether PinMame or MPF have been tested with at least one machine of this generation and whether some special preparation like additional cables are required. Details about these cables can be found here

The PinMame support is still under development and even if a generation is basically supported you still need the audio files for your particular game. A list of available audio files and a description how to extract your own files can be found on the PinMame page.

Williams System Tested PinMame support MPF support Comment
3 Yes Yes Yes When PinMame is used, some solenoid activation times need to be increase by a PinMameException
4 Yes Yes Yes When PinMame is used, some solenoid activation times need to be increase by a PinMameException
6 Yes Yes Yes When PinMame is used, some solenoid activation times need to be increase by a PinMameException
7 Yes Yes Yes Needs two additional wires
9 Yes Yes Yes
11 Yes Yes Yes
11a Yes Yes Yes Some cable ties have to be cut and the wiring harness opened a bit
11b Yes Yes Yes Some cable ties have to be cut and the wiring harness opened a bit
11c Yes Yes Yes The wires of three connectors must be extended

The following Data East MPUs are almost identical to their counterparts from Williams but DE used 2.1 audio boards. Check the known issues for details

Data East Version Tested PinMame support MPF support Comment
1 Not yet Yes Yes audio needs a cable adapter and is only mono
2 Not yet Yes Yes audio needs a cable adapter and is only mono
3 Yes Yes Yes Only non DMD machines / audio needs a cable adapter and is only mono / probably some cable extensions are needed

Changes / What's new?

A history of the recent changes can be found in the Changelog

Known issues

Stereo audio

Some games like Jokerz! or Data East games starting from MPU version 1 have stereo or even 2.1 audio boards. These are currently not supported by the APC SW.
From the HW point of view, the APC is capable of generating two independent sound channels which could also be used for stereo. But up to now they're used to generate separate channels for sounds and music which are combined in the output amplifier.
In order to use these machines with the APC you'd have to build a cable adapter and the audio would only be mono.

Stepper motors

Games like Jokerz! or Riverboat Gambler use stepper motors to drive a wheel in the backbox and the amount of steps being generated determine where the wheel stops.
Alas, there's a problem with Lisy/PinMame not sending all steps to the APC. This means it is not possible for the APC to determine at which position the wheel is supposed to stop.
Note that this is not a problem of the APC itself, but occurs only when Lisy/PinMame is used. If you program your game code in C there won't be any problems.

Rollergames music problems

The Rollergames implementation in PinMame has a bug in the music control. For some reason a new music track is started every few seconds. Most of the time it's the same track that's already running. I have therefore implemented a workaround in the PinMameExceptions of the Rollergames which prevents that the running music track can be restarted. This improves the situation somehow, but more sophisticated PinMameExceptions are needed to really fix this.
Up to now only Rollergames seems to be affected, other machines using the same audio boards are working fine.

Feedback

Feedback is very important for me, because if there is none I must assume that nobody is interested in this project and that I can stop to bother with additional documentation. And albeit I have tried my best to help you to become familiar with this project, there will be questions and I am willing to do some support. Like I said, it's a hobby so don't expect 24/7 availability, but I'll do my best to help.

So if you're interested please leave some feedback in the Flippertreff forum (german) or in the - Pinside Form (english).

How to get startet?

I'm sorry, but I'm not going to sell any boards. Check whether anyone in the above mentioned forums has a spare board for sale. If this fails you can still order populated boards from China.
If you're interested in using an APC, then be sure to follow the instructions given in the first part of the documentation listet below. They will guide you through the process of getting and setting up an APC board.

Documentation contents

  1. Building and setting up an APC
    1.1. The APC board - How to get one and how to set it up
    1.2. Upload the SW - How to program the Arduino DUE
    1.3. Basic Preparation - Required cables and stuff
    1.4. Do the tests - Test your board
    1.5. Run a game - All the ways to get a game running

  2. References
    2.1. Setting up the BaseCode - Do the BaseCode setup to get a very simple game
    2.2. Useful software tools - Simple tools for audio data conversion and so on
    2.3. APC settings - a table of the settings and how to use them
    2.4. APC schematics - just in case you want to know what you're about to build
    2.5. If things don't work - If you have a problem, check here first

  3. Writing my own game code - You want to program your own game in C? Then read this.
    3.1. Game code tutorial - A step by step introduction to writing your own game code
    3.2. APC software reference - All commands of the API in a nutshell

  4. Running PinMame
    4.1. Lisy Homepage - Location of the Lisy SW download and more
    4.2. PinMame Sound - shows whether your game is supported and what to do if not
    4.3. PinMame System 3 - 7 Sound howto - How to enable the sound of System 3 - 7 games
    4.4. PinMame System 9 Sound howto - How to enable the sound of System 9 games
    4.5. PinMame System 11 Sound howto - How to enable the sound of System 11 games
    4.6. PinMameExceptions - change your game, but let PinMame do the main work
    4.7. PinMame game numbers - list of the PinMame game numbers
    4.8. Controlling Lisy - updating Lisy and using the debug mode
    4.9. Instructions for extracting sound files - automatic extraction of sound files and the use of Audacity in more detail (by Mokopin)

  5. Using MPF
    5.1. MPF runs APC - see my first humble MPF steps in this video
    5.2. MPF setup - my MPF test config files

  6. Additional APC hardware - boards and other stuff that might come in handy with the APC
    6.1. APC LED expansion board - a board to control WS2812 based LED strips with the APC
    6.2. APC solenoid expansion board - to control additional features
    6.3. System 7 alphanumeric display - to have alphanumerical displays in a pre System 11 machine
    6.4. Installation frames - to mount the APC in your backbox

  7. Additional non APC hardware - just some stuff I designed over the years. Can also be used without the APC
    7.1. System 7 LED display - an LED replacement display for System 7, purely numerical
    7.2. System 11a LED display - an LED replacement display for System 11a

  8. APC games - Complete games running natively on the APC or games that run in PinMame but have been changed
    8.1. Black Knight - Complete game code with some additional features
    8.2. Pinbot - Complete game code with some additional features
    8.3. Comet - Some extensions to the original game code running in PinMame

  9. Videos - For the generation Youtube
    9.1. What's new in APC3 - Gives an overview about what the APC is and what version 3 can do
    9.2. Lisy, APC and PinMame - Shows the use of PinMame in an early stage
    9.3. PinMameExceptions - What is a PinMameException and how does it work?
    9.4. Adding a ball saver with PinMameExceptions - Another example of how to use PinMameExceptions
    9.5. APC MPF - A simple demonstration of the APC being controlled by MPF
    9.6. GI LEDs - Shows the LED_exp board in action
    9.7. Arduino Pinball Controller hardware extensions interface - Also shows the use of the LED_exp board, but in an early SW stage
    9.8. APC Black Knight demo - My first APC video. Not really up to date any more, but it shows the basics
    9.9. How to use numerical displays - How to navigate the menus when you can't read any text
    9.10. How to adjust the display setting to a 2x16 alphanumerical display - How to find the right setting to make these displays work