mirror of
https://github.com/euphy/polargraphcontroller
synced 2025-01-09 19:55:16 +01:00
Added rotate function to webcam. Primarily so folk with webcams on laptops can use it. Huzzah!
This commit is contained in:
parent
e3a6cea6cd
commit
aa92a55359
@ -374,24 +374,48 @@ class DisplayMachine extends Machine
|
|||||||
// draw actual image, maximum size
|
// draw actual image, maximum size
|
||||||
if (processedLiveImage != null)
|
if (processedLiveImage != null)
|
||||||
{
|
{
|
||||||
|
// origin - top left of the corner
|
||||||
float ox = getPanel(PANEL_NAME_WEBCAM).getOutline().getRight()+7;
|
float ox = getPanel(PANEL_NAME_WEBCAM).getOutline().getRight()+7;
|
||||||
float oy = getPanel(PANEL_NAME_GENERAL).getOutline().getTop();
|
float oy = getPanel(PANEL_NAME_GENERAL).getOutline().getTop();
|
||||||
|
|
||||||
// calculate height. 640 pixels stretched to
|
// calculate size to display at.
|
||||||
float aspectRatio = 480.0/640.0; // rotated, remember
|
float aspectRatio = (rotateWebcamImage) ? 480.0/640.0 : 640.0/480.0; // rotated, remember
|
||||||
float h = height - getPanel(PANEL_NAME_GENERAL).getOutline().getTop() -10;
|
float h = height - getPanel(PANEL_NAME_GENERAL).getOutline().getTop() -10;
|
||||||
float w = h * aspectRatio;
|
float w = h * (480.0/640.0);
|
||||||
|
println("height: " + h + ", width: " + w);
|
||||||
|
println("origin x: " + ox + ", y: " + oy);
|
||||||
|
|
||||||
stroke(255);
|
if (rotateWebcamImage)
|
||||||
|
{
|
||||||
|
float t = h;
|
||||||
|
h = w;
|
||||||
|
w = t;
|
||||||
|
}
|
||||||
|
|
||||||
|
//stroke(255);
|
||||||
rect(ox,oy,w,h);
|
rect(ox,oy,w,h);
|
||||||
|
|
||||||
tint(255, getImageTransparency());
|
tint(255, getImageTransparency());
|
||||||
translate(ox, oy+h);
|
if (rotateWebcamImage)
|
||||||
rotate(radians(270));
|
{
|
||||||
image(processedLiveImage, 0, 0, h, w);
|
translate(ox, oy);
|
||||||
image(liveImage, h-(h/4), w+10, h/4, w/4);
|
rotate(radians(270));
|
||||||
rotate(radians(-270));
|
image(processedLiveImage, -w, 0, w, h);
|
||||||
translate(-ox, -(oy+h));
|
image(liveImage, -w, (w-(w/4))+10, w/4, h/4);
|
||||||
|
// stroke(0,255,0);
|
||||||
|
// ellipse(0,0,80,40);
|
||||||
|
// stroke(0,0,255);
|
||||||
|
// ellipse(-w,0,80,40);
|
||||||
|
rotate(radians(-270));
|
||||||
|
translate(-ox, -oy);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
translate(ox, oy);
|
||||||
|
image(processedLiveImage, 0, 0, h, w);
|
||||||
|
image(liveImage, h-(h/4), w+10, h/4, w/4);
|
||||||
|
translate(-ox, -oy);
|
||||||
|
}
|
||||||
noTint();
|
noTint();
|
||||||
noFill();
|
noFill();
|
||||||
}
|
}
|
||||||
@ -419,8 +443,10 @@ class DisplayMachine extends Machine
|
|||||||
float aspectRatio = vec.getWidth()/vec.getHeight(); // rotated, remember
|
float aspectRatio = vec.getWidth()/vec.getHeight(); // rotated, remember
|
||||||
float h = height - getPanel(PANEL_NAME_GENERAL).getOutline().getTop() -10;
|
float h = height - getPanel(PANEL_NAME_GENERAL).getOutline().getTop() -10;
|
||||||
float w = h * aspectRatio;
|
float w = h * aspectRatio;
|
||||||
float scaler = h / vec.getHeight();
|
float scaler = h / vec.getWidth();
|
||||||
PVector position = new PVector(getPanel(PANEL_NAME_WEBCAM).getOutline().getRight()+7, getPanel(PANEL_NAME_GENERAL).getOutline().getTop() -10);
|
if (rotateWebcamImage)
|
||||||
|
scaler = h / vec.getHeight();
|
||||||
|
PVector position = new PVector(getPanel(PANEL_NAME_WEBCAM).getOutline().getRight()+7, getPanel(PANEL_NAME_GENERAL).getOutline().getTop());
|
||||||
|
|
||||||
noFill();
|
noFill();
|
||||||
RPoint[][] pointPaths = vec.getPointsInPaths();
|
RPoint[][] pointPaths = vec.getPointsInPaths();
|
||||||
|
@ -159,6 +159,18 @@ void button_mode_liveConfirmDraw()
|
|||||||
webcam_saveShape(captureShape);
|
webcam_saveShape(captureShape);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
void toggle_mode_showWebcamRawVideo(boolean flag)
|
||||||
|
{
|
||||||
|
drawingLiveVideo = flag;
|
||||||
|
}
|
||||||
|
void toggle_mode_flipWebcam(boolean flag)
|
||||||
|
{
|
||||||
|
flipWebcamImage = flag;
|
||||||
|
}
|
||||||
|
void toggle_mode_rotateWebcam(boolean flag)
|
||||||
|
{
|
||||||
|
rotateWebcamImage = flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void toggle_mode_inputBoxTopLeft(boolean flag)
|
void toggle_mode_inputBoxTopLeft(boolean flag)
|
||||||
|
@ -274,7 +274,7 @@ Map<String, Controller> buildAllControls()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
initialiseMiniToggleValues(map);
|
initialiseToggleValues(map);
|
||||||
initialiseNumberboxValues(map);
|
initialiseNumberboxValues(map);
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
@ -506,7 +506,7 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Map<String, Controller> initialiseMiniToggleValues(Map<String, Controller> map)
|
Map<String, Controller> initialiseToggleValues(Map<String, Controller> map)
|
||||||
{
|
{
|
||||||
for (String key : map.keySet())
|
for (String key : map.keySet())
|
||||||
{
|
{
|
||||||
@ -515,26 +515,42 @@ Map<String, Controller> initialiseMiniToggleValues(Map<String, Controller> map)
|
|||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((displayingDensityPreview) ? 1 : 0);
|
t.setValue((displayingDensityPreview) ? 1 : 0);
|
||||||
}
|
}
|
||||||
if (MODE_SHOW_QUEUE_PREVIEW.equals(key))
|
else if (MODE_SHOW_QUEUE_PREVIEW.equals(key))
|
||||||
{
|
{
|
||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((displayingQueuePreview) ? 1 : 0);
|
t.setValue((displayingQueuePreview) ? 1 : 0);
|
||||||
}
|
}
|
||||||
if (MODE_SHOW_IMAGE.equals(key))
|
else if (MODE_SHOW_IMAGE.equals(key))
|
||||||
{
|
{
|
||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((displayingImage) ? 1 : 0);
|
t.setValue((displayingImage) ? 1 : 0);
|
||||||
}
|
}
|
||||||
if (MODE_SHOW_VECTOR.equals(key))
|
else if (MODE_SHOW_VECTOR.equals(key))
|
||||||
{
|
{
|
||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((displayingVector) ? 1 : 0);
|
t.setValue((displayingVector) ? 1 : 0);
|
||||||
}
|
}
|
||||||
if (MODE_SHOW_GUIDES.equals(key))
|
else if (MODE_SHOW_GUIDES.equals(key))
|
||||||
{
|
{
|
||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((displayingGuides) ? 1 : 0);
|
t.setValue((displayingGuides) ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
else if (MODE_SHOW_WEBCAM_RAW_VIDEO.equals(key))
|
||||||
|
{
|
||||||
|
Toggle t = (Toggle) map.get(key);
|
||||||
|
t.setValue((drawingLiveVideo) ? 1 : 0);
|
||||||
|
}
|
||||||
|
else if (MODE_FLIP_WEBCAM_INPUT.equals(key))
|
||||||
|
{
|
||||||
|
Toggle t = (Toggle) map.get(key);
|
||||||
|
t.setValue((flipWebcamImage) ? 1 : 0);
|
||||||
|
}
|
||||||
|
else if (MODE_ROTATE_WEBCAM_INPUT.equals(key))
|
||||||
|
{
|
||||||
|
Toggle t = (Toggle) map.get(key);
|
||||||
|
t.setValue((rotateWebcamImage) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
@ -670,7 +686,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_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);
|
||||||
@ -712,9 +728,13 @@ List<String> getControlNamesForWebcamPanel()
|
|||||||
controlNames.add(MODE_LIVE_POSTERISE_VALUE);
|
controlNames.add(MODE_LIVE_POSTERISE_VALUE);
|
||||||
controlNames.add(MODE_LIVE_CAPTURE_FROM_LIVE);
|
controlNames.add(MODE_LIVE_CAPTURE_FROM_LIVE);
|
||||||
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);
|
// controlNames.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
||||||
|
|
||||||
|
controlNames.add(MODE_SHOW_WEBCAM_RAW_VIDEO);
|
||||||
|
controlNames.add(MODE_FLIP_WEBCAM_INPUT);
|
||||||
|
controlNames.add(MODE_ROTATE_WEBCAM_INPUT);
|
||||||
return controlNames;
|
return controlNames;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -923,6 +943,10 @@ Map<String, String> buildControlLabels()
|
|||||||
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");
|
result.put(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF, "Path length cutoff");
|
||||||
|
result.put(MODE_SHOW_WEBCAM_RAW_VIDEO, "Show video");
|
||||||
|
result.put(MODE_FLIP_WEBCAM_INPUT, "Flip video");
|
||||||
|
result.put(MODE_ROTATE_WEBCAM_INPUT, "Rotate webcam");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -1057,6 +1081,11 @@ Set<String> buildControlNames()
|
|||||||
result.add(MODE_LIVE_ADD_CAPTION);
|
result.add(MODE_LIVE_ADD_CAPTION);
|
||||||
result.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
result.add(MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
||||||
|
|
||||||
|
result.add(MODE_SHOW_WEBCAM_RAW_VIDEO);
|
||||||
|
result.add(MODE_FLIP_WEBCAM_INPUT);
|
||||||
|
result.add(MODE_ROTATE_WEBCAM_INPUT);
|
||||||
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,8 +50,8 @@ import controlP5.*;
|
|||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
|
|
||||||
int majorVersionNo = 1;
|
int majorVersionNo = 1;
|
||||||
int minorVersionNo = 4;
|
int minorVersionNo = 5;
|
||||||
int buildNo = 2;
|
int buildNo = 0;
|
||||||
|
|
||||||
String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo;
|
String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo;
|
||||||
ControlP5 cp5;
|
ControlP5 cp5;
|
||||||
@ -316,6 +316,9 @@ 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";
|
static final String MODE_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF = "numberbox_mode_vectorPathLengthHighPassCutoff";
|
||||||
|
static final String MODE_SHOW_WEBCAM_RAW_VIDEO = "toggle_mode_showWebcamRawVideo";
|
||||||
|
static final String MODE_FLIP_WEBCAM_INPUT = "toggle_mode_flipWebcam";
|
||||||
|
static final String MODE_ROTATE_WEBCAM_INPUT = "toggle_mode_rotateWebcam";
|
||||||
|
|
||||||
|
|
||||||
PVector statusTextPosition = new PVector(300.0, 12.0);
|
PVector statusTextPosition = new PVector(300.0, 12.0);
|
||||||
@ -455,9 +458,10 @@ public static Console console;
|
|||||||
public boolean useWindowedConsole = false;
|
public boolean useWindowedConsole = false;
|
||||||
|
|
||||||
static boolean webcamEnabled = false;
|
static boolean webcamEnabled = false;
|
||||||
static boolean drawingLiveVideo = false;
|
static boolean drawingLiveVideo = true;
|
||||||
static boolean drawingWebcamShape = true;
|
static boolean drawingWebcamShape = true;
|
||||||
static boolean flipWebcamImage = true;
|
static boolean flipWebcamImage = true;
|
||||||
|
static boolean rotateWebcamImage = true;
|
||||||
static boolean confirmedDraw = false;
|
static boolean confirmedDraw = false;
|
||||||
|
|
||||||
static PImage liveImage = null;
|
static PImage liveImage = null;
|
||||||
|
11
webcam.pde
11
webcam.pde
@ -107,10 +107,13 @@ public RShape webcam_traceImage(Map<Integer, PImage> seps)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// rotate image
|
// rotate image
|
||||||
allShapes.rotate(radians(-90));
|
if (rotateWebcamImage)
|
||||||
// transform it so that top left is at 0,0.
|
{
|
||||||
RPoint topLeft = allShapes.getTopLeft();
|
allShapes.rotate(radians(-90));
|
||||||
allShapes.translate(-topLeft.x, -topLeft.y);
|
// transform it so that top left is at 0,0.
|
||||||
|
RPoint topLeft = allShapes.getTopLeft();
|
||||||
|
allShapes.translate(-topLeft.x, -topLeft.y);
|
||||||
|
}
|
||||||
return allShapes;
|
return allShapes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user