multiple fixes to wxJoystick under Unix and new index-based API for accessing joystick buttons and axes (patch 1678497)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@44843 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2007-03-16 00:51:43 +00:00
parent 0fa5ce0c76
commit e6733873f5
11 changed files with 138 additions and 29 deletions

View File

@ -39,6 +39,7 @@ All:
- Fixed crashes in helpview when opening a file. - Fixed crashes in helpview when opening a file.
- Added wxMutex::LockTimeout() (Aleksandr Napylov) - Added wxMutex::LockTimeout() (Aleksandr Napylov)
- Set locale to the default in all ports, not just wxGTK - Set locale to the default in all ports, not just wxGTK
- Added wxJoystick::GetButtonState/Position() (Frank C Szczerba)
- Added wxGridUpdateLocker helper class (Evgeniy Tarassov) - Added wxGridUpdateLocker helper class (Evgeniy Tarassov)
- Support wxGRID_AUTOSIZE in wxGrid::SetRow/ColLabelSize() (Evgeniy Tarassov) - Support wxGRID_AUTOSIZE in wxGrid::SetRow/ColLabelSize() (Evgeniy Tarassov)

View File

@ -39,6 +39,14 @@ significant bit, and so on.
A bitlist of wxJOY\_BUTTONn identifiers, where n is 1, 2, 3 or 4 A bitlist of wxJOY\_BUTTONn identifiers, where n is 1, 2, 3 or 4
is available for historical reasons. is available for historical reasons.
\constfunc{bool}{GetButtonState}{\param{unsigned}{ id}}
Returns the state of the specified joystick button.
\wxheading{Parameters}
\docparam{id}{The button id to report, from 0 to \helpref{GetNumberButtons()}{wxjoystickgetnumberbuttons} - 1}
\membersection{wxJoystick::GetManufacturerId}\label{wxjoystickgetmanufacturerid} \membersection{wxJoystick::GetManufacturerId}\label{wxjoystickgetmanufacturerid}
\constfunc{int}{GetManufacturerId}{\void} \constfunc{int}{GetManufacturerId}{\void}
@ -100,6 +108,14 @@ Returns the product name for the joystick.
Returns the x, y position of the joystick. Returns the x, y position of the joystick.
\constfunc{int}{GetPosition}{\param{unsigned}{ axis}}
Returns the position of the specified joystick axis.
\wxheading{Parameters}
\docparam{axis}{The joystick axis to report, from 0 to \helpref{GetNumberAxes()}{wxjoystickgetnumberaxes} - 1.}
\membersection{wxJoystick::GetPOVPosition}\label{wxjoystickgetpovposition} \membersection{wxJoystick::GetPOVPosition}\label{wxjoystickgetpovposition}
\constfunc{int}{GetPOVPosition}{\void} \constfunc{int}{GetPOVPosition}{\void}

View File

@ -28,6 +28,8 @@ class WXDLLEXPORT wxJoystick: public wxObject
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
wxPoint GetPosition() const; wxPoint GetPosition() const;
int GetPosition(unsigned axis) const;
bool GetButtonState(unsigned button) const;
int GetZPosition() const; int GetZPosition() const;
int GetButtonState() const; int GetButtonState() const;
int GetPOVPosition() const; int GetPOVPosition() const;

View File

@ -28,6 +28,8 @@ class WXDLLEXPORT wxJoystick: public wxObject
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
wxPoint GetPosition() const; wxPoint GetPosition() const;
int GetPosition(unsigned axis) const;
bool GetButtonState(unsigned button) const;
int GetZPosition() const; int GetZPosition() const;
int GetButtonState() const; int GetButtonState() const;
int GetPOVPosition() const; int GetPOVPosition() const;

View File

@ -28,6 +28,8 @@ class WXDLLIMPEXP_ADV wxJoystick: public wxObject
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
wxPoint GetPosition(void) const; wxPoint GetPosition(void) const;
int GetPosition(unsigned axis) const;
bool GetButtonState(unsigned button) const;
int GetZPosition(void) const; int GetZPosition(void) const;
int GetButtonState(void) const; int GetButtonState(void) const;
int GetPOVPosition(void) const; int GetPOVPosition(void) const;

View File

@ -28,6 +28,8 @@ class WXDLLIMPEXP_ADV wxJoystick: public wxObject
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
wxPoint GetPosition(void) const; wxPoint GetPosition(void) const;
int GetPosition(unsigned axis) const;
bool GetButtonState(unsigned button) const;
int GetZPosition(void) const; int GetZPosition(void) const;
int GetButtonState(void) const; int GetButtonState(void) const;
int GetPOVPosition(void) const; int GetPOVPosition(void) const;

View File

@ -32,6 +32,8 @@ class WXDLLEXPORT wxJoystick: public wxObject
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
wxPoint GetPosition() const; wxPoint GetPosition() const;
int GetPosition(unsigned axis) const;
bool GetButtonState(unsigned button) const;
int GetZPosition() const; int GetZPosition() const;
int GetButtonState() const; int GetButtonState() const;
int GetPOVPosition() const; int GetPOVPosition() const;

View File

@ -28,6 +28,18 @@ wxPoint wxJoystick::GetPosition() const
return wxPoint(0, 0); return wxPoint(0, 0);
} }
int wxJoystick::GetPosition(unsigned axis) const
{
// TODO
return 0;
}
bool wxJoystick::GetButtonState(unsigned id) const
{
// TODO
return false;
}
int wxJoystick::GetZPosition() const int wxJoystick::GetZPosition() const
{ {
// TODO // TODO

View File

@ -86,6 +86,26 @@ wxPoint wxJoystick::GetPosition() const
return wxPoint(0,0); return wxPoint(0,0);
} }
int wxJoystick::GetPosition(unsigned axis) const
{
switch (axis) {
case 0:
return GetPosition().x;
case 1:
return GetPosition().y;
case 2:
return GetZPosition();
case 3:
return GetRudderPosition();
case 4:
return GetUPosition();
case 5:
return GetVPosition();
default:
return 0;
}
}
int wxJoystick::GetZPosition() const int wxJoystick::GetZPosition() const
{ {
JOYINFO joyInfo; JOYINFO joyInfo;
@ -127,6 +147,14 @@ int wxJoystick::GetButtonState() const
return 0; return 0;
} }
bool wxJoystick::GetButtonState(unsigned id) const
{
if (id > sizeof(int) * 8)
return false;
return (GetButtonState() & (1 << id)) != 0;
}
/** /**
JLI 2002-08-20: JLI 2002-08-20:
Returns -1 to signify error. Returns -1 to signify error.

View File

@ -35,6 +35,18 @@ wxPoint wxJoystick::GetPosition() const
return wxPoint(0, 0); return wxPoint(0, 0);
} }
int wxJoystick::GetPosition(unsigned axis) const
{
// TODO
return 0;
}
bool wxJoystick::GetButtonState(unsigned id) const
{
// TODO
return false;
}
int wxJoystick::GetZPosition() const int wxJoystick::GetZPosition() const
{ {
return 0; return 0;

View File

@ -44,7 +44,9 @@ enum {
wxJS_AXIS_V, wxJS_AXIS_V,
wxJS_AXIS_MAX = 32767, wxJS_AXIS_MAX = 32767,
wxJS_AXIS_MIN = -32767 wxJS_AXIS_MIN = -32767,
wxJS_MAX_AXES = 15,
wxJS_MAX_BUTTONS = sizeof(int) * 8
}; };
@ -62,13 +64,15 @@ public:
void* Entry(); void* Entry();
private: private:
void SendEvent(wxEventType type, long ts, int change = 0);
int m_device; int m_device;
int m_joystick; int m_joystick;
wxPoint m_lastposition; wxPoint m_lastposition;
int m_axe[15]; int m_axe[wxJS_MAX_AXES];
int m_buttons; int m_buttons;
wxWindow* m_catchwin; wxWindow* m_catchwin;
int m_polling; int m_polling;
int m_threshold;
friend class wxJoystick; friend class wxJoystick;
}; };
@ -80,12 +84,24 @@ wxJoystickThread::wxJoystickThread(int device, int joystick)
m_lastposition(wxDefaultPosition), m_lastposition(wxDefaultPosition),
m_buttons(0), m_buttons(0),
m_catchwin(NULL), m_catchwin(NULL),
m_polling(0) m_polling(0),
m_threshold(0)
{ {
for (int i=0; i<15; i++) memset(m_axe, 0, sizeof(m_axe));
m_axe[i] = 0;
} }
void wxJoystickThread::SendEvent(wxEventType type, long ts, int change)
{
wxJoystickEvent jwx_event(type, m_buttons, m_joystick, change);
jwx_event.SetTimestamp(ts);
jwx_event.SetPosition(m_lastposition);
jwx_event.SetZPosition(m_axe[wxJS_AXIS_Z]);
jwx_event.SetEventObject(m_catchwin);
if (m_catchwin)
m_catchwin->AddPendingEvent(jwx_event);
}
void* wxJoystickThread::Entry() void* wxJoystickThread::Entry()
{ {
@ -116,9 +132,10 @@ void* wxJoystickThread::Entry()
//printf("time: %d\t value: %d\t type: %d\t number: %d\n", //printf("time: %d\t value: %d\t type: %d\t number: %d\n",
// j_evt.time, j_evt.value, j_evt.type, j_evt.number); // j_evt.time, j_evt.value, j_evt.type, j_evt.number);
wxJoystickEvent jwx_event; if ((j_evt.type & JS_EVENT_AXIS) && (j_evt.number < wxJS_MAX_AXES))
{
if (j_evt.type & JS_EVENT_AXIS) if ( (m_axe[j_evt.number] + m_threshold < j_evt.value)
|| (m_axe[j_evt.number] - m_threshold > j_evt.value) )
{ {
m_axe[j_evt.number] = j_evt.value; m_axe[j_evt.number] = j_evt.value;
@ -126,47 +143,36 @@ void* wxJoystickThread::Entry()
{ {
case wxJS_AXIS_X: case wxJS_AXIS_X:
m_lastposition.x = j_evt.value; m_lastposition.x = j_evt.value;
jwx_event.SetEventType(wxEVT_JOY_MOVE); SendEvent(wxEVT_JOY_MOVE, j_evt.time);
break; break;
case wxJS_AXIS_Y: case wxJS_AXIS_Y:
m_lastposition.y = j_evt.value; m_lastposition.y = j_evt.value;
jwx_event.SetEventType(wxEVT_JOY_MOVE); SendEvent(wxEVT_JOY_MOVE, j_evt.time);
break; break;
case wxJS_AXIS_Z: case wxJS_AXIS_Z:
jwx_event.SetEventType(wxEVT_JOY_ZMOVE); SendEvent(wxEVT_JOY_ZMOVE, j_evt.time);
break; break;
default: default:
jwx_event.SetEventType(wxEVT_JOY_MOVE); SendEvent(wxEVT_JOY_MOVE, j_evt.time);
// TODO: There should be a way to indicate that the event // TODO: There should be a way to indicate that the event
// is for some other axes. // is for some other axes.
break; break;
} }
} }
}
if (j_evt.type & JS_EVENT_BUTTON) if ( (j_evt.type & JS_EVENT_BUTTON) && (j_evt.number < wxJS_MAX_BUTTONS) )
{ {
if (j_evt.value) if (j_evt.value)
{ {
m_buttons |= (1 << j_evt.number); m_buttons |= (1 << j_evt.number);
jwx_event.SetEventType(wxEVT_JOY_BUTTON_DOWN); SendEvent(wxEVT_JOY_BUTTON_DOWN, j_evt.time, j_evt.number);
} }
else else
{ {
m_buttons &= ~(1 << j_evt.number); m_buttons &= ~(1 << j_evt.number);
jwx_event.SetEventType(wxEVT_JOY_BUTTON_UP); SendEvent(wxEVT_JOY_BUTTON_UP, j_evt.time, j_evt.number);
} }
jwx_event.SetButtonChange(j_evt.number);
jwx_event.SetTimestamp(j_evt.time);
jwx_event.SetJoystick(m_joystick);
jwx_event.SetButtonState(m_buttons);
jwx_event.SetPosition(m_lastposition);
jwx_event.SetZPosition(m_axe[3]);
jwx_event.SetEventObject(m_catchwin);
if (m_catchwin)
m_catchwin->AddPendingEvent(jwx_event);
} }
} }
} }
@ -225,6 +231,13 @@ wxPoint wxJoystick::GetPosition() const
return pos; return pos;
} }
int wxJoystick::GetPosition(unsigned axis) const
{
if (m_thread && (axis < wxJS_MAX_AXES))
return m_thread->m_axe[axis];
return 0;
}
int wxJoystick::GetZPosition() const int wxJoystick::GetZPosition() const
{ {
if (m_thread) if (m_thread)
@ -239,6 +252,13 @@ int wxJoystick::GetButtonState() const
return 0; return 0;
} }
bool wxJoystick::GetButtonState(unsigned id) const
{
if (m_thread && (id < wxJS_MAX_BUTTONS))
return (m_thread->m_buttons & (1 << id)) != 0;
return false;
}
int wxJoystick::GetPOVPosition() const int wxJoystick::GetPOVPosition() const
{ {
return -1; return -1;
@ -272,11 +292,15 @@ int wxJoystick::GetVPosition() const
int wxJoystick::GetMovementThreshold() const int wxJoystick::GetMovementThreshold() const
{ {
if (m_thread)
return m_thread->m_threshold;
return 0; return 0;
} }
void wxJoystick::SetMovementThreshold(int threshold) void wxJoystick::SetMovementThreshold(int threshold)
{ {
if (m_thread)
m_thread->m_threshold = threshold;
} }
//////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
@ -370,6 +394,9 @@ int wxJoystick::GetNumberButtons() const
if (m_device != -1) if (m_device != -1)
ioctl(m_device, JSIOCGBUTTONS, &nb); ioctl(m_device, JSIOCGBUTTONS, &nb);
if (nb > wxJS_MAX_BUTTONS)
nb = wxJS_MAX_BUTTONS;
return nb; return nb;
} }
@ -380,17 +407,20 @@ int wxJoystick::GetNumberAxes() const
if (m_device != -1) if (m_device != -1)
ioctl(m_device, JSIOCGAXES, &nb); ioctl(m_device, JSIOCGAXES, &nb);
if (nb > wxJS_MAX_AXES)
nb = wxJS_MAX_AXES;
return nb; return nb;
} }
int wxJoystick::GetMaxButtons() const int wxJoystick::GetMaxButtons() const
{ {
return 15; // internal return wxJS_MAX_BUTTONS; // internal
} }
int wxJoystick::GetMaxAxes() const int wxJoystick::GetMaxAxes() const
{ {
return 15; // internal return wxJS_MAX_AXES; // internal
} }
int wxJoystick::GetPollingMin() const int wxJoystick::GetPollingMin() const