mirror of
https://github.com/cemu-project/DS4Windows.git
synced 2025-01-12 16:29:05 +01:00
Minor optimizations
This commit is contained in:
parent
b3bd007219
commit
1e2c57a08a
@ -1047,11 +1047,11 @@ namespace DS4Windows
|
|||||||
public bool[] flushHIDQueue = { false, false, false, false, false };
|
public bool[] flushHIDQueue = { false, false, false, false, false };
|
||||||
public bool[] enableTouchToggle = { true, true, true, true, true };
|
public bool[] enableTouchToggle = { true, true, true, true, true };
|
||||||
public int[] idleDisconnectTimeout = { 0, 0, 0, 0, 0 };
|
public int[] idleDisconnectTimeout = { 0, 0, 0, 0, 0 };
|
||||||
public Boolean[] touchpadJitterCompensation = { true, true, true, true, true };
|
public bool[] touchpadJitterCompensation = { true, true, true, true, true };
|
||||||
public Boolean[] lowerRCOn = { false, false, false, false, false };
|
public bool[] lowerRCOn = { false, false, false, false, false };
|
||||||
public Boolean[] ledAsBattery = { false, false, false, false, false };
|
public bool[] ledAsBattery = { false, false, false, false, false };
|
||||||
public Byte[] flashType = { 0, 0, 0, 0, 0 };
|
public byte[] flashType = { 0, 0, 0, 0, 0 };
|
||||||
public String[] profilePath = { String.Empty, String.Empty, String.Empty, String.Empty, String.Empty };
|
public string[] profilePath = { string.Empty, string.Empty, string.Empty, string.Empty, string.Empty };
|
||||||
// Cache properties instead of performing a string comparison every frame
|
// Cache properties instead of performing a string comparison every frame
|
||||||
public bool[] distanceProfiles = { false, false, false, false, false };
|
public bool[] distanceProfiles = { false, false, false, false, false };
|
||||||
public Byte[] rumble = { 100, 100, 100, 100, 100 };
|
public Byte[] rumble = { 100, 100, 100, 100, 100 };
|
||||||
@ -1368,16 +1368,21 @@ namespace DS4Windows
|
|||||||
string keyType = string.Empty;
|
string keyType = string.Empty;
|
||||||
|
|
||||||
if (dcs.action is string)
|
if (dcs.action is string)
|
||||||
|
{
|
||||||
if (dcs.action.ToString() == "Unbound")
|
if (dcs.action.ToString() == "Unbound")
|
||||||
keyType += DS4KeyType.Unbound;
|
keyType += DS4KeyType.Unbound;
|
||||||
|
}
|
||||||
|
|
||||||
if (dcs.keyType.HasFlag(DS4KeyType.HoldMacro))
|
if (dcs.keyType.HasFlag(DS4KeyType.HoldMacro))
|
||||||
keyType += DS4KeyType.HoldMacro;
|
keyType += DS4KeyType.HoldMacro;
|
||||||
else if (dcs.keyType.HasFlag(DS4KeyType.Macro))
|
else if (dcs.keyType.HasFlag(DS4KeyType.Macro))
|
||||||
keyType += DS4KeyType.Macro;
|
keyType += DS4KeyType.Macro;
|
||||||
|
|
||||||
if (dcs.keyType.HasFlag(DS4KeyType.Toggle))
|
if (dcs.keyType.HasFlag(DS4KeyType.Toggle))
|
||||||
keyType += DS4KeyType.Toggle;
|
keyType += DS4KeyType.Toggle;
|
||||||
if (dcs.keyType.HasFlag(DS4KeyType.ScanCode))
|
if (dcs.keyType.HasFlag(DS4KeyType.ScanCode))
|
||||||
keyType += DS4KeyType.ScanCode;
|
keyType += DS4KeyType.ScanCode;
|
||||||
|
|
||||||
if (keyType != string.Empty)
|
if (keyType != string.Empty)
|
||||||
{
|
{
|
||||||
buttonNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
buttonNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
||||||
@ -1411,12 +1416,17 @@ namespace DS4Windows
|
|||||||
|
|
||||||
bool hasvalue = false;
|
bool hasvalue = false;
|
||||||
if (!string.IsNullOrEmpty(dcs.extras))
|
if (!string.IsNullOrEmpty(dcs.extras))
|
||||||
|
{
|
||||||
foreach (string s in dcs.extras.Split(','))
|
foreach (string s in dcs.extras.Split(','))
|
||||||
|
{
|
||||||
if (s != "0")
|
if (s != "0")
|
||||||
{
|
{
|
||||||
hasvalue = true;
|
hasvalue = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (hasvalue)
|
if (hasvalue)
|
||||||
{
|
{
|
||||||
XmlNode extraNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
XmlNode extraNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
||||||
@ -1430,8 +1440,11 @@ namespace DS4Windows
|
|||||||
string keyType = string.Empty;
|
string keyType = string.Empty;
|
||||||
|
|
||||||
if (dcs.shiftAction is string)
|
if (dcs.shiftAction is string)
|
||||||
|
{
|
||||||
if (dcs.shiftAction.ToString() == "Unbound")
|
if (dcs.shiftAction.ToString() == "Unbound")
|
||||||
keyType += DS4KeyType.Unbound;
|
keyType += DS4KeyType.Unbound;
|
||||||
|
}
|
||||||
|
|
||||||
if (dcs.shiftKeyType.HasFlag(DS4KeyType.HoldMacro))
|
if (dcs.shiftKeyType.HasFlag(DS4KeyType.HoldMacro))
|
||||||
keyType += DS4KeyType.HoldMacro;
|
keyType += DS4KeyType.HoldMacro;
|
||||||
if (dcs.shiftKeyType.HasFlag(DS4KeyType.Macro))
|
if (dcs.shiftKeyType.HasFlag(DS4KeyType.Macro))
|
||||||
@ -1440,6 +1453,7 @@ namespace DS4Windows
|
|||||||
keyType += DS4KeyType.Toggle;
|
keyType += DS4KeyType.Toggle;
|
||||||
if (dcs.shiftKeyType.HasFlag(DS4KeyType.ScanCode))
|
if (dcs.shiftKeyType.HasFlag(DS4KeyType.ScanCode))
|
||||||
keyType += DS4KeyType.ScanCode;
|
keyType += DS4KeyType.ScanCode;
|
||||||
|
|
||||||
if (keyType != string.Empty)
|
if (keyType != string.Empty)
|
||||||
{
|
{
|
||||||
buttonNode = m_Xdoc.CreateElement(dcs.control.ToString());
|
buttonNode = m_Xdoc.CreateElement(dcs.control.ToString());
|
||||||
@ -1466,14 +1480,20 @@ namespace DS4Windows
|
|||||||
ShiftButton.AppendChild(buttonNode);
|
ShiftButton.AppendChild(buttonNode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
hasvalue = false;
|
hasvalue = false;
|
||||||
if (!string.IsNullOrEmpty(dcs.shiftExtras))
|
if (!string.IsNullOrEmpty(dcs.shiftExtras))
|
||||||
|
{
|
||||||
foreach (string s in dcs.shiftExtras.Split(','))
|
foreach (string s in dcs.shiftExtras.Split(','))
|
||||||
|
{
|
||||||
if (s != "0")
|
if (s != "0")
|
||||||
{
|
{
|
||||||
hasvalue = true;
|
hasvalue = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (hasvalue)
|
if (hasvalue)
|
||||||
{
|
{
|
||||||
XmlNode extraNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
XmlNode extraNode = m_Xdoc.CreateNode(XmlNodeType.Element, dcs.control.ToString(), null);
|
||||||
@ -1481,6 +1501,7 @@ namespace DS4Windows
|
|||||||
ShiftExtras.AppendChild(extraNode);
|
ShiftExtras.AppendChild(extraNode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Node.AppendChild(NodeControl);
|
Node.AppendChild(NodeControl);
|
||||||
if (Button.HasChildNodes)
|
if (Button.HasChildNodes)
|
||||||
NodeControl.AppendChild(Button);
|
NodeControl.AppendChild(Button);
|
||||||
@ -1616,6 +1637,7 @@ namespace DS4Windows
|
|||||||
|
|
||||||
if (!key.StartsWith("bn"))
|
if (!key.StartsWith("bn"))
|
||||||
return (DS4Controls)Enum.Parse(typeof(DS4Controls), key, true);
|
return (DS4Controls)Enum.Parse(typeof(DS4Controls), key, true);
|
||||||
|
|
||||||
switch (key)
|
switch (key)
|
||||||
{
|
{
|
||||||
case "bnShare": return DS4Controls.Share;
|
case "bnShare": return DS4Controls.Share;
|
||||||
@ -1744,6 +1766,7 @@ namespace DS4Windows
|
|||||||
case "bnShiftSwipeLeft": return DS4Controls.SwipeLeft;
|
case "bnShiftSwipeLeft": return DS4Controls.SwipeLeft;
|
||||||
case "bnShiftSwipeRight": return DS4Controls.SwipeRight;
|
case "bnShiftSwipeRight": return DS4Controls.SwipeRight;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1752,6 +1775,7 @@ namespace DS4Windows
|
|||||||
X360Controls x3c;
|
X360Controls x3c;
|
||||||
if (Enum.TryParse(key, true, out x3c))
|
if (Enum.TryParse(key, true, out x3c))
|
||||||
return x3c;
|
return x3c;
|
||||||
|
|
||||||
switch (key)
|
switch (key)
|
||||||
{
|
{
|
||||||
case "Back": return X360Controls.Back;
|
case "Back": return X360Controls.Back;
|
||||||
@ -1795,8 +1819,8 @@ namespace DS4Windows
|
|||||||
case "Mouse Left": return X360Controls.MouseLeft;
|
case "Mouse Left": return X360Controls.MouseLeft;
|
||||||
case "Mouse Right": return X360Controls.MouseRight;
|
case "Mouse Right": return X360Controls.MouseRight;
|
||||||
case "Unbound": return X360Controls.Unbound;
|
case "Unbound": return X360Controls.Unbound;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return X360Controls.Unbound;
|
return X360Controls.Unbound;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1909,11 +1933,13 @@ namespace DS4Windows
|
|||||||
colors = Item.InnerText.Split(',');
|
colors = Item.InnerText.Split(',');
|
||||||
else
|
else
|
||||||
colors = new string[0];
|
colors = new string[0];
|
||||||
|
|
||||||
m_Leds[device].red = byte.Parse(colors[0]);
|
m_Leds[device].red = byte.Parse(colors[0]);
|
||||||
m_Leds[device].green = byte.Parse(colors[1]);
|
m_Leds[device].green = byte.Parse(colors[1]);
|
||||||
m_Leds[device].blue = byte.Parse(colors[2]);
|
m_Leds[device].blue = byte.Parse(colors[2]);
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
if (m_Xdoc.SelectSingleNode("/" + rootname + "/Color") == null)
|
if (m_Xdoc.SelectSingleNode("/" + rootname + "/Color") == null)
|
||||||
{
|
{
|
||||||
//Old method of color saving
|
//Old method of color saving
|
||||||
@ -1925,6 +1951,7 @@ namespace DS4Windows
|
|||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Blue"); Byte.TryParse(Item.InnerText, out m_Leds[device].blue); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Blue"); Byte.TryParse(Item.InnerText, out m_Leds[device].blue); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
}
|
}
|
||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RumbleBoost"); Byte.TryParse(Item.InnerText, out rumble[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RumbleBoost"); Byte.TryParse(Item.InnerText, out rumble[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
@ -1939,6 +1966,7 @@ namespace DS4Windows
|
|||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/touchSensitivity"); Byte.TryParse(Item.InnerText, out touchSensitivity[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/touchSensitivity"); Byte.TryParse(Item.InnerText, out touchSensitivity[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
//New method for saving color
|
//New method for saving color
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -1954,6 +1982,7 @@ namespace DS4Windows
|
|||||||
m_LowLeds[device].blue = byte.Parse(colors[2]);
|
m_LowLeds[device].blue = byte.Parse(colors[2]);
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
if (m_Xdoc.SelectSingleNode("/" + rootname + "/LowColor") == null)
|
if (m_Xdoc.SelectSingleNode("/" + rootname + "/LowColor") == null)
|
||||||
{
|
{
|
||||||
//Old method of color saving
|
//Old method of color saving
|
||||||
@ -1964,6 +1993,7 @@ namespace DS4Windows
|
|||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/LowBlue"); byte.TryParse(Item.InnerText, out m_LowLeds[device].blue); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/LowBlue"); byte.TryParse(Item.InnerText, out m_LowLeds[device].blue); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
}
|
}
|
||||||
|
|
||||||
//New method for saving color
|
//New method for saving color
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -1979,6 +2009,7 @@ namespace DS4Windows
|
|||||||
m_ChargingLeds[device].blue = byte.Parse(colors[2]);
|
m_ChargingLeds[device].blue = byte.Parse(colors[2]);
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
if (m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingColor") == null)
|
if (m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingColor") == null)
|
||||||
{
|
{
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingRed"); Byte.TryParse(Item.InnerText, out m_ChargingLeds[device].red); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingRed"); Byte.TryParse(Item.InnerText, out m_ChargingLeds[device].red); }
|
||||||
@ -1988,6 +2019,7 @@ namespace DS4Windows
|
|||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingBlue"); Byte.TryParse(Item.InnerText, out m_ChargingLeds[device].blue); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingBlue"); Byte.TryParse(Item.InnerText, out m_ChargingLeds[device].blue); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/FlashColor");
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/FlashColor");
|
||||||
@ -2001,6 +2033,7 @@ namespace DS4Windows
|
|||||||
m_FlashLeds[device].blue = byte.Parse(colors[2]);
|
m_FlashLeds[device].blue = byte.Parse(colors[2]);
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/touchpadJitterCompensation"); bool.TryParse(Item.InnerText, out touchpadJitterCompensation[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/touchpadJitterCompensation"); bool.TryParse(Item.InnerText, out touchpadJitterCompensation[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/lowerRCOn"); bool.TryParse(Item.InnerText, out lowerRCOn[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/lowerRCOn"); bool.TryParse(Item.InnerText, out lowerRCOn[device]); }
|
||||||
@ -2019,18 +2052,21 @@ namespace DS4Windows
|
|||||||
catch { l2AntiDeadzone[device] = 0; missingSetting = true; }
|
catch { l2AntiDeadzone[device] = 0; missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/R2AntiDeadZone"); int.TryParse(Item.InnerText, out r2AntiDeadzone[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/R2AntiDeadZone"); int.TryParse(Item.InnerText, out r2AntiDeadzone[device]); }
|
||||||
catch { r2AntiDeadzone[device] = 0; missingSetting = true; }
|
catch { r2AntiDeadzone[device] = 0; missingSetting = true; }
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/L2MaxZone"); int temp = 100;
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/L2MaxZone"); int temp = 100;
|
||||||
int.TryParse(Item.InnerText, out temp);
|
int.TryParse(Item.InnerText, out temp);
|
||||||
l2Maxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
l2Maxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
||||||
}
|
}
|
||||||
catch { l2Maxzone[device] = 100; missingSetting = true; }
|
catch { l2Maxzone[device] = 100; missingSetting = true; }
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/R2MaxZone"); int temp = 100;
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/R2MaxZone"); int temp = 100;
|
||||||
int.TryParse(Item.InnerText, out temp);
|
int.TryParse(Item.InnerText, out temp);
|
||||||
r2Maxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
r2Maxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
||||||
}
|
}
|
||||||
catch { r2Maxzone[device] = 100; missingSetting = true; }
|
catch { r2Maxzone[device] = 100; missingSetting = true; }
|
||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ButtonMouseSensitivity"); int.TryParse(Item.InnerText, out buttonMouseSensitivity[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ButtonMouseSensitivity"); int.TryParse(Item.InnerText, out buttonMouseSensitivity[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Rainbow"); double.TryParse(Item.InnerText, out rainbow[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Rainbow"); double.TryParse(Item.InnerText, out rainbow[device]); }
|
||||||
@ -2043,22 +2079,26 @@ namespace DS4Windows
|
|||||||
catch { LSAntiDeadzone[device] = 0; missingSetting = true; }
|
catch { LSAntiDeadzone[device] = 0; missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSAntiDeadZone"); int.TryParse(Item.InnerText, out RSAntiDeadzone[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSAntiDeadZone"); int.TryParse(Item.InnerText, out RSAntiDeadzone[device]); }
|
||||||
catch { RSAntiDeadzone[device] = 0; missingSetting = true; }
|
catch { RSAntiDeadzone[device] = 0; missingSetting = true; }
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/LSMaxZone"); int temp = 100;
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/LSMaxZone"); int temp = 100;
|
||||||
int.TryParse(Item.InnerText, out temp);
|
int.TryParse(Item.InnerText, out temp);
|
||||||
LSMaxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
LSMaxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
||||||
}
|
}
|
||||||
catch { LSMaxzone[device] = 100; missingSetting = true; }
|
catch { LSMaxzone[device] = 100; missingSetting = true; }
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSMaxZone"); int temp = 100;
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSMaxZone"); int temp = 100;
|
||||||
int.TryParse(Item.InnerText, out temp);
|
int.TryParse(Item.InnerText, out temp);
|
||||||
RSMaxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
RSMaxzone[device] = Math.Min(Math.Max(temp, 0), 100);
|
||||||
}
|
}
|
||||||
catch { RSMaxzone[device] = 100; missingSetting = true; }
|
catch { RSMaxzone[device] = 100; missingSetting = true; }
|
||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/SXDeadZone"); double.TryParse(Item.InnerText, out SXDeadzone[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/SXDeadZone"); double.TryParse(Item.InnerText, out SXDeadzone[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/SZDeadZone"); double.TryParse(Item.InnerText, out SZDeadzone[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/SZDeadZone"); double.TryParse(Item.InnerText, out SZDeadzone[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Sensitivity");
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/Sensitivity");
|
||||||
@ -2079,6 +2119,7 @@ namespace DS4Windows
|
|||||||
SZSens[device] = 1;
|
SZSens[device] = 1;
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingType"); int.TryParse(Item.InnerText, out chargingType[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/ChargingType"); int.TryParse(Item.InnerText, out chargingType[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/MouseAcceleration"); bool.TryParse(Item.InnerText, out mouseAccel[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/MouseAcceleration"); bool.TryParse(Item.InnerText, out mouseAccel[device]); }
|
||||||
@ -2193,6 +2234,7 @@ namespace DS4Windows
|
|||||||
if (startTouchpadOff[device] == true) control.StartTPOff(device);
|
if (startTouchpadOff[device] == true) control.StartTPOff(device);
|
||||||
}
|
}
|
||||||
catch { startTouchpadOff[device] = false; missingSetting = true; }
|
catch { startTouchpadOff[device] = false; missingSetting = true; }
|
||||||
|
|
||||||
try
|
try
|
||||||
{ Item = m_Xdoc.SelectSingleNode("/" + rootname + "/UseTPforControls"); Boolean.TryParse(Item.InnerText, out useTPforControls[device]); }
|
{ Item = m_Xdoc.SelectSingleNode("/" + rootname + "/UseTPforControls"); Boolean.TryParse(Item.InnerText, out useTPforControls[device]); }
|
||||||
catch { useTPforControls[device] = false; missingSetting = true; }
|
catch { useTPforControls[device] = false; missingSetting = true; }
|
||||||
@ -2212,6 +2254,7 @@ namespace DS4Windows
|
|||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSCurve"); int.TryParse(Item.InnerText, out rsCurve[device]); }
|
try { Item = m_Xdoc.SelectSingleNode("/" + rootname + "/RSCurve"); int.TryParse(Item.InnerText, out rsCurve[device]); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/BTPollRate");
|
Item = m_Xdoc.SelectSingleNode("/" + rootname + "/BTPollRate");
|
||||||
int temp = 0;
|
int temp = 0;
|
||||||
@ -2560,10 +2603,11 @@ namespace DS4Windows
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool Load()
|
public bool Load()
|
||||||
{
|
{
|
||||||
Boolean Loaded = true;
|
bool Loaded = true;
|
||||||
Boolean missingSetting = false;
|
bool missingSetting = false;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -2588,7 +2632,7 @@ namespace DS4Windows
|
|||||||
distanceProfiles[0] = true;
|
distanceProfiles[0] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { profilePath[0] = string.Empty; distanceProfiles[0] = false; missingSetting = true; }
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/Profile/Controller2"); profilePath[1] = Item.InnerText;
|
Item = m_Xdoc.SelectSingleNode("/Profile/Controller2"); profilePath[1] = Item.InnerText;
|
||||||
if (profilePath[1].ToLower().Contains("distance"))
|
if (profilePath[1].ToLower().Contains("distance"))
|
||||||
@ -2596,7 +2640,7 @@ namespace DS4Windows
|
|||||||
distanceProfiles[1] = true;
|
distanceProfiles[1] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { profilePath[1] = string.Empty; distanceProfiles[1] = false; missingSetting = true; }
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/Profile/Controller3"); profilePath[2] = Item.InnerText;
|
Item = m_Xdoc.SelectSingleNode("/Profile/Controller3"); profilePath[2] = Item.InnerText;
|
||||||
if (profilePath[2].ToLower().Contains("distance"))
|
if (profilePath[2].ToLower().Contains("distance"))
|
||||||
@ -2604,7 +2648,7 @@ namespace DS4Windows
|
|||||||
distanceProfiles[2] = true;
|
distanceProfiles[2] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { profilePath[2] = string.Empty; distanceProfiles[2] = false; missingSetting = true; }
|
||||||
try {
|
try {
|
||||||
Item = m_Xdoc.SelectSingleNode("/Profile/Controller4"); profilePath[3] = Item.InnerText;
|
Item = m_Xdoc.SelectSingleNode("/Profile/Controller4"); profilePath[3] = Item.InnerText;
|
||||||
if (profilePath[3].ToLower().Contains("distance"))
|
if (profilePath[3].ToLower().Contains("distance"))
|
||||||
@ -2612,7 +2656,7 @@ namespace DS4Windows
|
|||||||
distanceProfiles[3] = true;
|
distanceProfiles[3] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch { missingSetting = true; }
|
catch { profilePath[3] = string.Empty; distanceProfiles[3] = false; missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/Profile/LastChecked"); DateTime.TryParse(Item.InnerText, out lastChecked); }
|
try { Item = m_Xdoc.SelectSingleNode("/Profile/LastChecked"); DateTime.TryParse(Item.InnerText, out lastChecked); }
|
||||||
catch { missingSetting = true; }
|
catch { missingSetting = true; }
|
||||||
try { Item = m_Xdoc.SelectSingleNode("/Profile/CheckWhen"); Int32.TryParse(Item.InnerText, out CheckWhen); }
|
try { Item = m_Xdoc.SelectSingleNode("/Profile/CheckWhen"); Int32.TryParse(Item.InnerText, out CheckWhen); }
|
||||||
@ -2658,13 +2702,16 @@ namespace DS4Windows
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
|
|
||||||
if (missingSetting)
|
if (missingSetting)
|
||||||
Save();
|
Save();
|
||||||
|
|
||||||
return Loaded;
|
return Loaded;
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool Save()
|
public bool Save()
|
||||||
{
|
{
|
||||||
Boolean Saved = true;
|
bool Saved = true;
|
||||||
|
|
||||||
XmlNode Node;
|
XmlNode Node;
|
||||||
|
|
||||||
@ -2802,12 +2849,14 @@ namespace DS4Windows
|
|||||||
el.AppendChild(m_Xdoc.CreateElement("Details")).InnerText = details;
|
el.AppendChild(m_Xdoc.CreateElement("Details")).InnerText = details;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (edit)
|
if (edit)
|
||||||
{
|
{
|
||||||
XmlNode oldxmlprocess = m_Xdoc.SelectSingleNode("/Actions/Action[@Name=\"" + name + "\"]");
|
XmlNode oldxmlprocess = m_Xdoc.SelectSingleNode("/Actions/Action[@Name=\"" + name + "\"]");
|
||||||
Node.ReplaceChild(el, oldxmlprocess);
|
Node.ReplaceChild(el, oldxmlprocess);
|
||||||
}
|
}
|
||||||
else { Node.AppendChild(el); }
|
else { Node.AppendChild(el); }
|
||||||
|
|
||||||
m_Xdoc.AppendChild(Node);
|
m_Xdoc.AppendChild(Node);
|
||||||
try { m_Xdoc.Save(m_Actions); }
|
try { m_Xdoc.Save(m_Actions); }
|
||||||
catch { saved = false; }
|
catch { saved = false; }
|
||||||
@ -2822,6 +2871,7 @@ namespace DS4Windows
|
|||||||
XmlNode Item = m_Xdoc.SelectSingleNode("/Actions/Action[@Name=\"" + name + "\"]");
|
XmlNode Item = m_Xdoc.SelectSingleNode("/Actions/Action[@Name=\"" + name + "\"]");
|
||||||
if (Item != null)
|
if (Item != null)
|
||||||
Node.RemoveChild(Item);
|
Node.RemoveChild(Item);
|
||||||
|
|
||||||
m_Xdoc.AppendChild(Node);
|
m_Xdoc.AppendChild(Node);
|
||||||
m_Xdoc.Save(m_Actions);
|
m_Xdoc.Save(m_Actions);
|
||||||
LoadActions();
|
LoadActions();
|
||||||
@ -2835,6 +2885,7 @@ namespace DS4Windows
|
|||||||
SaveAction("Disconnect Controller", "PS/Options", 5, "0", false);
|
SaveAction("Disconnect Controller", "PS/Options", 5, "0", false);
|
||||||
saved = false;
|
saved = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
actions.Clear();
|
actions.Clear();
|
||||||
@ -3419,6 +3470,7 @@ namespace DS4Windows
|
|||||||
case "Tilt Left": return DS4Controls.GyroXPos;
|
case "Tilt Left": return DS4Controls.GyroXPos;
|
||||||
case "Tilt Right": return DS4Controls.GyroXNeg;
|
case "Tilt Right": return DS4Controls.GyroXNeg;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -132,7 +132,7 @@ namespace DS4Windows
|
|||||||
private byte[] accel = new byte[6];
|
private byte[] accel = new byte[6];
|
||||||
private byte[] gyro = new byte[6];
|
private byte[] gyro = new byte[6];
|
||||||
private byte[] inputReport;
|
private byte[] inputReport;
|
||||||
private byte[] inputReport2;
|
//private byte[] inputReport2;
|
||||||
private byte[] btInputReport = null;
|
private byte[] btInputReport = null;
|
||||||
private byte[] outputReportBuffer, outputReport;
|
private byte[] outputReportBuffer, outputReport;
|
||||||
private readonly DS4Touchpad touchpad = null;
|
private readonly DS4Touchpad touchpad = null;
|
||||||
@ -391,7 +391,7 @@ namespace DS4Windows
|
|||||||
if (conType == ConnectionType.USB || conType == ConnectionType.SONYWA)
|
if (conType == ConnectionType.USB || conType == ConnectionType.SONYWA)
|
||||||
{
|
{
|
||||||
inputReport = new byte[64];
|
inputReport = new byte[64];
|
||||||
inputReport2 = new byte[64];
|
//inputReport2 = new byte[64];
|
||||||
outputReport = new byte[hDevice.Capabilities.OutputReportByteLength];
|
outputReport = new byte[hDevice.Capabilities.OutputReportByteLength];
|
||||||
outputReportBuffer = new byte[hDevice.Capabilities.OutputReportByteLength];
|
outputReportBuffer = new byte[hDevice.Capabilities.OutputReportByteLength];
|
||||||
if (conType == ConnectionType.USB)
|
if (conType == ConnectionType.USB)
|
||||||
@ -534,7 +534,7 @@ namespace DS4Windows
|
|||||||
if (lastError != thisError)
|
if (lastError != thisError)
|
||||||
{
|
{
|
||||||
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> encountered write failure: " + thisError);
|
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> encountered write failure: " + thisError);
|
||||||
Log.LogToGui(Mac.ToString() + " encountered write failure: " + thisError, true);
|
//Log.LogToGui(Mac.ToString() + " encountered write failure: " + thisError, true);
|
||||||
lastError = thisError;
|
lastError = thisError;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -579,23 +579,29 @@ namespace DS4Windows
|
|||||||
{
|
{
|
||||||
firstActive = DateTime.UtcNow;
|
firstActive = DateTime.UtcNow;
|
||||||
NativeMethods.HidD_SetNumInputBuffers(hDevice.safeReadHandle.DangerousGetHandle(), 2);
|
NativeMethods.HidD_SetNumInputBuffers(hDevice.safeReadHandle.DangerousGetHandle(), 2);
|
||||||
List<long> Latency = new List<long>(101); // Set capacity at max + 1 to avoid any list resizing
|
List<long> latencyList = new List<long>(51); // Set capacity at max + 1 to avoid any list resizing
|
||||||
|
int tempLatencyCount = 0;
|
||||||
long oldtime = 0;
|
long oldtime = 0;
|
||||||
Stopwatch sw = new Stopwatch();
|
Stopwatch sw = new Stopwatch();
|
||||||
sw.Start();
|
sw.Start();
|
||||||
|
|
||||||
while (!exitInputThread)
|
while (!exitInputThread)
|
||||||
{
|
{
|
||||||
oldCharging = charging;
|
oldCharging = charging;
|
||||||
string currerror = string.Empty;
|
string currerror = string.Empty;
|
||||||
long curtime = sw.ElapsedMilliseconds;
|
long curtime = sw.ElapsedMilliseconds;
|
||||||
this.lastTimeElapsed = curtime - oldtime;
|
this.lastTimeElapsed = curtime - oldtime;
|
||||||
Latency.Add(this.lastTimeElapsed);
|
latencyList.Add(this.lastTimeElapsed);
|
||||||
|
tempLatencyCount++;
|
||||||
oldtime = curtime;
|
oldtime = curtime;
|
||||||
|
|
||||||
if (Latency.Count > 100)
|
if (tempLatencyCount > 50)
|
||||||
Latency.RemoveAt(0);
|
{
|
||||||
|
latencyList.RemoveAt(0);
|
||||||
|
tempLatencyCount--;
|
||||||
|
}
|
||||||
|
|
||||||
this.Latency = Latency.Average();
|
Latency = latencyList.Average();
|
||||||
|
|
||||||
if (conType == ConnectionType.BT)
|
if (conType == ConnectionType.BT)
|
||||||
{
|
{
|
||||||
@ -617,7 +623,7 @@ namespace DS4Windows
|
|||||||
{
|
{
|
||||||
int winError = Marshal.GetLastWin32Error();
|
int winError = Marshal.GetLastWin32Error();
|
||||||
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> disconnect due to read failure: " + winError);
|
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> disconnect due to read failure: " + winError);
|
||||||
Log.LogToGui(Mac.ToString() + " disconnected due to read failure: " + winError, true);
|
//Log.LogToGui(Mac.ToString() + " disconnected due to read failure: " + winError, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
sendOutputReport(true); // Kick Windows into noticing the disconnection.
|
sendOutputReport(true); // Kick Windows into noticing the disconnection.
|
||||||
@ -648,7 +654,7 @@ namespace DS4Windows
|
|||||||
{
|
{
|
||||||
int winError = Marshal.GetLastWin32Error();
|
int winError = Marshal.GetLastWin32Error();
|
||||||
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> disconnect due to read failure: " + winError);
|
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> disconnect due to read failure: " + winError);
|
||||||
Log.LogToGui(Mac.ToString() + " disconnected due to read failure: " + winError, true);
|
//Log.LogToGui(Mac.ToString() + " disconnected due to read failure: " + winError, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
StopOutputUpdate();
|
StopOutputUpdate();
|
||||||
@ -672,7 +678,7 @@ namespace DS4Windows
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
DateTime utcNow = System.DateTime.UtcNow; // timestamp with UTC in case system time zone changes
|
DateTime utcNow = DateTime.UtcNow; // timestamp with UTC in case system time zone changes
|
||||||
resetHapticState();
|
resetHapticState();
|
||||||
cState.ReportTimeStamp = utcNow;
|
cState.ReportTimeStamp = utcNow;
|
||||||
cState.LX = inputReport[1];
|
cState.LX = inputReport[1];
|
||||||
@ -825,11 +831,10 @@ namespace DS4Windows
|
|||||||
}
|
}
|
||||||
sendOutputReport(syncWriteReport);
|
sendOutputReport(syncWriteReport);
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(error))
|
|
||||||
error = string.Empty;
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(currerror))
|
if (!string.IsNullOrEmpty(currerror))
|
||||||
error = currerror;
|
error = currerror;
|
||||||
|
else if (!string.IsNullOrEmpty(error))
|
||||||
|
error = string.Empty;
|
||||||
|
|
||||||
cState.CopyTo(pState);
|
cState.CopyTo(pState);
|
||||||
|
|
||||||
@ -863,27 +868,27 @@ namespace DS4Windows
|
|||||||
outputReportBuffer[0] = 0x11;
|
outputReportBuffer[0] = 0x11;
|
||||||
//outputReportBuffer[1] = 0x80;
|
//outputReportBuffer[1] = 0x80;
|
||||||
//outputReportBuffer[1] = 0x84;
|
//outputReportBuffer[1] = 0x84;
|
||||||
outputReportBuffer[1] = (byte)(0x80 | btPollRate);
|
outputReportBuffer[1] = (byte)(0x80 | btPollRate); // input report rate
|
||||||
outputReportBuffer[3] = 0xff;
|
outputReportBuffer[3] = 0xff;
|
||||||
outputReportBuffer[6] = rightLightFastRumble; //fast motor
|
outputReportBuffer[6] = rightLightFastRumble; // fast motor
|
||||||
outputReportBuffer[7] = leftHeavySlowRumble; //slow motor
|
outputReportBuffer[7] = leftHeavySlowRumble; // slow motor
|
||||||
outputReportBuffer[8] = LightBarColor.red; //red
|
outputReportBuffer[8] = LightBarColor.red; // red
|
||||||
outputReportBuffer[9] = LightBarColor.green; //green
|
outputReportBuffer[9] = LightBarColor.green; // green
|
||||||
outputReportBuffer[10] = LightBarColor.blue; //blue
|
outputReportBuffer[10] = LightBarColor.blue; // blue
|
||||||
outputReportBuffer[11] = ledFlashOn; //flash on duration
|
outputReportBuffer[11] = ledFlashOn; // flash on duration
|
||||||
outputReportBuffer[12] = ledFlashOff; //flash off duration
|
outputReportBuffer[12] = ledFlashOff; // flash off duration
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
outputReportBuffer[0] = 0x05;
|
outputReportBuffer[0] = 0x05;
|
||||||
outputReportBuffer[1] = 0xff;
|
outputReportBuffer[1] = 0xff;
|
||||||
outputReportBuffer[4] = rightLightFastRumble; //fast motor
|
outputReportBuffer[4] = rightLightFastRumble; // fast motor
|
||||||
outputReportBuffer[5] = leftHeavySlowRumble; //slow motor
|
outputReportBuffer[5] = leftHeavySlowRumble; // slow motor
|
||||||
outputReportBuffer[6] = LightBarColor.red; //red
|
outputReportBuffer[6] = LightBarColor.red; // red
|
||||||
outputReportBuffer[7] = LightBarColor.green; //green
|
outputReportBuffer[7] = LightBarColor.green; // green
|
||||||
outputReportBuffer[8] = LightBarColor.blue; //blue
|
outputReportBuffer[8] = LightBarColor.blue; // blue
|
||||||
outputReportBuffer[9] = ledFlashOn; //flash on duration
|
outputReportBuffer[9] = ledFlashOn; // flash on duration
|
||||||
outputReportBuffer[10] = ledFlashOff; //flash off duration
|
outputReportBuffer[10] = ledFlashOff; // flash off duration
|
||||||
if (conType == ConnectionType.SONYWA)
|
if (conType == ConnectionType.SONYWA)
|
||||||
{
|
{
|
||||||
// Headphone volume levels
|
// Headphone volume levels
|
||||||
@ -907,7 +912,7 @@ namespace DS4Windows
|
|||||||
{
|
{
|
||||||
int winError = Marshal.GetLastWin32Error();
|
int winError = Marshal.GetLastWin32Error();
|
||||||
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> encountered synchronous write failure: " + winError);
|
Console.WriteLine(Mac.ToString() + " " + System.DateTime.UtcNow.ToString("o") + "> encountered synchronous write failure: " + winError);
|
||||||
Log.LogToGui(Mac.ToString() + " encountered synchronous write failure: " + winError, true);
|
//Log.LogToGui(Mac.ToString() + " encountered synchronous write failure: " + winError, true);
|
||||||
quitOutputThread = true;
|
quitOutputThread = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user