2008-05-12 22:40:26 +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
|
|
|
|
//
|
2014-01-12 17:23:42 +00:00
|
|
|
// Copyright (c) 1995-2014 by Bradford W. Mott, Stephen Anthony
|
2010-04-10 21:37:23 +00:00
|
|
|
// and the Stella Team
|
2008-05-12 22:40:26 +00:00
|
|
|
//
|
2010-01-10 03:23:32 +00:00
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
2008-05-12 22:40:26 +00:00
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2009-05-13 13:55:40 +00:00
|
|
|
// $Id$
|
2008-05-12 22:40:26 +00:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef TRACKBALL_HXX
|
|
|
|
#define TRACKBALL_HXX
|
|
|
|
|
|
|
|
#include "bspf.hxx"
|
|
|
|
#include "Control.hxx"
|
|
|
|
#include "Event.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
The various trackball-like controllers supported by the Atari 2600.
|
|
|
|
They're all placed in one class, since other than a few minor
|
|
|
|
differences, they work almost exactly the same. This code was
|
|
|
|
heavily borrowed from z26.
|
|
|
|
|
|
|
|
The supported controllers include:
|
|
|
|
TrackBall22: Atari 2600 CX-22 Trakball
|
|
|
|
TrackBall80: Atari ST CX-80 Trakball
|
|
|
|
AmigaMouse: Amiga Mouse
|
|
|
|
|
|
|
|
@author Stephen Anthony & z26 team
|
2009-05-13 13:55:40 +00:00
|
|
|
@version $Id$
|
2008-05-12 22:40:26 +00:00
|
|
|
*/
|
|
|
|
class TrackBall : public Controller
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new TrackBall 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
|
|
|
|
@param type The type of trackball controller
|
|
|
|
*/
|
|
|
|
TrackBall(Jack jack, const Event& event, const System& system, Type type);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor
|
|
|
|
*/
|
|
|
|
virtual ~TrackBall();
|
|
|
|
|
|
|
|
public:
|
2012-10-24 10:10:32 +00:00
|
|
|
using Controller::read;
|
|
|
|
|
2008-05-12 22:40:26 +00:00
|
|
|
/**
|
2012-01-02 16:37:17 +00:00
|
|
|
Read the entire state of all digital pins for this controller.
|
2012-01-28 15:19:41 +00:00
|
|
|
Note that this method must use the lower 4 bits, and zero the upper bits.
|
2012-01-02 16:37:17 +00:00
|
|
|
|
|
|
|
@return The state of all digital pins
|
2008-05-12 22:40:26 +00:00
|
|
|
*/
|
2012-01-02 16:37:17 +00:00
|
|
|
uInt8 read();
|
2008-05-12 22:40:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Update the entire digital and analog pin state according to the
|
|
|
|
events currently set.
|
|
|
|
*/
|
2011-05-24 16:04:48 +00:00
|
|
|
void update();
|
2008-05-12 22:40:26 +00:00
|
|
|
|
2012-04-19 13:00:02 +00:00
|
|
|
/**
|
|
|
|
Determines how this controller will treat values received from the
|
|
|
|
X/Y axis and left/right buttons of the mouse. Since not all controllers
|
|
|
|
use the mouse the same way (or at all), it's up to the specific class to
|
|
|
|
decide how to use this data.
|
|
|
|
|
|
|
|
In the current implementation, the left button is tied to the X axis,
|
|
|
|
and the right one tied to the Y axis.
|
|
|
|
|
|
|
|
@param xtype The controller to use for x-axis data
|
|
|
|
@param xid The controller ID to use for x-axis data (-1 for no id)
|
|
|
|
@param ytype The controller to use for y-axis data
|
|
|
|
@param yid The controller ID to use for y-axis data (-1 for no id)
|
|
|
|
|
|
|
|
@return Whether the controller supports using the mouse
|
|
|
|
*/
|
|
|
|
bool setMouseControl(
|
|
|
|
Controller::Type xtype, int xid, Controller::Type ytype, int yid);
|
|
|
|
|
2008-05-12 22:40:26 +00:00
|
|
|
private:
|
|
|
|
// Counter to iterate through the gray codes
|
|
|
|
int myHCounter, myVCounter;
|
|
|
|
|
|
|
|
// How many new horizontal and vertical values this frame
|
|
|
|
int myTrakBallCountH, myTrakBallCountV;
|
|
|
|
|
|
|
|
// How many lines to wait before sending new horz and vert val
|
|
|
|
int myTrakBallLinesH, myTrakBallLinesV;
|
|
|
|
|
|
|
|
// Was TrakBall moved left or moved right instead
|
|
|
|
int myTrakBallLeft;
|
|
|
|
|
|
|
|
// Was TrakBall moved down or moved up instead
|
|
|
|
int myTrakBallDown;
|
|
|
|
|
|
|
|
int myScanCountH, myScanCountV, myCountH, myCountV;
|
|
|
|
|
2012-04-19 13:00:02 +00:00
|
|
|
// Whether to use the mouse to emulate this controller
|
|
|
|
int myMouseEnabled;
|
|
|
|
|
2008-05-12 22:40:26 +00:00
|
|
|
// CX-22
|
|
|
|
static const uInt32 ourTrakBallTableTB_H[2][2];
|
|
|
|
static const uInt32 ourTrakBallTableTB_V[2][2];
|
|
|
|
|
|
|
|
// ST mouse / CX-80
|
|
|
|
static const uInt32 ourTrakBallTableST_H[4];
|
|
|
|
static const uInt32 ourTrakBallTableST_V[4];
|
|
|
|
|
|
|
|
// Amiga mouse
|
|
|
|
static const uInt32 ourTrakBallTableAM_H[4];
|
|
|
|
static const uInt32 ourTrakBallTableAM_V[4];
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|