Skip to content
This repository has been archived by the owner on Jan 1, 2024. It is now read-only.

Commit

Permalink
Some small changes to the mapping routine
Browse files Browse the repository at this point in the history
  • Loading branch information
Ryochan7 committed Apr 8, 2017
1 parent f050df5 commit a1f103c
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 11 deletions.
4 changes: 2 additions & 2 deletions DS4Windows/DS4Control/DS4LightBar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -164,9 +164,9 @@ public static void updateLightBar(DS4Device device, int deviceNum, DS4State cSta
//distanceprofile = (ProfilePath[deviceNum].ToLower().Contains("distance") || tempprofilename[deviceNum].ToLower().Contains("distance"));
if (distanceprofile && !defualtLight)
{ //Thing I did for Distance
float rumble = device.LeftHeavySlowRumble / 2.55f;
float rumble = device.getLeftHeavySlowRumble() / 2.55f;
byte max = Max(color.red, Max(color.green, color.blue));
if (device.LeftHeavySlowRumble > 100)
if (device.getLeftHeavySlowRumble() > 100)
color = getTransitionedColor(new DS4Color(max, max, 0), new DS4Color(255, 0, 0), rumble);
else
color = getTransitionedColor(color, getTransitionedColor(new DS4Color(max, max, 0), new DS4Color(255, 0, 0), 39.6078f), device.getLeftHeavySlowRumble());
Expand Down
32 changes: 23 additions & 9 deletions DS4Windows/DS4Control/Mapping.cs
Original file line number Diff line number Diff line change
Expand Up @@ -687,6 +687,7 @@ private static bool ShiftTrigger(int trigger, int device, DS4State cState, DS4St
{
switch (trigger)
{
case 0: return false;
case 1: return getBoolMapping(device, DS4Controls.Cross, cState, eState, tp);
case 2: return getBoolMapping(device, DS4Controls.Circle, cState, eState, tp);
case 3: return getBoolMapping(device, DS4Controls.Square, cState, eState, tp);
Expand Down Expand Up @@ -792,7 +793,6 @@ public static void MapCustom(int device, DS4State cState, DS4State MappedState,
cState.CopyTo(MappedState);

Dictionary<DS4Controls, DS4Controls> tempControlDict = new Dictionary<DS4Controls, DS4Controls>();
//Dictionary<DS4Controls, DS4Controls> tempAxesControlDict = new Dictionary<DS4Controls, DS4Controls>();
DS4Controls usingExtra = DS4Controls.None;
foreach (DS4ControlSettings dcs in getDS4CSettings(device))
{
Expand All @@ -811,6 +811,7 @@ public static void MapCustom(int device, DS4State cState, DS4State MappedState,
actionType = dcs.actionType;
keyType = dcs.keyType;
}

if (action != null)
{
if (actionType == DS4ControlSettings.ActionType.Macro)
Expand Down Expand Up @@ -991,8 +992,9 @@ public static void MapCustom(int device, DS4State cState, DS4State MappedState,
else
p = dcs.extras;
string[] extraS = p.Split(',');
int[] extras = new int[extraS.Length];
for (int i = 0; i < extraS.Length; i++)
int extrasSLen = extraS.Length;
int[] extras = new int[extrasSLen];
for (int i = 0; i < extrasSLen; i++)
{
int b;
if (int.TryParse(extraS[i], out b))
Expand Down Expand Up @@ -1188,7 +1190,10 @@ public static void MapCustom(int device, DS4State cState, DS4State MappedState,
}
}

InputMethods.MoveCursorBy(MouseDeltaX, MouseDeltaY);
if (MouseDeltaX != 0 || MouseDeltaY != 0)
{
InputMethods.MoveCursorBy(MouseDeltaX, MouseDeltaY);
}
}

private static bool IfAxisIsNotModified(int device, bool shift, DS4Controls dc)
Expand All @@ -1200,6 +1205,8 @@ public static async void MapCustomAction(int device, DS4State cState, DS4State M
/* TODO: This method is slow sauce. Find ways to speed up action execution */
try
{
int actionDoneCount = actionDone.Count;
int totalActionCount = GetActions().Count;
List<string> profileActions = getProfileActions(device);
foreach (string actionname in profileActions)
{
Expand All @@ -1208,11 +1215,18 @@ public static async void MapCustomAction(int device, DS4State cState, DS4State M
//int index = GetActionIndexOf(actionname);
SpecialAction action = GetProfileAction(device, actionname);
int index = GetProfileActionIndexOf(device, actionname);
int actionDoneCount = actionDone.Count;

if (actionDoneCount < index + 1)
{
actionDone.Add(new ActionState());
else if (actionDoneCount > GetActions().Count)
actionDoneCount++;
}
else if (actionDoneCount > totalActionCount)
{
actionDone.RemoveAt(actionDoneCount - 1);
actionDoneCount--;
}

double time = 0.0;
//If a key or button is assigned to the trigger, a key special action is used like
//a quick tap to use and hold to use the regular custom button/key
Expand Down Expand Up @@ -1399,7 +1413,7 @@ public static async void MapCustomAction(int device, DS4State cState, DS4State M
else if (triggeractivated && action.typeID == SpecialAction.ActionTypeId.DisconnectBT)
{
DS4Device d = ctrl.DS4Controllers[device];
if (!d.Charging)
if (!d.isCharging())
{
ConnectionType deviceConn = d.ConnectionType;
if (deviceConn == ConnectionType.BT)
Expand All @@ -1417,7 +1431,7 @@ public static async void MapCustomAction(int device, DS4State cState, DS4State M
else if (dcs.actionType == DS4ControlSettings.ActionType.Macro)
{
int[] keys = (int[])dcs.action;
for (int i = 0; i < keys.Length; i++)
for (int i = 0, keysLen = keys.Length; i < keysLen; i++)
InputMethods.performKeyRelease((ushort)keys[i]);
}
}
Expand Down Expand Up @@ -1616,7 +1630,7 @@ public static async void MapCustomAction(int device, DS4State cState, DS4State M
else if (dcs.actionType == DS4ControlSettings.ActionType.Macro)
{
int[] keys = (int[])dcs.action;
for (int i = 0; i < keys.Length; i++)
for (int i = 0, keysLen=keys.Length; i < keysLen; i++)
InputMethods.performKeyRelease((ushort)keys[i]);
}
}
Expand Down

0 comments on commit a1f103c

Please sign in to comment.