mirror of
https://github.com/euphy/polargraphcontroller
synced 2025-01-09 19:55:16 +01:00
More gamepad based things, and a couple of ways to filter the vector results.
This commit is contained in:
parent
f81386f61c
commit
fe828d01d8
@ -430,17 +430,20 @@ class DisplayMachine extends Machine
|
|||||||
{
|
{
|
||||||
for(int i = 0; i<pointPaths.length; i++)
|
for(int i = 0; i<pointPaths.length; i++)
|
||||||
{
|
{
|
||||||
if (pointPaths[i] != null)
|
if (pointPaths[i].length >= pathLengthHighPassCutoff)
|
||||||
{
|
{
|
||||||
beginShape();
|
if (pointPaths[i] != null)
|
||||||
for (int j = 0; j<pointPaths[i].length; j++)
|
|
||||||
{
|
{
|
||||||
PVector p = new PVector(pointPaths[i][j].x, pointPaths[i][j].y);
|
beginShape();
|
||||||
p = PVector.mult(p, scaler);
|
for (int j = 0; j<pointPaths[i].length; j++)
|
||||||
p = PVector.add(p, position);
|
{
|
||||||
vertex(p.x, p.y);
|
PVector p = new PVector(pointPaths[i][j].x, pointPaths[i][j].y);
|
||||||
|
p = PVector.mult(p, scaler);
|
||||||
|
p = PVector.add(p, position);
|
||||||
|
vertex(p.x, p.y);
|
||||||
|
}
|
||||||
|
endShape();
|
||||||
}
|
}
|
||||||
endShape();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -132,14 +132,26 @@ void button_mode_liveAddCaption()
|
|||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
void numberbox_mode_vectorPathLengthHighPassCutoff(int value)
|
||||||
|
{
|
||||||
|
pathLengthHighPassCutoff = value;
|
||||||
|
}
|
||||||
|
|
||||||
void button_mode_liveConfirmDraw()
|
void button_mode_liveConfirmDraw()
|
||||||
{
|
{
|
||||||
// work out scaling and position
|
if (captureShape != null)
|
||||||
float scaling = getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getWidth()) / captureShape.getWidth();
|
{
|
||||||
PVector position = new PVector(getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getPosition().x), getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getPosition().y) + (captureShape.getHeight() * scaling));
|
// save shape as SVG
|
||||||
|
|
||||||
sendVectorShapes(captureShape, scaling, position);
|
|
||||||
|
|
||||||
|
// work out scaling and position
|
||||||
|
float scaling = getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getWidth()) / captureShape.getWidth();
|
||||||
|
PVector position = new PVector(getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getPosition().x), getDisplayMachine().inMM(getDisplayMachine().getPictureFrame().getPosition().y) + (captureShape.getHeight() * scaling));
|
||||||
|
|
||||||
|
sendVectorShapes(captureShape, scaling, position);
|
||||||
|
button_mode_penUp();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -474,15 +474,15 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
|||||||
n.setDecimalPrecision(1);
|
n.setDecimalPrecision(1);
|
||||||
n.setValue(blurValue);
|
n.setValue(blurValue);
|
||||||
n.setMin(1);
|
n.setMin(1);
|
||||||
n.setMax(100);
|
n.setMax(10);
|
||||||
n.setMultiplier(0.1);
|
n.setMultiplier(0.1);
|
||||||
}
|
}
|
||||||
else if (MODE_LIVE_SIMPLIFICATION_VALUE.equals(key))
|
else if (MODE_LIVE_SIMPLIFICATION_VALUE.equals(key))
|
||||||
{
|
{
|
||||||
n.setDecimalPrecision(1);
|
n.setDecimalPrecision(1);
|
||||||
n.setValue(liveSimplification);
|
n.setValue(liveSimplification);
|
||||||
n.setMin(0);
|
n.setMin(LIVE_SIMPLIFICATION_MIN);
|
||||||
n.setMax(360);
|
n.setMax(LIVE_SIMPLIFICATION_MAX);
|
||||||
n.setMultiplier(0.1);
|
n.setMultiplier(0.1);
|
||||||
}
|
}
|
||||||
else if (MODE_LIVE_POSTERISE_VALUE.equals(key))
|
else if (MODE_LIVE_POSTERISE_VALUE.equals(key))
|
||||||
@ -493,6 +493,14 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
|||||||
n.setMax(32);
|
n.setMax(32);
|
||||||
n.setMultiplier(0.1);
|
n.setMultiplier(0.1);
|
||||||
}
|
}
|
||||||
|
else if (MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF.equals(key))
|
||||||
|
{
|
||||||
|
n.setDecimalPrecision(1);
|
||||||
|
n.setValue(pathLengthHighPassCutoff);
|
||||||
|
n.setMin(0);
|
||||||
|
n.setMax(10000);
|
||||||
|
n.setMultiplier(0.5);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
@ -663,6 +671,7 @@ List<String> getControlNamesForInputPanel()
|
|||||||
controlNames.add(MODE_RESIZE_VECTOR);
|
controlNames.add(MODE_RESIZE_VECTOR);
|
||||||
controlNames.add(MODE_MOVE_VECTOR);
|
controlNames.add(MODE_MOVE_VECTOR);
|
||||||
controlNames.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
controlNames.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
||||||
|
controlNames.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
||||||
controlNames.add(MODE_RENDER_VECTORS);
|
controlNames.add(MODE_RENDER_VECTORS);
|
||||||
|
|
||||||
controlNames.add(MODE_SHOW_IMAGE);
|
controlNames.add(MODE_SHOW_IMAGE);
|
||||||
@ -706,6 +715,7 @@ List<String> getControlNamesForWebcamPanel()
|
|||||||
controlNames.add(MODE_LIVE_CANCEL_CAPTURE);
|
controlNames.add(MODE_LIVE_CANCEL_CAPTURE);
|
||||||
controlNames.add(MODE_LIVE_ADD_CAPTION);
|
controlNames.add(MODE_LIVE_ADD_CAPTION);
|
||||||
controlNames.add(MODE_LIVE_CONFIRM_DRAW);
|
controlNames.add(MODE_LIVE_CONFIRM_DRAW);
|
||||||
|
controlNames.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
||||||
return controlNames;
|
return controlNames;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -911,6 +921,8 @@ Map<String, String> buildControlLabels()
|
|||||||
result.put(MODE_LIVE_CANCEL_CAPTURE, "Cancel capture");
|
result.put(MODE_LIVE_CANCEL_CAPTURE, "Cancel capture");
|
||||||
result.put(MODE_LIVE_ADD_CAPTION, "Add caption");
|
result.put(MODE_LIVE_ADD_CAPTION, "Add caption");
|
||||||
|
|
||||||
|
result.put(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF, "Path length cutoff");
|
||||||
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -1043,6 +1055,7 @@ Set<String> buildControlNames()
|
|||||||
result.add(MODE_LIVE_CONFIRM_DRAW);
|
result.add(MODE_LIVE_CONFIRM_DRAW);
|
||||||
result.add(MODE_LIVE_CANCEL_CAPTURE);
|
result.add(MODE_LIVE_CANCEL_CAPTURE);
|
||||||
result.add(MODE_LIVE_ADD_CAPTION);
|
result.add(MODE_LIVE_ADD_CAPTION);
|
||||||
|
result.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
86
drawing.pde
86
drawing.pde
@ -649,7 +649,7 @@ void sendVectorShapes(RShape vec, float scaling, PVector position)
|
|||||||
RPoint[][] pointPaths = vec.getPointsInPaths();
|
RPoint[][] pointPaths = vec.getPointsInPaths();
|
||||||
|
|
||||||
// sort the paths to optimise the draw sequence
|
// sort the paths to optimise the draw sequence
|
||||||
pointPaths = sortPathLongestFirst(pointPaths);
|
pointPaths = sortPathLongestFirst(pointPaths, pathLengthHighPassCutoff);
|
||||||
|
|
||||||
String command = "";
|
String command = "";
|
||||||
PVector lastPoint = new PVector();
|
PVector lastPoint = new PVector();
|
||||||
@ -662,43 +662,47 @@ void sendVectorShapes(RShape vec, float scaling, PVector position)
|
|||||||
{
|
{
|
||||||
boolean firstPointFound = false;
|
boolean firstPointFound = false;
|
||||||
|
|
||||||
List<PVector> filteredPoints = filterPoints(pointPaths[i], VECTOR_FILTER_LOW_PASS, minimumVectorLineLength, scaling, position);
|
if (pointPaths[i].length > pathLengthHighPassCutoff)
|
||||||
//println(filteredPoints);
|
|
||||||
if (!filteredPoints.isEmpty())
|
|
||||||
{
|
{
|
||||||
// draw the first one with a pen up and down to get to it
|
List<PVector> filteredPoints = filterPoints(pointPaths[i], VECTOR_FILTER_LOW_PASS, minimumVectorLineLength, scaling, position);
|
||||||
PVector p = filteredPoints.get(0);
|
//println(filteredPoints);
|
||||||
if ( p.x == lastPoint.x && p.y == lastPoint.y )
|
if (!filteredPoints.isEmpty())
|
||||||
liftToGetToNewPoint = false;
|
|
||||||
else
|
|
||||||
liftToGetToNewPoint = true;
|
|
||||||
|
|
||||||
// pen UP! (IF THE NEW POINT IS DIFFERENT FROM THE LAST ONE!)
|
|
||||||
if (liftToGetToNewPoint)
|
|
||||||
addToCommandQueue(CMD_PENUP+"END");
|
|
||||||
// move to this point and put the pen down
|
|
||||||
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
|
||||||
addToCommandQueue(command);
|
|
||||||
if (liftToGetToNewPoint)
|
|
||||||
addToCommandQueue(CMD_PENDOWN+"END");
|
|
||||||
|
|
||||||
// then just iterate through the rest
|
|
||||||
for (int j=1; j<filteredPoints.size(); j++)
|
|
||||||
{
|
{
|
||||||
p = filteredPoints.get(j);
|
// draw the first one with a pen up and down to get to it
|
||||||
|
PVector p = filteredPoints.get(0);
|
||||||
|
if ( p.x == lastPoint.x && p.y == lastPoint.y )
|
||||||
|
liftToGetToNewPoint = false;
|
||||||
|
else
|
||||||
|
liftToGetToNewPoint = true;
|
||||||
|
|
||||||
|
// pen UP! (IF THE NEW POINT IS DIFFERENT FROM THE LAST ONE!)
|
||||||
|
if (liftToGetToNewPoint)
|
||||||
|
addToCommandQueue(CMD_PENUP+"END");
|
||||||
|
// move to this point and put the pen down
|
||||||
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
||||||
addToCommandQueue(command);
|
addToCommandQueue(command);
|
||||||
|
if (liftToGetToNewPoint)
|
||||||
|
addToCommandQueue(CMD_PENDOWN+"END");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// then just iterate through the rest
|
||||||
|
for (int j=1; j<filteredPoints.size(); j++)
|
||||||
|
{
|
||||||
|
p = filteredPoints.get(j);
|
||||||
|
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
||||||
|
addToCommandQueue(command);
|
||||||
|
}
|
||||||
|
lastPoint = new PVector(p.x,p.y);
|
||||||
|
|
||||||
}
|
}
|
||||||
lastPoint = new PVector(p.x,p.y);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
println("finished.");
|
println("finished.");
|
||||||
}
|
}
|
||||||
|
|
||||||
public RPoint[][] sortPathLongestFirst(RPoint[][] pointPaths)
|
public RPoint[][] sortPathLongestFirst(RPoint[][] pointPaths, int highPassCutoff)
|
||||||
{
|
{
|
||||||
// put the paths into a list
|
// put the paths into a list
|
||||||
List<RPoint[]> pathsList = new ArrayList<RPoint[]>(pointPaths.length);
|
List<RPoint[]> pathsList = new ArrayList<RPoint[]>(pointPaths.length);
|
||||||
@ -710,7 +714,6 @@ public RPoint[][] sortPathLongestFirst(RPoint[][] pointPaths)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
println("PathsList: ");
|
|
||||||
for (RPoint[] path : pathsList)
|
for (RPoint[] path : pathsList)
|
||||||
println(path.length + ", ");
|
println(path.length + ", ");
|
||||||
|
|
||||||
@ -726,18 +729,35 @@ public RPoint[][] sortPathLongestFirst(RPoint[][] pointPaths)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// filter out some short paths
|
||||||
|
pathsList = removeShortPaths(pathsList, highPassCutoff);
|
||||||
|
|
||||||
println("Sorted PathsList: ");
|
// and put them into a new array
|
||||||
for (RPoint[] path : pathsList)
|
|
||||||
println(path.length + ", ");
|
|
||||||
|
|
||||||
for (int i=0; i<pathsList.size(); i++)
|
for (int i=0; i<pathsList.size(); i++)
|
||||||
{
|
{
|
||||||
pointPaths[i] = pathsList.get(i);
|
pointPaths[i] = pathsList.get(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
return pointPaths;
|
return pointPaths;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<RPoint[]> removeShortPaths(List<RPoint[]> list, int cutoff)
|
||||||
|
{
|
||||||
|
if (cutoff > 0)
|
||||||
|
{
|
||||||
|
int numberOfPaths = list.size();
|
||||||
|
for (int i=0; i<numberOfPaths; i++)
|
||||||
|
{
|
||||||
|
if (cutoff >= list.get(i).length)
|
||||||
|
{
|
||||||
|
list.remove(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
List<PVector> filterPoints(RPoint[] points, int filterToUse, long filterParam, float scaling, PVector position)
|
List<PVector> filterPoints(RPoint[] points, int filterToUse, long filterParam, float scaling, PVector position)
|
||||||
{
|
{
|
||||||
return filterPointsLowPass(points, filterParam, scaling, position);
|
return filterPointsLowPass(points, filterParam, scaling, position);
|
||||||
|
108
gamepad.pde
108
gamepad.pde
@ -1,31 +1,113 @@
|
|||||||
ControllIO controllIO;
|
ControllIO controllIO;
|
||||||
ControllDevice joypad;
|
ControllDevice joypad;
|
||||||
ControllCoolieHat cooliehat;
|
|
||||||
ControllStick leftStick;
|
|
||||||
ControllStick rightStick;
|
|
||||||
|
|
||||||
ControllButton buttonA;
|
ControllButton buttonA;
|
||||||
ControllButton buttonB;
|
ControllButton buttonB;
|
||||||
ControllButton buttonX;
|
ControllButton buttonX;
|
||||||
ControllButton buttonY;
|
ControllButton buttonY;
|
||||||
|
|
||||||
|
ControllCoolieHat dpad;
|
||||||
|
|
||||||
|
|
||||||
|
String inputDeviceName = "Controller (Xbox 360 Wireless Receiver for Windows)";
|
||||||
|
|
||||||
|
|
||||||
|
String signalFromGamepad = null;
|
||||||
|
|
||||||
|
static final String BUTTON_A_RELEASED = "ButtonAReleased";
|
||||||
|
static final String BUTTON_B_RELEASED = "ButtonBReleased";
|
||||||
|
|
||||||
void gamepad_init()
|
void gamepad_init()
|
||||||
{
|
{
|
||||||
controllIO = ControllIO.getInstance(this);
|
controllIO = ControllIO.getInstance(this);
|
||||||
|
|
||||||
joypad = controllIO.getDevice("Controller (Xbox 360 Wireless Receiver for Windows)");
|
try
|
||||||
joypad.printButtons();
|
{
|
||||||
|
joypad = controllIO.getDevice(inputDeviceName);
|
||||||
buttonA = joypad.getButton("Button 0");
|
joypad.printButtons();
|
||||||
buttonB = joypad.getButton("Button 1");
|
|
||||||
buttonX = joypad.getButton("Button 2");
|
|
||||||
buttonY = joypad.getButton("Button 3");
|
|
||||||
|
|
||||||
buttonA.plug(this, "buttonARelease", ControllIO.ON_RELEASE);
|
buttonA = joypad.getButton("Button 0");
|
||||||
|
buttonB = joypad.getButton("Button 1");
|
||||||
|
buttonX = joypad.getButton("Button 2");
|
||||||
|
buttonY = joypad.getButton("Button 3");
|
||||||
|
|
||||||
|
buttonA.plug(this, "buttonARelease", ControllIO.ON_RELEASE);
|
||||||
|
buttonB.plug(this, "buttonBRelease", ControllIO.ON_RELEASE);
|
||||||
|
buttonX.plug(this, "buttonXPress", ControllIO.ON_PRESS);
|
||||||
|
buttonX.plug(this, "buttonXRelease", ControllIO.ON_RELEASE);
|
||||||
|
buttonY.plug(this, "buttonYRelease", ControllIO.ON_RELEASE);
|
||||||
|
|
||||||
|
dpad = joypad.getCoolieHat(10);
|
||||||
|
dpad.setMultiplier(4);
|
||||||
|
dpad.plug(this, "dpadPress", ControllIO.ON_PRESS);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (RuntimeException e)
|
||||||
|
{
|
||||||
|
println("Requested device (" + inputDeviceName + ") not found.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void buttonARelease()
|
public void buttonARelease()
|
||||||
{
|
{
|
||||||
button_mode_liveCaptureFromLive();
|
signalFromGamepad = BUTTON_A_RELEASED;
|
||||||
|
}
|
||||||
|
public void buttonBRelease()
|
||||||
|
{
|
||||||
|
signalFromGamepad = BUTTON_B_RELEASED;
|
||||||
|
}
|
||||||
|
|
||||||
|
void buttonXPress()
|
||||||
|
{
|
||||||
|
drawingLiveVideo = true;
|
||||||
|
}
|
||||||
|
void buttonXRelease()
|
||||||
|
{
|
||||||
|
drawingLiveVideo = false;
|
||||||
|
}
|
||||||
|
void buttonYRelease()
|
||||||
|
{
|
||||||
|
flipWebcamImage = !flipWebcamImage;
|
||||||
|
}
|
||||||
|
|
||||||
|
void dpadPress(float x, float y)
|
||||||
|
{
|
||||||
|
println("VAl:" + dpad.getValue());
|
||||||
|
float val = dpad.getValue();
|
||||||
|
if (val == 2.0)
|
||||||
|
{
|
||||||
|
liveSimplification--;
|
||||||
|
if (liveSimplification < LIVE_SIMPLIFICATION_MIN)
|
||||||
|
liveSimplification = LIVE_SIMPLIFICATION_MIN;
|
||||||
|
}
|
||||||
|
else if (val == 6.0)
|
||||||
|
{
|
||||||
|
liveSimplification++;
|
||||||
|
if (liveSimplification > LIVE_SIMPLIFICATION_MAX)
|
||||||
|
liveSimplification = LIVE_SIMPLIFICATION_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
Numberbox n = (Numberbox) getAllControls().get(MODE_LIVE_SIMPLIFICATION_VALUE);
|
||||||
|
n.setValue(liveSimplification);
|
||||||
|
n.update();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void processGamepadInput()
|
||||||
|
{
|
||||||
|
if (signalFromGamepad != null)
|
||||||
|
{
|
||||||
|
if (signalFromGamepad == BUTTON_A_RELEASED)
|
||||||
|
if (captureShape == null)
|
||||||
|
button_mode_liveCaptureFromLive();
|
||||||
|
else
|
||||||
|
button_mode_liveClearCapture();
|
||||||
|
else if (signalFromGamepad == BUTTON_B_RELEASED)
|
||||||
|
button_mode_liveConfirmDraw();
|
||||||
|
|
||||||
|
|
||||||
|
// clear the signal
|
||||||
|
signalFromGamepad = null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -111,6 +111,8 @@ Serial myPort; // The serial port
|
|||||||
int[] serialInArray = new int[1]; // Where we'll put what we receive
|
int[] serialInArray = new int[1]; // Where we'll put what we receive
|
||||||
int serialCount = 0; // A count of how many bytes we receive
|
int serialCount = 0; // A count of how many bytes we receive
|
||||||
|
|
||||||
|
boolean[] keys = new boolean[526];
|
||||||
|
|
||||||
final JFileChooser chooser = new JFileChooser();
|
final JFileChooser chooser = new JFileChooser();
|
||||||
|
|
||||||
SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yy hh:mm:ss");
|
SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yy hh:mm:ss");
|
||||||
@ -317,6 +319,8 @@ static final String MODE_LIVE_CANCEL_CAPTURE = "button_mode_liveClearCapture";
|
|||||||
static final String MODE_LIVE_ADD_CAPTION = "button_mode_liveAddCaption";
|
static final String MODE_LIVE_ADD_CAPTION = "button_mode_liveAddCaption";
|
||||||
static final String MODE_LIVE_CONFIRM_DRAW = "button_mode_liveConfirmDraw";
|
static final String MODE_LIVE_CONFIRM_DRAW = "button_mode_liveConfirmDraw";
|
||||||
|
|
||||||
|
static final String MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF = "numberbox_mode_vectorPathLengthHighPassCutoff";
|
||||||
|
|
||||||
|
|
||||||
PVector statusTextPosition = new PVector(300.0, 12.0);
|
PVector statusTextPosition = new PVector(300.0, 12.0);
|
||||||
|
|
||||||
@ -463,6 +467,11 @@ static PImage processedLiveImage = null;
|
|||||||
static PImage capturedImage = null;
|
static PImage capturedImage = null;
|
||||||
static PImage processedCapturedImage = null;
|
static PImage processedCapturedImage = null;
|
||||||
|
|
||||||
|
static final Integer LIVE_SIMPLIFICATION_MIN = 1;
|
||||||
|
static final Integer LIVE_SIMPLIFICATION_MAX = 32;
|
||||||
|
|
||||||
|
static int pathLengthHighPassCutoff = 100;
|
||||||
|
|
||||||
JMyron liveCamera;
|
JMyron liveCamera;
|
||||||
BlobDetector blob_detector;
|
BlobDetector blob_detector;
|
||||||
int liveSimplification = 4;
|
int liveSimplification = 4;
|
||||||
@ -818,8 +827,11 @@ void drawWebcamPage()
|
|||||||
drawStatusText((int)statusTextPosition.x, (int)statusTextPosition.y);
|
drawStatusText((int)statusTextPosition.x, (int)statusTextPosition.y);
|
||||||
showCommandQueue((int) width-200, 20);
|
showCommandQueue((int) width-200, 20);
|
||||||
|
|
||||||
|
processGamepadInput();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void drawCommandQueuePage()
|
void drawCommandQueuePage()
|
||||||
{
|
{
|
||||||
cursor(ARROW);
|
cursor(ARROW);
|
||||||
@ -1318,41 +1330,44 @@ void changeMachineScaling(int delta)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean checkKey(int k)
|
||||||
|
{
|
||||||
|
if (keys.length >= k) {
|
||||||
|
return keys[k];
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void keyReleased()
|
||||||
|
{
|
||||||
|
keys[keyCode] = false;
|
||||||
|
}
|
||||||
|
|
||||||
void keyPressed()
|
void keyPressed()
|
||||||
{
|
{
|
||||||
if (key == CODED)
|
|
||||||
{
|
keys[keyCode] = true;
|
||||||
// set key to zero (or something besides the ESC).
|
println(KeyEvent.getKeyText(keyCode));
|
||||||
if (keyCode == java.awt.event.KeyEvent.VK_PAGE_UP)
|
|
||||||
{
|
if (checkKey(CONTROL) && checkKey(KeyEvent.VK_PAGE_UP))
|
||||||
changeMachineScaling(1);
|
changeMachineScaling(1);
|
||||||
}
|
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_PAGE_DOWN))
|
||||||
else if (keyCode == java.awt.event.KeyEvent.VK_PAGE_DOWN)
|
changeMachineScaling(-1);
|
||||||
{
|
else if (checkKey(CONTROL) && checkKey(DOWN))
|
||||||
changeMachineScaling(-1);
|
getDisplayMachine().getOffset().y = getDisplayMachine().getOffset().y + 10;
|
||||||
}
|
else if (checkKey(CONTROL) && checkKey(UP))
|
||||||
else if (keyCode == DOWN)
|
getDisplayMachine().getOffset().y = getDisplayMachine().getOffset().y - 10;
|
||||||
{
|
else if (checkKey(CONTROL) && checkKey(RIGHT))
|
||||||
getDisplayMachine().getOffset().y = getDisplayMachine().getOffset().y + 10;
|
getDisplayMachine().getOffset().x = getDisplayMachine().getOffset().x + 10;
|
||||||
}
|
else if (checkKey(CONTROL) && checkKey(LEFT))
|
||||||
else if (keyCode == UP)
|
getDisplayMachine().getOffset().x = getDisplayMachine().getOffset().x - 10;
|
||||||
{
|
else if (checkKey(KeyEvent.VK_ESCAPE))
|
||||||
getDisplayMachine().getOffset().y = getDisplayMachine().getOffset().y - 10;
|
|
||||||
}
|
|
||||||
else if (keyCode == RIGHT)
|
|
||||||
{
|
|
||||||
getDisplayMachine().getOffset().x = getDisplayMachine().getOffset().x + 10;
|
|
||||||
}
|
|
||||||
else if (keyCode == LEFT)
|
|
||||||
{
|
|
||||||
getDisplayMachine().getOffset().x = getDisplayMachine().getOffset().x - 10;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (key == java.awt.event.KeyEvent.VK_ESCAPE)
|
|
||||||
{
|
|
||||||
key = 0;
|
key = 0;
|
||||||
}
|
|
||||||
else if (key == 'g' || key == 'G')
|
// if (checkKey(CONTROL) && checkKey(KeyEvent.VK_G))
|
||||||
|
// println("CTRL+G");
|
||||||
|
|
||||||
|
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_G))
|
||||||
{
|
{
|
||||||
Toggle t = (Toggle) getAllControls().get(MODE_SHOW_GUIDES);
|
Toggle t = (Toggle) getAllControls().get(MODE_SHOW_GUIDES);
|
||||||
if (displayingGuides)
|
if (displayingGuides)
|
||||||
@ -1367,7 +1382,7 @@ void keyPressed()
|
|||||||
}
|
}
|
||||||
t.update();
|
t.update();
|
||||||
}
|
}
|
||||||
else if (key == 'c' || key == 'C')
|
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_C))
|
||||||
{
|
{
|
||||||
if (isUseWindowedConsole())
|
if (isUseWindowedConsole())
|
||||||
setUseWindowedConsole(false);
|
setUseWindowedConsole(false);
|
||||||
@ -1376,70 +1391,69 @@ void keyPressed()
|
|||||||
|
|
||||||
initLogging();
|
initLogging();
|
||||||
}
|
}
|
||||||
else if (key == 's' || key == 'S')
|
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_S))
|
||||||
{
|
{
|
||||||
if (getDisplayMachine().pixelsCanBeExtracted() && isBoxSpecified())
|
if (getDisplayMachine().pixelsCanBeExtracted() && isBoxSpecified())
|
||||||
displayingSelectedCentres = (displayingSelectedCentres) ? false : true;
|
displayingSelectedCentres = (displayingSelectedCentres) ? false : true;
|
||||||
}
|
}
|
||||||
else if (key == 'i' || key == 'I')
|
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_I))
|
||||||
{
|
{
|
||||||
println("I pressed!.");
|
|
||||||
displayingInfoTextOnInputPage = (displayingInfoTextOnInputPage) ? false : true;
|
displayingInfoTextOnInputPage = (displayingInfoTextOnInputPage) ? false : true;
|
||||||
}
|
}
|
||||||
else if (key == '+')
|
// else if (key == '+')
|
||||||
{
|
// {
|
||||||
currentMachineMaxSpeed = currentMachineMaxSpeed+MACHINE_MAXSPEED_INCREMENT;
|
// currentMachineMaxSpeed = currentMachineMaxSpeed+MACHINE_MAXSPEED_INCREMENT;
|
||||||
currentMachineMaxSpeed = Math.round(currentMachineMaxSpeed*100.0)/100.0;
|
// currentMachineMaxSpeed = Math.round(currentMachineMaxSpeed*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_SETMOTORSPEED+df.format(currentMachineMaxSpeed)+",END");
|
// addToRealtimeCommandQueue(CMD_SETMOTORSPEED+df.format(currentMachineMaxSpeed)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == '-')
|
// else if (key == '-')
|
||||||
{
|
// {
|
||||||
currentMachineMaxSpeed = currentMachineMaxSpeed+(0.0 - MACHINE_MAXSPEED_INCREMENT);
|
// currentMachineMaxSpeed = currentMachineMaxSpeed+(0.0 - MACHINE_MAXSPEED_INCREMENT);
|
||||||
currentMachineMaxSpeed = Math.round(currentMachineMaxSpeed*100.0)/100.0;
|
// currentMachineMaxSpeed = Math.round(currentMachineMaxSpeed*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_SETMOTORSPEED+df.format(currentMachineMaxSpeed)+",END");
|
// addToRealtimeCommandQueue(CMD_SETMOTORSPEED+df.format(currentMachineMaxSpeed)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == '*')
|
// else if (key == '*')
|
||||||
{
|
// {
|
||||||
currentMachineAccel = currentMachineAccel+MACHINE_ACCEL_INCREMENT;
|
// currentMachineAccel = currentMachineAccel+MACHINE_ACCEL_INCREMENT;
|
||||||
currentMachineAccel = Math.round(currentMachineAccel*100.0)/100.0;
|
// currentMachineAccel = Math.round(currentMachineAccel*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_SETMOTORACCEL+df.format(currentMachineAccel)+",END");
|
// addToRealtimeCommandQueue(CMD_SETMOTORACCEL+df.format(currentMachineAccel)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == '/')
|
// else if (key == '/')
|
||||||
{
|
// {
|
||||||
currentMachineAccel = currentMachineAccel+(0.0 - MACHINE_ACCEL_INCREMENT);
|
// currentMachineAccel = currentMachineAccel+(0.0 - MACHINE_ACCEL_INCREMENT);
|
||||||
currentMachineAccel = Math.round(currentMachineAccel*100.0)/100.0;
|
// currentMachineAccel = Math.round(currentMachineAccel*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_SETMOTORACCEL+df.format(currentMachineAccel)+",END");
|
// addToRealtimeCommandQueue(CMD_SETMOTORACCEL+df.format(currentMachineAccel)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == ']')
|
// else if (key == ']')
|
||||||
{
|
// {
|
||||||
currentPenWidth = currentPenWidth+penIncrement;
|
// currentPenWidth = currentPenWidth+penIncrement;
|
||||||
currentPenWidth = Math.round(currentPenWidth*100.0)/100.0;
|
// currentPenWidth = Math.round(currentPenWidth*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_CHANGEPENWIDTH+df.format(currentPenWidth)+",END");
|
// addToRealtimeCommandQueue(CMD_CHANGEPENWIDTH+df.format(currentPenWidth)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == '[')
|
// else if (key == '[')
|
||||||
{
|
// {
|
||||||
currentPenWidth = currentPenWidth-penIncrement;
|
// currentPenWidth = currentPenWidth-penIncrement;
|
||||||
currentPenWidth = Math.round(currentPenWidth*100.0)/100.0;
|
// currentPenWidth = Math.round(currentPenWidth*100.0)/100.0;
|
||||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
// NumberFormat nf = NumberFormat.getNumberInstance(Locale.UK);
|
||||||
DecimalFormat df = (DecimalFormat)nf;
|
// DecimalFormat df = (DecimalFormat)nf;
|
||||||
df.applyPattern("###.##");
|
// df.applyPattern("###.##");
|
||||||
addToRealtimeCommandQueue(CMD_CHANGEPENWIDTH+df.format(currentPenWidth)+",END");
|
// addToRealtimeCommandQueue(CMD_CHANGEPENWIDTH+df.format(currentPenWidth)+",END");
|
||||||
}
|
// }
|
||||||
else if (key == '#' )
|
else if (key == '#' )
|
||||||
{
|
{
|
||||||
addToRealtimeCommandQueue(CMD_PENUP+"END");
|
addToRealtimeCommandQueue(CMD_PENUP+"END");
|
||||||
@ -1457,15 +1471,15 @@ void keyPressed()
|
|||||||
{
|
{
|
||||||
this.maxSegmentLength++;
|
this.maxSegmentLength++;
|
||||||
}
|
}
|
||||||
else if (key == ',')
|
// else if (key == ',')
|
||||||
{
|
// {
|
||||||
if (this.minimumVectorLineLength > 0)
|
// if (this.minimumVectorLineLength > 0)
|
||||||
this.minimumVectorLineLength--;
|
// this.minimumVectorLineLength--;
|
||||||
}
|
// }
|
||||||
else if (key == '.')
|
// else if (key == '.')
|
||||||
{
|
// {
|
||||||
this.minimumVectorLineLength++;
|
// this.minimumVectorLineLength++;
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
void mouseDragged()
|
void mouseDragged()
|
||||||
{
|
{
|
||||||
|
24
webcam.pde
24
webcam.pde
@ -1,15 +1,15 @@
|
|||||||
public PImage webcam_buildLiveImage()
|
public PImage webcam_buildLiveImage()
|
||||||
{
|
{
|
||||||
liveCamera.update();
|
liveCamera.update();
|
||||||
PImage pimg = createImage(640,480, RGB);
|
PImage pimg = createImage(640, 480, RGB);
|
||||||
pimg.loadPixels();
|
pimg.loadPixels();
|
||||||
pimg.pixels = liveCamera.image();
|
pimg.pixels = liveCamera.image();
|
||||||
// flip the image left to right
|
// flip the image left to right
|
||||||
if (flipWebcamImage)
|
if (flipWebcamImage)
|
||||||
{
|
{
|
||||||
|
|
||||||
List<int[]> list = new ArrayList<int[]>(480);
|
List<int[]> list = new ArrayList<int[]>(480);
|
||||||
|
|
||||||
for (int r=0; r<pimg.pixels.length; r+=640)
|
for (int r=0; r<pimg.pixels.length; r+=640)
|
||||||
{
|
{
|
||||||
int[] temp = new int[640];
|
int[] temp = new int[640];
|
||||||
@ -19,10 +19,10 @@ public PImage webcam_buildLiveImage()
|
|||||||
}
|
}
|
||||||
list.add(temp);
|
list.add(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
// reverse the list
|
// reverse the list
|
||||||
Collections.reverse(list);
|
Collections.reverse(list);
|
||||||
|
|
||||||
for (int r=0; r<list.size(); r++)
|
for (int r=0; r<list.size(); r++)
|
||||||
{
|
{
|
||||||
for (int c=0; c<640; c++)
|
for (int c=0; c<640; c++)
|
||||||
@ -132,7 +132,7 @@ Map<Integer, PImage> webcam_buildSeps(PImage img, Integer keyColour)
|
|||||||
Integer pixel = img.pixels[i];
|
Integer pixel = img.pixels[i];
|
||||||
seps.get(pixel).pixels[i] = keyColour;
|
seps.get(pixel).pixels[i] = keyColour;
|
||||||
}
|
}
|
||||||
|
|
||||||
return seps;
|
return seps;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,15 +153,21 @@ RShape webcam_convertDiewaldToRShape(List<Pixel> points)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void webcam_captureCurrentImage(PImage inImage)
|
||||||
|
{
|
||||||
|
processedCapturedImage = webcam_processImageForTrace(inImage);
|
||||||
|
colourSeparations = webcam_buildSeps(processedCapturedImage, sepKeyColour);
|
||||||
|
captureShape = webcam_traceImage(colourSeparations);
|
||||||
|
}
|
||||||
|
|
||||||
public void webcam_captureCurrentImage()
|
public void webcam_captureCurrentImage()
|
||||||
{
|
{
|
||||||
capturedImage = webcam_buildLiveImage();
|
capturedImage = webcam_buildLiveImage();
|
||||||
processedCapturedImage = webcam_processImageForTrace(liveImage);
|
webcam_captureCurrentImage(capturedImage);
|
||||||
colourSeparations = webcam_buildSeps(processedCapturedImage, sepKeyColour);
|
|
||||||
captureShape = webcam_traceImage(colourSeparations);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void stop() {
|
public void stop() {
|
||||||
liveCamera.stop();
|
liveCamera.stop();
|
||||||
super.stop();
|
super.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user