Removed obsolete legacy joystick driver.
This commit is contained in:
parent
92141295cd
commit
8719556315
4 changed files with 1 additions and 147 deletions
|
@ -716,7 +716,6 @@
|
||||||
<Compile Include="Input\ConfigurationType.cs" />
|
<Compile Include="Input\ConfigurationType.cs" />
|
||||||
<Compile Include="Input\GamePadConfigurationSource.cs" />
|
<Compile Include="Input\GamePadConfigurationSource.cs" />
|
||||||
<Compile Include="Input\GamePadConfigurationItem.cs" />
|
<Compile Include="Input\GamePadConfigurationItem.cs" />
|
||||||
<Compile Include="Platform\LegacyJoystickDriver.cs" />
|
|
||||||
<Compile Include="Platform\PlatformFactoryBase.cs" />
|
<Compile Include="Platform\PlatformFactoryBase.cs" />
|
||||||
<Compile Include="Input\JoystickHat.cs" />
|
<Compile Include="Input\JoystickHat.cs" />
|
||||||
<Compile Include="Input\HatPosition.cs" />
|
<Compile Include="Input\HatPosition.cs" />
|
||||||
|
|
|
@ -53,9 +53,6 @@ namespace OpenTK.Platform
|
||||||
|
|
||||||
Input.IJoystickDriver2 CreateJoystickDriver();
|
Input.IJoystickDriver2 CreateJoystickDriver();
|
||||||
|
|
||||||
[Obsolete]
|
|
||||||
Input.IJoystickDriver CreateLegacyJoystickDriver();
|
|
||||||
|
|
||||||
void RegisterResource(IDisposable resource);
|
void RegisterResource(IDisposable resource);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,136 +0,0 @@
|
||||||
#region License
|
|
||||||
//
|
|
||||||
// LegacyJoystickDriver.cs
|
|
||||||
//
|
|
||||||
// Author:
|
|
||||||
// Stefanos A. <stapostol@gmail.com>
|
|
||||||
//
|
|
||||||
// Copyright (c) 2006-2014 Stefanos Apostolopoulos
|
|
||||||
//
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
// of this software and associated documentation files (the "Software"), to deal
|
|
||||||
// in the Software without restriction, including without limitation the rights
|
|
||||||
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
// copies of the Software, and to permit persons to whom the Software is
|
|
||||||
// furnished to do so, subject to the following conditions:
|
|
||||||
//
|
|
||||||
// The above copyright notice and this permission notice shall be included in
|
|
||||||
// all copies or substantial portions of the Software.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
// THE SOFTWARE.
|
|
||||||
//
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using OpenTK.Input;
|
|
||||||
|
|
||||||
namespace OpenTK.Platform
|
|
||||||
{
|
|
||||||
[Obsolete]
|
|
||||||
internal class LegacyJoystickDriver : IJoystickDriver
|
|
||||||
{
|
|
||||||
static readonly string ConnectedName = "Connected Joystick";
|
|
||||||
static readonly string DisconnectedName = "Disconnected Joystick";
|
|
||||||
readonly List<JoystickDevice> joysticks = new List<JoystickDevice>();
|
|
||||||
readonly IList<JoystickDevice> joysticks_readonly;
|
|
||||||
|
|
||||||
class LegacyJoystickDevice : JoystickDevice
|
|
||||||
{
|
|
||||||
public LegacyJoystickDevice(int id, int axes, int buttons)
|
|
||||||
: base(id, axes, buttons)
|
|
||||||
{ }
|
|
||||||
}
|
|
||||||
|
|
||||||
internal LegacyJoystickDriver()
|
|
||||||
{
|
|
||||||
joysticks_readonly = joysticks.AsReadOnly();
|
|
||||||
for (int i = 0; i < 4; i++)
|
|
||||||
{
|
|
||||||
joysticks.Add(new LegacyJoystickDevice(i, 0, 0));
|
|
||||||
joysticks[i].Description = DisconnectedName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Poll()
|
|
||||||
{
|
|
||||||
for (int i = 0; i < 4; i++)
|
|
||||||
{
|
|
||||||
JoystickCapabilities caps = Joystick.GetCapabilities(i);
|
|
||||||
if (caps.IsConnected && joysticks[i].Description == DisconnectedName)
|
|
||||||
{
|
|
||||||
// New joystick connected
|
|
||||||
joysticks[i] = new LegacyJoystickDevice(
|
|
||||||
i,
|
|
||||||
caps.AxisCount + 2 * caps.HatCount,
|
|
||||||
caps.ButtonCount);
|
|
||||||
//device.Description = Joystick.GetName(i);
|
|
||||||
joysticks[i].Description = ConnectedName;
|
|
||||||
|
|
||||||
}
|
|
||||||
else if (!caps.IsConnected && joysticks[i].Description != DisconnectedName)
|
|
||||||
{
|
|
||||||
// Joystick disconnected
|
|
||||||
joysticks[i] = new LegacyJoystickDevice(i, 0, 0);
|
|
||||||
joysticks[i].Description = DisconnectedName;
|
|
||||||
}
|
|
||||||
|
|
||||||
JoystickState state = Joystick.GetState(i);
|
|
||||||
for (int axis_index = 0; axis_index < caps.AxisCount; axis_index++)
|
|
||||||
{
|
|
||||||
JoystickAxis axis = JoystickAxis.Axis0 + axis_index;
|
|
||||||
joysticks[i].SetAxis(axis, state.GetAxis(axis));
|
|
||||||
}
|
|
||||||
for (int button_index = 0; button_index < caps.ButtonCount; button_index++)
|
|
||||||
{
|
|
||||||
joysticks[i].SetButton(button_index, state.GetButton(button_index) == ButtonState.Pressed);
|
|
||||||
}
|
|
||||||
for (int hat_index = 0; hat_index < caps.HatCount; hat_index++)
|
|
||||||
{
|
|
||||||
// LegacyJoystickDriver report hats as pairs of axes
|
|
||||||
// Make sure we have enough axes left for this mapping
|
|
||||||
int axis_index = caps.AxisCount + 2 * hat_index;
|
|
||||||
if (axis_index < JoystickState.MaxAxes)
|
|
||||||
{
|
|
||||||
JoystickHat hat = JoystickHat.Hat0 + hat_index;
|
|
||||||
JoystickHatState hat_state = state.GetHat(hat);
|
|
||||||
JoystickAxis axis = JoystickAxis.Axis0 + axis_index;
|
|
||||||
float x = 0;
|
|
||||||
float y = 0;
|
|
||||||
if (hat_state.IsDown)
|
|
||||||
y--;
|
|
||||||
if (hat_state.IsUp)
|
|
||||||
y++;
|
|
||||||
if (hat_state.IsLeft)
|
|
||||||
x--;
|
|
||||||
if (hat_state.IsRight)
|
|
||||||
x++;
|
|
||||||
|
|
||||||
joysticks[i].SetAxis(axis, x);
|
|
||||||
joysticks[i].SetAxis(axis + 1, y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#region IJoystickDriver Members
|
|
||||||
|
|
||||||
public IList<JoystickDevice> Joysticks
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
Poll();
|
|
||||||
return joysticks_readonly;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -78,12 +78,6 @@ namespace OpenTK.Platform
|
||||||
|
|
||||||
public abstract IJoystickDriver2 CreateJoystickDriver();
|
public abstract IJoystickDriver2 CreateJoystickDriver();
|
||||||
|
|
||||||
[Obsolete]
|
|
||||||
public virtual IJoystickDriver CreateLegacyJoystickDriver()
|
|
||||||
{
|
|
||||||
return new LegacyJoystickDriver();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void RegisterResource(IDisposable resource)
|
public void RegisterResource(IDisposable resource)
|
||||||
{
|
{
|
||||||
lock (sync)
|
lock (sync)
|
||||||
|
|
Loading…
Reference in a new issue