stella/src/emucore/MindLink.hxx

96 lines
2.6 KiB
C++
Raw Normal View History

//============================================================================
//
// 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:
/**
Called after *all* digital pins have been written on Port A.
*/
void controlWrite() { nextMindlinkBit(); }
/**
Update the entire digital and analog pin state according to the
events currently set.
*/
void update();
private:
void nextMindlinkBit();
private:
uInt8 myMask1, myMask2, myMask3;
// Internal state of the port pins
uInt8 myIOPort;
// Position value in Mindlink controller
// Gets transferred bitwise (16 bits)
int myMindlinkPos;
// Position for player 1 (0x2800-0x3800)
int myMindlinkPos1;
// Position for player 2 (0x1000-0x2000)
int myMindlinkPos2;
// Which bit to transfer next
int myMindlinkShift;
};
#endif