2017-07-30 13:18:13 +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
|
|
|
|
//
|
2019-12-31 17:18:56 +00:00
|
|
|
// Copyright (c) 1995-2020 by Bradford W. Mott, Stephen Anthony
|
2017-07-30 13:18:13 +00:00
|
|
|
// 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.
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef POINTING_DEVICE_HXX
|
|
|
|
#define POINTING_DEVICE_HXX
|
|
|
|
|
2017-08-02 18:37:02 +00:00
|
|
|
class Event;
|
|
|
|
|
2017-10-01 07:52:39 +00:00
|
|
|
#include "Control.hxx"
|
2017-07-30 13:18:13 +00:00
|
|
|
#include "bspf.hxx"
|
|
|
|
|
|
|
|
/**
|
2017-08-01 13:45:41 +00:00
|
|
|
Common controller class for pointing devices (Atari Mouse, Amiga Mouse, Trak-Ball)
|
2017-07-30 13:18:13 +00:00
|
|
|
This code was heavily borrowed from z26.
|
|
|
|
|
2017-08-01 13:45:41 +00:00
|
|
|
@author Stephen Anthony, Thomas Jentzsch & z26 team
|
2017-07-30 13:18:13 +00:00
|
|
|
*/
|
2017-07-30 14:18:52 +00:00
|
|
|
class PointingDevice : public Controller
|
2017-07-30 13:18:13 +00:00
|
|
|
{
|
2017-10-01 11:06:34 +00:00
|
|
|
friend class PointingDeviceWidget;
|
2017-10-01 07:52:39 +00:00
|
|
|
|
2017-07-30 13:18:13 +00:00
|
|
|
public:
|
2017-08-02 18:37:02 +00:00
|
|
|
PointingDevice(Jack jack, const Event& event,
|
|
|
|
const System& system, Controller::Type type,
|
|
|
|
float sensitivity);
|
2017-07-30 13:18:13 +00:00
|
|
|
virtual ~PointingDevice() = default;
|
|
|
|
|
|
|
|
public:
|
|
|
|
using Controller::read;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Read the entire state of all digital pins for this controller.
|
|
|
|
Note that this method must use the lower 4 bits, and zero the upper bits.
|
|
|
|
|
|
|
|
@return The state of all digital pins
|
|
|
|
*/
|
|
|
|
uInt8 read() override;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Update the entire digital and analog pin state according to the
|
|
|
|
events currently set.
|
|
|
|
*/
|
|
|
|
void update() override;
|
|
|
|
|
2018-03-17 22:33:05 +00:00
|
|
|
/**
|
|
|
|
Answers whether the controller is intrinsically an analog controller.
|
|
|
|
*/
|
|
|
|
bool isAnalog() const override { return true; }
|
|
|
|
|
2017-07-30 13:18:13 +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) override;
|
|
|
|
|
2017-08-02 18:37:02 +00:00
|
|
|
/**
|
|
|
|
Sets the sensitivity for analog emulation of trackball movement
|
|
|
|
using a mouse.
|
|
|
|
|
|
|
|
@param sensitivity Value from 1 to 20, with larger values causing
|
|
|
|
more movement (10 represents the baseline)
|
|
|
|
*/
|
|
|
|
static void setSensitivity(int sensitivity);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Each derived class must implement this, to determine how its
|
|
|
|
// IOPortA values are calculated
|
|
|
|
virtual uInt8 ioPortA(uInt8 countH, uInt8 countV, uInt8 left, uInt8 down) = 0;
|
|
|
|
|
2017-07-30 13:18:13 +00:00
|
|
|
private:
|
2017-08-02 20:23:07 +00:00
|
|
|
void updateDirection(int counter, float& counterRemainder,
|
2017-08-01 13:45:41 +00:00
|
|
|
bool& trackBallDir, int& trackBallLines,
|
|
|
|
int& scanCount, int& firstScanOffset);
|
|
|
|
|
|
|
|
private:
|
2017-08-02 18:37:02 +00:00
|
|
|
// Mouse input to sensitivity emulation
|
2019-12-29 22:06:56 +00:00
|
|
|
float mySensitivity{0.F}, myHCounterRemainder{0.F}, myVCounterRemainder{0.F};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-07-30 22:49:00 +00:00
|
|
|
// How many lines to wait between sending new horz and vert values
|
2019-12-29 22:06:56 +00:00
|
|
|
int myTrackBallLinesH{1}, myTrackBallLinesV{1};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-08-01 13:45:41 +00:00
|
|
|
// Was TrackBall moved left or moved right instead
|
2019-12-29 22:06:56 +00:00
|
|
|
bool myTrackBallLeft{false};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-08-01 13:45:41 +00:00
|
|
|
// Was TrackBall moved down or moved up instead
|
2019-12-29 22:06:56 +00:00
|
|
|
bool myTrackBallDown{false};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-07-30 22:49:00 +00:00
|
|
|
// Counter to iterate through the gray codes
|
2019-12-29 22:06:56 +00:00
|
|
|
uInt8 myCountH{0}, myCountV{0};
|
2017-08-01 13:45:41 +00:00
|
|
|
|
|
|
|
// Next scanline for change
|
2019-12-29 22:06:56 +00:00
|
|
|
int myScanCountH{0}, myScanCountV{0};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-08-01 13:45:41 +00:00
|
|
|
// Offset factor for first scanline, 0..(1 << 12 - 1)
|
2019-12-29 22:06:56 +00:00
|
|
|
int myFirstScanOffsetH{0}, myFirstScanOffsetV{0};
|
2017-08-01 13:45:41 +00:00
|
|
|
|
2017-07-30 13:18:13 +00:00
|
|
|
// Whether to use the mouse to emulate this controller
|
2019-12-29 22:06:56 +00:00
|
|
|
bool myMouseEnabled{false};
|
2017-07-30 13:18:13 +00:00
|
|
|
|
2017-08-02 18:37:02 +00:00
|
|
|
// User-defined sensitivity; adjustable since end-users may have different
|
|
|
|
// mouse speeds
|
|
|
|
static float TB_SENSITIVITY;
|
|
|
|
|
|
|
|
private:
|
2017-07-30 13:18:13 +00:00
|
|
|
// Following constructors and assignment operators not supported
|
|
|
|
PointingDevice() = delete;
|
2017-08-02 18:37:02 +00:00
|
|
|
PointingDevice(const PointingDevice&) = delete;
|
|
|
|
PointingDevice(PointingDevice&&) = delete;
|
|
|
|
PointingDevice& operator=(const PointingDevice&) = delete;
|
|
|
|
PointingDevice& operator=(PointingDevice&&) = delete;
|
2017-07-30 13:18:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // POINTING_DEVICE_HXX
|