2012-01-02 16:37:17 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
|
|
|
// Copyright (c) 1995-2012 by Bradford W. Mott, Stephen Anthony
|
|
|
|
// and the Stella Team
|
|
|
|
//
|
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
|
|
|
// $Id$
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef MINDLINK_HXX
|
|
|
|
#define MINDLINK_HXX
|
|
|
|
|
|
|
|
#include "bspf.hxx"
|
|
|
|
#include "Control.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
The Atari Mindlink was an unreleased video game controller intended for
|
|
|
|
release in 1984. The Mindlink was unique in that one had to move the
|
|
|
|
muscles in one's head to control the game. These movements would be read by
|
|
|
|
infrared sensors and transferred as movement in the game. For more
|
|
|
|
information, see the following link:
|
|
|
|
|
|
|
|
http://www.atarimuseum.com/videogames/consoles/2600/mindlink.html
|
|
|
|
|
|
|
|
This code was heavily borrowed from z26, and uses conventions defined
|
|
|
|
there. Specifically, IOPortA is treated as a complete uInt8, whereas
|
|
|
|
the Stella core actually stores this information in boolean arrays
|
|
|
|
addressable by DigitalPin number.
|
|
|
|
|
|
|
|
@author Stephen Anthony & z26 team
|
|
|
|
@version $Id$
|
|
|
|
*/
|
|
|
|
class MindLink : public Controller
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new MindLink controller plugged into the specified jack
|
|
|
|
|
|
|
|
@param jack The jack the controller is plugged into
|
|
|
|
@param event The event object to use for events
|
|
|
|
@param system The system using this controller
|
|
|
|
*/
|
|
|
|
MindLink(Jack jack, const Event& event, const System& system);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor
|
|
|
|
*/
|
|
|
|
virtual ~MindLink();
|
|
|
|
|
|
|
|
public:
|
2012-03-25 14:42:09 +00:00
|
|
|
/**
|
|
|
|
Write the given value to the specified digital pin for this
|
|
|
|
controller. Writing is only allowed to the pins associated
|
|
|
|
with the PIA. Therefore you cannot write to pin six.
|
|
|
|
|
|
|
|
@param pin The pin of the controller jack to write to
|
|
|
|
@param value The value to write to the pin
|
|
|
|
*/
|
|
|
|
void write(DigitalPin pin, bool value) { myDigitalPinState[pin] = value; }
|
|
|
|
|
2012-01-02 16:37:17 +00:00
|
|
|
/**
|
|
|
|
Called after *all* digital pins have been written on Port A.
|
2012-03-25 14:42:09 +00:00
|
|
|
|
|
|
|
@param value The entire contents of the SWCHA register
|
2012-01-02 16:37:17 +00:00
|
|
|
*/
|
2012-03-25 14:42:09 +00:00
|
|
|
void controlWrite(uInt8) { nextMindlinkBit(); }
|
2012-01-02 16:37:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Update the entire digital and analog pin state according to the
|
|
|
|
events currently set.
|
|
|
|
*/
|
|
|
|
void update();
|
|
|
|
|
|
|
|
private:
|
|
|
|
void nextMindlinkBit();
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Position value in Mindlink controller
|
|
|
|
// Gets transferred bitwise (16 bits)
|
|
|
|
int myMindlinkPos;
|
|
|
|
|
|
|
|
// Which bit to transfer next
|
|
|
|
int myMindlinkShift;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|