Minor optimizations

This commit is contained in:
Travis Nickles 2017-05-18 17:51:01 -07:00
parent b3bd007219
commit 1e2c57a08a
2 changed files with 100 additions and 43 deletions

View File

@ -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;
} }
} }

View File

@ -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;
} }
} }