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:
parent
0fa5ce0c76
commit
e6733873f5
@ -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)
|
||||||
|
|
||||||
|
@ -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}
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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.
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user