mirror of
https://github.com/euphy/polargraphcontroller
synced 2025-04-06 12:33:19 +02:00
Compare commits
45 Commits
2015-09-13
...
master
Author | SHA1 | Date | |
---|---|---|---|
|
9c224d039b | ||
|
f8f1f78ce3 | ||
|
dba2788d1f | ||
|
417c18fec7 | ||
|
995db8a8a5 | ||
|
8e263852ee | ||
|
6665883c9b | ||
|
75fe43ddcb | ||
|
aadca73b17 | ||
|
5e7e010a79 | ||
|
f2b1df7405 | ||
|
9307c4e61e | ||
|
f32f22abae | ||
|
c545545f19 | ||
|
0c687ed234 | ||
|
936d918402 | ||
|
d74881f2de | ||
|
7da0e7e378 | ||
|
a7f37d8553 | ||
|
6b49794cc1 | ||
|
eddaf3661a | ||
|
3bf418fa93 | ||
|
3909dee0a7 | ||
|
bbcae8b079 | ||
|
d584624791 | ||
|
bd1d19018e | ||
|
71713b5246 | ||
|
6f6755f231 | ||
|
2fbe578954 | ||
|
c221b9456c | ||
|
69ab977f90 | ||
|
cd61a66253 | ||
|
81b45259e3 | ||
|
dba8bb5b2a | ||
|
74636289e5 | ||
|
1179fd7471 | ||
|
a1bdca895f | ||
|
70eaae51bd | ||
|
e84d027d43 | ||
|
4b3f7c5edd | ||
|
3b5648085c | ||
|
1b0455a886 | ||
|
f48d625b49 | ||
|
cbd018fc3d | ||
|
87e11f6b93 |
@ -316,6 +316,10 @@ class DisplayMachine extends Machine
|
|||||||
{
|
{
|
||||||
drawExtractedPixelCentres();
|
drawExtractedPixelCentres();
|
||||||
}
|
}
|
||||||
|
if (displayingGridSpots)
|
||||||
|
{
|
||||||
|
drawGridIntersections();
|
||||||
|
}
|
||||||
if (displayingDensityPreview)
|
if (displayingDensityPreview)
|
||||||
{
|
{
|
||||||
drawExtractedPixelDensities();
|
drawExtractedPixelDensities();
|
||||||
@ -532,10 +536,13 @@ class DisplayMachine extends Machine
|
|||||||
beginShape();
|
beginShape();
|
||||||
inShape = true;
|
inShape = true;
|
||||||
}
|
}
|
||||||
|
// PVector nativeCoords = asNativeCoords(inSteps(p));
|
||||||
|
// println(j + "! Adding point " + nativeCoords);
|
||||||
|
|
||||||
p = scaleToScreen(p);
|
p = scaleToScreen(p);
|
||||||
stroke(strokeColour);
|
stroke(strokeColour);
|
||||||
vertex(p.x, p.y);
|
vertex(p.x, p.y);
|
||||||
//ellipse(p.x, p.y, 3, 3);
|
// ellipse(p.x, p.y, 2, 2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -660,10 +667,18 @@ class DisplayMachine extends Machine
|
|||||||
*/
|
*/
|
||||||
public void drawRows()
|
public void drawRows()
|
||||||
{
|
{
|
||||||
PVector mVect = getMouseVector();
|
float rowThickness = inMM(getGridSize()) * getScaling();
|
||||||
|
rowThickness = (rowThickness < 1.0) ? 1.0 : rowThickness;
|
||||||
|
strokeWeight(rowThickness);
|
||||||
|
stroke(150, 200, 255, 50);
|
||||||
|
strokeCap(SQUARE);
|
||||||
|
drawRow(getMouseVector(), true, true);
|
||||||
|
noStroke();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void drawRow(PVector mouse, boolean left, boolean right) {
|
||||||
// scale it to find out the coordinates on the machine that the mouse is pointing at.
|
// scale it to find out the coordinates on the machine that the mouse is pointing at.
|
||||||
mVect = scaleToDisplayMachine(mVect);
|
PVector mVect = scaleToDisplayMachine(mouse);
|
||||||
// convert it to the native coordinates system
|
// convert it to the native coordinates system
|
||||||
mVect = convertToNative(mVect);
|
mVect = convertToNative(mVect);
|
||||||
// snap it to the grid
|
// snap it to the grid
|
||||||
@ -674,17 +689,15 @@ class DisplayMachine extends Machine
|
|||||||
// and finally, because scaleToScreen also allows for the machine position (offset), subtract it.
|
// and finally, because scaleToScreen also allows for the machine position (offset), subtract it.
|
||||||
mVect.sub(getOffset());
|
mVect.sub(getOffset());
|
||||||
|
|
||||||
float rowThickness = inMM(getGridSize()) * getScaling();
|
|
||||||
rowThickness = (rowThickness < 1.0) ? 1.0 : rowThickness;
|
|
||||||
strokeWeight(rowThickness);
|
|
||||||
stroke(150, 200, 255, 50);
|
|
||||||
strokeCap(SQUARE);
|
|
||||||
|
|
||||||
float dia = mVect.x*2;
|
float dia = mVect.x*2;
|
||||||
arc(getOutline().getLeft(), getOutline().getTop(), dia, dia, 0, 1.57079633);
|
if (left) {
|
||||||
|
arc(getOutline().getLeft(), getOutline().getTop(), dia, dia, 0, 1.57079633);
|
||||||
|
}
|
||||||
|
|
||||||
dia = mVect.y*2;
|
dia = mVect.y*2;
|
||||||
arc(getOutline().getRight(), getOutline().getTop(), dia, dia, 1.57079633, 3.14159266);
|
if (right) {
|
||||||
|
arc(getOutline().getRight(), getOutline().getTop(), dia, dia, 1.57079633, 3.14159266);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -701,6 +714,28 @@ class DisplayMachine extends Machine
|
|||||||
line(scaledPos.x-1, scaledPos.y+1, scaledPos.x+1, scaledPos.y-1);
|
line(scaledPos.x-1, scaledPos.y+1, scaledPos.x+1, scaledPos.y-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void drawGridIntersections()
|
||||||
|
{
|
||||||
|
// println("oh");
|
||||||
|
}
|
||||||
|
|
||||||
|
int pixel_maxDensity(float penSize, float rowSizeInMM)
|
||||||
|
{
|
||||||
|
float numberOfSegments = rowSizeInMM / penSize;
|
||||||
|
|
||||||
|
int maxDens = 1;
|
||||||
|
|
||||||
|
if (numberOfSegments >= 2.0) {
|
||||||
|
maxDens = int(numberOfSegments);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (maxDens <= 1) {
|
||||||
|
maxDens = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return maxDens;
|
||||||
|
}
|
||||||
|
|
||||||
void drawExtractedPixelDensities()
|
void drawExtractedPixelDensities()
|
||||||
{
|
{
|
||||||
@ -709,17 +744,38 @@ class DisplayMachine extends Machine
|
|||||||
pixelSize = (pixelSize < 1.0) ? 1.0 : pixelSize;
|
pixelSize = (pixelSize < 1.0) ? 1.0 : pixelSize;
|
||||||
|
|
||||||
pixelSize = pixelSize * getPixelScalingOverGridSize();
|
pixelSize = pixelSize * getPixelScalingOverGridSize();
|
||||||
|
|
||||||
|
float rowSizeInMM = inMM(getGridSize()) * getPixelScalingOverGridSize();
|
||||||
|
|
||||||
|
int posterizeLevels = 255;
|
||||||
|
|
||||||
|
if (previewPixelDensityRange) {
|
||||||
|
posterizeLevels = pixel_maxDensity(currentPenWidth, rowSizeInMM);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
posterizeLevels = densityPreviewPosterize;
|
||||||
|
}
|
||||||
|
|
||||||
if (getExtractedPixels() != null)
|
if (getExtractedPixels() != null)
|
||||||
{
|
{
|
||||||
for (PVector cartesianPos : getExtractedPixels())
|
for (PVector cartesianPos : getExtractedPixels())
|
||||||
{
|
{
|
||||||
if ((cartesianPos.z <= pixelExtractBrightThreshold) && (cartesianPos.z >= pixelExtractDarkThreshold))
|
if ((cartesianPos.z <= pixelExtractBrightThreshold) &&
|
||||||
|
(cartesianPos.z >= pixelExtractDarkThreshold))
|
||||||
{
|
{
|
||||||
// scale em, danno.
|
// scale em, danno.
|
||||||
PVector scaledPos = scaleToScreen(cartesianPos);
|
PVector scaledPos = scaleToScreen(cartesianPos);
|
||||||
noStroke();
|
noStroke();
|
||||||
fill(cartesianPos.z);
|
if ((scaledPos.x <= 0) || (scaledPos.x > windowWidth) ||
|
||||||
|
(scaledPos.y <= 0) || (scaledPos.y > windowHeight)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Posterize the density value
|
||||||
|
int reduced = int(map(cartesianPos.z, 1, 255, 1, posterizeLevels)+0.5);
|
||||||
|
int brightness = int(map(reduced, 1, posterizeLevels, 1, 255));
|
||||||
|
|
||||||
|
fill(brightness);
|
||||||
switch (getDensityPreviewStyle())
|
switch (getDensityPreviewStyle())
|
||||||
{
|
{
|
||||||
case DENSITY_PREVIEW_ROUND:
|
case DENSITY_PREVIEW_ROUND:
|
||||||
@ -727,20 +783,20 @@ class DisplayMachine extends Machine
|
|||||||
break;
|
break;
|
||||||
case DENSITY_PREVIEW_ROUND_SIZE:
|
case DENSITY_PREVIEW_ROUND_SIZE:
|
||||||
fill(0);
|
fill(0);
|
||||||
previewRoundPixel(scaledPos, map(cartesianPos.z, 1, 255, pixelSize, 1));
|
previewRoundPixel(scaledPos, map(brightness, 1, posterizeLevels, pixelSize, 1));
|
||||||
break;
|
break;
|
||||||
case DENSITY_PREVIEW_DIAMOND:
|
case DENSITY_PREVIEW_DIAMOND:
|
||||||
previewDiamondPixel(scaledPos, pixelSize, pixelSize, cartesianPos.z);
|
previewDiamondPixel(scaledPos, pixelSize, pixelSize, brightness);
|
||||||
break;
|
break;
|
||||||
case DENSITY_PREVIEW_NATIVE:
|
case DENSITY_PREVIEW_NATIVE:
|
||||||
previewNativePixel(scaledPos, pixelSize, cartesianPos.z);
|
previewNativePixel(scaledPos, pixelSize, brightness);
|
||||||
break;
|
break;
|
||||||
case DENSITY_PREVIEW_NATIVE_SIZE:
|
case DENSITY_PREVIEW_NATIVE_SIZE:
|
||||||
previewNativePixel(scaledPos, map(cartesianPos.z, 1, 255, pixelSize, 1), 50);
|
previewNativePixel(scaledPos, map(brightness, 1, posterizeLevels, pixelSize, 1), 50);
|
||||||
break;
|
break;
|
||||||
case DENSITY_PREVIEW_NATIVE_ARC:
|
case DENSITY_PREVIEW_NATIVE_ARC:
|
||||||
previewRoundPixel(scaledPos, pixelSize*0.8);
|
previewRoundPixel(scaledPos, pixelSize*0.8);
|
||||||
previewNativeArcPixel(scaledPos, pixelSize, cartesianPos.z);
|
previewNativeArcPixel(scaledPos, pixelSize, brightness);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
previewRoundPixel(scaledPos, pixelSize);
|
previewRoundPixel(scaledPos, pixelSize);
|
||||||
@ -805,25 +861,30 @@ class DisplayMachine extends Machine
|
|||||||
// plot out the vertexes
|
// plot out the vertexes
|
||||||
noFill();
|
noFill();
|
||||||
stroke(0,0,0, 255-brightness);
|
stroke(0,0,0, 255-brightness);
|
||||||
|
try {
|
||||||
|
|
||||||
float i1Angle1 = atan2(int1.get(0).y-getOutline().getTop(), int1.get(0).x-getOutline().getLeft());
|
float i1Angle1 = atan2(int1.get(0).y-getOutline().getTop(), int1.get(0).x-getOutline().getLeft());
|
||||||
float i1Angle2 = atan2(int1.get(1).y-getOutline().getTop(), int1.get(1).x-getOutline().getLeft());
|
float i1Angle2 = atan2(int1.get(1).y-getOutline().getTop(), int1.get(1).x-getOutline().getLeft());
|
||||||
arc(getOutline().getLeft(), getOutline().getTop(), (distFromPointA-half)*2, (distFromPointA-half)*2, i1Angle1, i1Angle2);
|
arc(getOutline().getLeft(), getOutline().getTop(), (distFromPointA-half)*2, (distFromPointA-half)*2, i1Angle1, i1Angle2);
|
||||||
|
|
||||||
i1Angle1 = atan2(int2.get(0).y-getOutline().getTop(), int2.get(0).x-getOutline().getLeft());
|
i1Angle1 = atan2(int2.get(0).y-getOutline().getTop(), int2.get(0).x-getOutline().getLeft());
|
||||||
i1Angle2 = atan2(int2.get(1).y-getOutline().getTop(), int2.get(1).x-getOutline().getLeft());
|
i1Angle2 = atan2(int2.get(1).y-getOutline().getTop(), int2.get(1).x-getOutline().getLeft());
|
||||||
arc(getOutline().getLeft(), getOutline().getTop(), (distFromPointA+half)*2, (distFromPointA+half)*2, i1Angle1, i1Angle2);
|
arc(getOutline().getLeft(), getOutline().getTop(), (distFromPointA+half)*2, (distFromPointA+half)*2, i1Angle1, i1Angle2);
|
||||||
|
|
||||||
i1Angle1 = atan2( int1.get(0).y-getOutline().getTop(), int1.get(0).x-getOutline().getRight());
|
i1Angle1 = atan2( int1.get(0).y-getOutline().getTop(), int1.get(0).x-getOutline().getRight());
|
||||||
i1Angle2 = atan2( int2.get(0).y-getOutline().getTop(), int2.get(0).x-getOutline().getRight());
|
i1Angle2 = atan2( int2.get(0).y-getOutline().getTop(), int2.get(0).x-getOutline().getRight());
|
||||||
arc(getOutline().getRight(), getOutline().getTop(), (distFromPointB-half)*2, (distFromPointB-half)*2, i1Angle2, i1Angle1);
|
arc(getOutline().getRight(), getOutline().getTop(), (distFromPointB-half)*2, (distFromPointB-half)*2, i1Angle2, i1Angle1);
|
||||||
|
|
||||||
i1Angle1 = atan2( int1.get(1).y-getOutline().getTop(), int1.get(1).x-getOutline().getRight());
|
i1Angle1 = atan2( int1.get(1).y-getOutline().getTop(), int1.get(1).x-getOutline().getRight());
|
||||||
i1Angle2 = atan2( int2.get(1).y-getOutline().getTop(), int2.get(1).x-getOutline().getRight());
|
i1Angle2 = atan2( int2.get(1).y-getOutline().getTop(), int2.get(1).x-getOutline().getRight());
|
||||||
arc(getOutline().getRight(), getOutline().getTop(), (distFromPointB+half)*2, (distFromPointB+half)*2, i1Angle2, i1Angle1);
|
arc(getOutline().getRight(), getOutline().getTop(), (distFromPointB+half)*2, (distFromPointB+half)*2, i1Angle2, i1Angle1);
|
||||||
|
}
|
||||||
|
catch (IndexOutOfBoundsException ioobe) {
|
||||||
endShape();
|
println(ioobe);
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
endShape();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ ControlFrameSimple addDrawPixelsControlFrame(String theName, int theWidth, int t
|
|||||||
p.dispose();
|
p.dispose();
|
||||||
f.dispose();
|
f.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
f.setResizable( true );
|
f.setResizable( true );
|
||||||
f.setVisible( true );
|
f.setVisible( true );
|
||||||
|
439
FileLoading.pde
Normal file
439
FileLoading.pde
Normal file
@ -0,0 +1,439 @@
|
|||||||
|
/**
|
||||||
|
Polargraph controller
|
||||||
|
Copyright Sandy Noble 2018.
|
||||||
|
|
||||||
|
This file is part of Polargraph Controller.
|
||||||
|
|
||||||
|
Polargraph Controller is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
Polargraph Controller is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with Polargraph Controller. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Requires the excellent ControlP5 GUI library available from http://www.sojamo.de/libraries/controlP5/.
|
||||||
|
Requires the excellent Geomerative library available from http://www.ricardmarxer.com/geomerative/.
|
||||||
|
|
||||||
|
This is an application for controlling a polargraph machine, communicating using ASCII command language over a serial link.
|
||||||
|
|
||||||
|
sandy.noble@gmail.com
|
||||||
|
http://www.polargraph.co.uk/
|
||||||
|
https://github.com/euphy/polargraphcontroller
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void loadImageWithFileChooser()
|
||||||
|
{
|
||||||
|
SwingUtilities.invokeLater(new Runnable()
|
||||||
|
{
|
||||||
|
public void run() {
|
||||||
|
JFileChooser fc = new JFileChooser();
|
||||||
|
if (lastImageDirectory != null) fc.setCurrentDirectory(lastImageDirectory);
|
||||||
|
fc.setFileFilter(new ImageFileFilter());
|
||||||
|
fc.setDialogTitle("Choose an image file...");
|
||||||
|
|
||||||
|
int returned = fc.showOpenDialog(frame);
|
||||||
|
|
||||||
|
lastImageDirectory = fc.getCurrentDirectory();
|
||||||
|
|
||||||
|
if (returned == JFileChooser.APPROVE_OPTION)
|
||||||
|
{
|
||||||
|
File file = fc.getSelectedFile();
|
||||||
|
// see if it's an image
|
||||||
|
PImage img = loadImage(file.getPath());
|
||||||
|
if (img != null)
|
||||||
|
{
|
||||||
|
img = null;
|
||||||
|
getDisplayMachine().loadNewImageFromFilename(file.getPath());
|
||||||
|
if (getDisplayMachine().pixelsCanBeExtracted() && isBoxSpecified())
|
||||||
|
{
|
||||||
|
getDisplayMachine().extractPixelsFromArea(getBoxVector1(), getBoxVectorSize(), getGridSize(), sampleArea);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class ImageFileFilter extends javax.swing.filechooser.FileFilter
|
||||||
|
{
|
||||||
|
public boolean accept(File file) {
|
||||||
|
String filename = file.getName();
|
||||||
|
filename.toLowerCase();
|
||||||
|
if (file.isDirectory() || filename.endsWith(".png") || filename.endsWith(".jpg") || filename.endsWith(".jpeg"))
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
public String getDescription() {
|
||||||
|
return "Image files (PNG or JPG)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void loadVectorWithFileChooser()
|
||||||
|
{
|
||||||
|
SwingUtilities.invokeLater(new Runnable()
|
||||||
|
{
|
||||||
|
public void run() {
|
||||||
|
JFileChooser fc = new JFileChooser();
|
||||||
|
if (lastImageDirectory != null)
|
||||||
|
{
|
||||||
|
fc.setCurrentDirectory(lastImageDirectory);
|
||||||
|
}
|
||||||
|
|
||||||
|
fc.setFileFilter(new VectorFileFilter());
|
||||||
|
fc.setDialogTitle("Choose a vector file...");
|
||||||
|
int returned = fc.showOpenDialog(frame);
|
||||||
|
lastImageDirectory = fc.getCurrentDirectory();
|
||||||
|
|
||||||
|
if (returned == JFileChooser.APPROVE_OPTION)
|
||||||
|
{
|
||||||
|
File file = fc.getSelectedFile();
|
||||||
|
if (file.exists())
|
||||||
|
{
|
||||||
|
RShape shape = loadShapeFromFile(file.getPath());
|
||||||
|
if (shape != null)
|
||||||
|
{
|
||||||
|
setVectorFilename(file.getPath());
|
||||||
|
setVectorShape(shape);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
println("File not found (" + file.getPath() + ")");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
class VectorFileFilter extends javax.swing.filechooser.FileFilter
|
||||||
|
{
|
||||||
|
public boolean accept(File file) {
|
||||||
|
String filename = file.getName();
|
||||||
|
filename.toLowerCase();
|
||||||
|
if (file.isDirectory() || filename.endsWith(".svg") || isGCodeExtension(filename))
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
public String getDescription() {
|
||||||
|
return "Vector graphic files (SVG, GCode)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void loadNewPropertiesFilenameWithFileChooser()
|
||||||
|
{
|
||||||
|
SwingUtilities.invokeLater(new Runnable()
|
||||||
|
{
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
JFileChooser fc = new JFileChooser();
|
||||||
|
if (lastPropertiesDirectory != null) fc.setCurrentDirectory(lastPropertiesDirectory);
|
||||||
|
fc.setFileFilter(new PropertiesFileFilter());
|
||||||
|
|
||||||
|
fc.setDialogTitle("Choose a config file...");
|
||||||
|
|
||||||
|
int returned = fc.showOpenDialog(frame);
|
||||||
|
|
||||||
|
lastPropertiesDirectory = fc.getCurrentDirectory();
|
||||||
|
|
||||||
|
if (returned == JFileChooser.APPROVE_OPTION)
|
||||||
|
{
|
||||||
|
File file = fc.getSelectedFile();
|
||||||
|
if (file.exists())
|
||||||
|
{
|
||||||
|
println("New properties file exists.");
|
||||||
|
newPropertiesFilename = file.toString();
|
||||||
|
println("new propertiesFilename: "+ newPropertiesFilename);
|
||||||
|
propertiesFilename = newPropertiesFilename;
|
||||||
|
// clear old properties.
|
||||||
|
props = null;
|
||||||
|
loadFromPropertiesFile();
|
||||||
|
|
||||||
|
// set values of number spinners etc
|
||||||
|
updateNumberboxValues();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
class PropertiesFileFilter extends javax.swing.filechooser.FileFilter
|
||||||
|
{
|
||||||
|
public boolean accept(File file) {
|
||||||
|
String filename = file.getName();
|
||||||
|
filename.toLowerCase();
|
||||||
|
if (file.isDirectory() || filename.endsWith(".properties.txt"))
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
public String getDescription() {
|
||||||
|
return "Properties files (*.properties.txt)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void saveNewPropertiesFileWithFileChooser()
|
||||||
|
{
|
||||||
|
SwingUtilities.invokeLater(new Runnable()
|
||||||
|
{
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
JFileChooser fc = new JFileChooser();
|
||||||
|
if (lastPropertiesDirectory != null) fc.setCurrentDirectory(lastPropertiesDirectory);
|
||||||
|
fc.setFileFilter(new PropertiesFileFilter());
|
||||||
|
|
||||||
|
fc.setDialogTitle("Enter a config file name...");
|
||||||
|
|
||||||
|
int returned = fc.showSaveDialog(frame);
|
||||||
|
if (returned == JFileChooser.APPROVE_OPTION)
|
||||||
|
{
|
||||||
|
File file = fc.getSelectedFile();
|
||||||
|
newPropertiesFilename = file.toString();
|
||||||
|
newPropertiesFilename.toLowerCase();
|
||||||
|
if (!newPropertiesFilename.endsWith(".properties.txt"))
|
||||||
|
newPropertiesFilename+=".properties.txt";
|
||||||
|
|
||||||
|
println("new propertiesFilename: "+ newPropertiesFilename);
|
||||||
|
propertiesFilename = newPropertiesFilename;
|
||||||
|
savePropertiesFile();
|
||||||
|
// clear old properties.
|
||||||
|
props = null;
|
||||||
|
loadFromPropertiesFile();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
RShape loadShapeFromFile(String filename) {
|
||||||
|
RShape sh = null;
|
||||||
|
if (filename.toLowerCase().endsWith(".svg")) {
|
||||||
|
sh = RG.loadShape(filename);
|
||||||
|
}
|
||||||
|
else if (isGCodeExtension(filename)) {
|
||||||
|
sh = loadShapeFromGCodeFile(filename);
|
||||||
|
}
|
||||||
|
return sh;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
boolean isGCodeExtension(String filename) {
|
||||||
|
return (filename.toLowerCase().endsWith(".gcode") || filename.toLowerCase().endsWith(".g") || filename.toLowerCase().endsWith(".ngc") || filename.toLowerCase().endsWith(".txt"));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int countLines(String filename) throws IOException {
|
||||||
|
InputStream is = new BufferedInputStream(new FileInputStream(filename));
|
||||||
|
try {
|
||||||
|
byte[] c = new byte[1024];
|
||||||
|
int count = 0;
|
||||||
|
int readChars = 0;
|
||||||
|
boolean empty = true;
|
||||||
|
while ((readChars = is.read(c)) != -1) {
|
||||||
|
empty = false;
|
||||||
|
for (int i = 0; i < readChars; ++i) {
|
||||||
|
if (c[i] == '\n') {
|
||||||
|
++count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (count == 0 && !empty) ? 1 : count+1;
|
||||||
|
} finally {
|
||||||
|
is.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RShape loadShapeFromGCodeFile(String filename) {
|
||||||
|
noLoop();
|
||||||
|
RShape parent = null;
|
||||||
|
BufferedReader reader = null;
|
||||||
|
long totalPoints = 0;
|
||||||
|
long time = millis();
|
||||||
|
long countLines = 0;
|
||||||
|
|
||||||
|
try {
|
||||||
|
countLines = countLines(filename);
|
||||||
|
println("" + countLines + " lines found.");
|
||||||
|
if (countLines < 1) {
|
||||||
|
throw new IOException("No lines found in GCode file.");
|
||||||
|
}
|
||||||
|
reader = createReader(filename);
|
||||||
|
parent = new RShape();
|
||||||
|
String line;
|
||||||
|
boolean drawLine = false;
|
||||||
|
int gCodeZAxisChanges = 0;
|
||||||
|
|
||||||
|
long lineNo = 0;
|
||||||
|
float lastPercent = 0.0f;
|
||||||
|
boolean reportStatus = true;
|
||||||
|
while ((line = reader.readLine ()) != null) {
|
||||||
|
lineNo++;
|
||||||
|
// println("Line: " + line);
|
||||||
|
|
||||||
|
if (reportStatus) {
|
||||||
|
float percent = ((float)lineNo / (float)countLines) * 100.0;
|
||||||
|
println("----" + percent + "% of the way through.");
|
||||||
|
lastPercent = percent;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (line.toUpperCase().startsWith("G")) {
|
||||||
|
if (reportStatus) {
|
||||||
|
println(new StringBuilder().append(lineNo).append(" of ").append(countLines).append(": ").append(line).append(". Points: ").append(totalPoints).toString());
|
||||||
|
long free = Runtime.getRuntime().freeMemory();
|
||||||
|
long maximum = Runtime.getRuntime().maxMemory();
|
||||||
|
println(new StringBuilder().append("Free: ").append(free).append(", max: ").append(maximum).toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Float> ins = null;
|
||||||
|
try {
|
||||||
|
ins = unpackGCodeInstruction(line);
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
println(e.toString());
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// println("Ins: " + ins);
|
||||||
|
Integer code = Math.round(ins.get("G"));
|
||||||
|
|
||||||
|
Float z = ins.get("Z");
|
||||||
|
if (z != null) {
|
||||||
|
gCodeZAxisChanges++;
|
||||||
|
if (gCodeZAxisChanges == 2) {
|
||||||
|
println("Assume second z axis change is to drop the pen to start drawing " + z);
|
||||||
|
gcodeZAxisDrawingHeight = z;
|
||||||
|
drawLine = true;
|
||||||
|
}
|
||||||
|
else if (gCodeZAxisChanges > 2) {
|
||||||
|
drawLine = isGCodeZAxisForDrawing(z);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
println("Assume first z axis change is to RAISE the pen " + z);
|
||||||
|
drawLine = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { // if there is no Z axis, assume it's always on
|
||||||
|
// drawLine = true; // this isn't always safe!
|
||||||
|
}
|
||||||
|
|
||||||
|
Float x = ins.get("X");
|
||||||
|
Float y = ins.get("Y");
|
||||||
|
if (x != null && y == null) {
|
||||||
|
// move x axis only, use y of last
|
||||||
|
RPoint[][] points = parent.getPointsInPaths();
|
||||||
|
RPoint rp = points[points.length-1][points[points.length-1].length-1];
|
||||||
|
y = rp.y;
|
||||||
|
}
|
||||||
|
else if (x == null && y != null) {
|
||||||
|
// move y axis only, use x of last
|
||||||
|
RPoint[][] points = parent.getPointsInPaths();
|
||||||
|
RPoint rp = points[points.length-1][points[points.length-1].length-1];
|
||||||
|
x = rp.x;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (x != null && y != null) {
|
||||||
|
// move both x and y axis
|
||||||
|
if (drawLine) {
|
||||||
|
parent.addLineTo(x, y);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
parent.addMoveTo(x, y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((millis() - time) > 500) {
|
||||||
|
time = millis();
|
||||||
|
reportStatus = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
reportStatus = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (lineNo == (countLines-1)) {
|
||||||
|
reportStatus = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
println("IOExecption reading lines from the gcode file " + filename);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
try {
|
||||||
|
reader.close();
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
println("IOException closing the gcode file " + filename);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RPoint[][] points = parent.getPointsInPaths();
|
||||||
|
totalPoints = 0;
|
||||||
|
if (points != null) {
|
||||||
|
for (int i = 0; i<points.length; i++) {
|
||||||
|
if (points[i] != null) {
|
||||||
|
for (int j = 0; j<points[i].length; j++) {
|
||||||
|
totalPoints++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
String conclusionMessage = "Imported " + totalPoints + " points from " + countLines + " lines of code in the file.";
|
||||||
|
println(conclusionMessage);
|
||||||
|
javax.swing.JOptionPane.showMessageDialog(null, conclusionMessage);
|
||||||
|
|
||||||
|
loop();
|
||||||
|
return parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
Boolean isGCodeZAxisForDrawing(float z) {
|
||||||
|
return gcodeZAxisDrawingHeight.compareTo(z) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Float> unpackGCodeInstruction(String line) throws Exception {
|
||||||
|
Map<String, Float> instruction = new HashMap<String, Float>(4);
|
||||||
|
try {
|
||||||
|
String[] splitted = line.trim().split(" ");
|
||||||
|
for (int i = 0; i < splitted.length; i++) {
|
||||||
|
// remove ; character
|
||||||
|
splitted[i] = splitted[i].replace(";", "");
|
||||||
|
String axis = splitted[i].substring(0, 1);
|
||||||
|
String sanitisedValue = splitted[i].substring(1);
|
||||||
|
sanitisedValue = sanitisedValue.replace(",", ".");
|
||||||
|
Float value = Float.parseFloat(sanitisedValue);
|
||||||
|
if ("X".equalsIgnoreCase(axis) || "Y".equalsIgnoreCase(axis) || "Z".equalsIgnoreCase(axis) || "G".equalsIgnoreCase(axis)) {
|
||||||
|
instruction.put(axis.toUpperCase(), value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// println("instruction: " + instruction);
|
||||||
|
if (instruction.isEmpty()) {
|
||||||
|
throw new Exception("Empty instruction");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (NumberFormatException nfe) {
|
||||||
|
println("Number format exception: " + nfe.getMessage());
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
println("e: " + e);
|
||||||
|
throw new Exception("Exception while reading the lines from a gcode file: " + line + ", " + e.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
return instruction;
|
||||||
|
}
|
34
Machine.pde
34
Machine.pde
@ -39,7 +39,7 @@ class Machine
|
|||||||
protected Rectangle imageFrame = new Rectangle(1500,1500,1000,1000);
|
protected Rectangle imageFrame = new Rectangle(1500,1500,1000,1000);
|
||||||
protected Rectangle pictureFrame = new Rectangle(1600,1600,800,800);
|
protected Rectangle pictureFrame = new Rectangle(1600,1600,800,800);
|
||||||
|
|
||||||
protected Float stepsPerRev = 800.0;
|
protected Float stepsPerRev = 200.0;
|
||||||
protected Float mmPerRev = 95.0;
|
protected Float mmPerRev = 95.0;
|
||||||
|
|
||||||
protected Float mmPerStep = null;
|
protected Float mmPerStep = null;
|
||||||
@ -186,9 +186,15 @@ class Machine
|
|||||||
return mmInt;
|
return mmInt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public float inMMFloat(float steps)
|
||||||
|
{
|
||||||
|
double mm = steps / getStepsPerMM();
|
||||||
|
return (float) mm;
|
||||||
|
}
|
||||||
|
|
||||||
public PVector inMM (PVector steps)
|
public PVector inMM (PVector steps)
|
||||||
{
|
{
|
||||||
PVector mm = new PVector(inMM(steps.x), inMM(steps.y));
|
PVector mm = new PVector(inMMFloat(steps.x), inMMFloat(steps.y));
|
||||||
return mm;
|
return mm;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -286,6 +292,16 @@ class Machine
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean isMasked(PVector pos, float scalingFactor)
|
||||||
|
{
|
||||||
|
switch (invertMaskMode) {
|
||||||
|
case MASK_IS_UNUSED: return false;
|
||||||
|
case MASKED_COLOURS_ARE_HIDDEN: return isChromaKey(pos, scalingFactor);
|
||||||
|
case MASKED_COLOURS_ARE_SHOWN: return !isChromaKey(pos, scalingFactor);
|
||||||
|
default: return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
boolean isChromaKey(PVector pos, float scalingFactor)
|
boolean isChromaKey(PVector pos, float scalingFactor)
|
||||||
{
|
{
|
||||||
if (getImageFrame().surrounds(pos))
|
if (getImageFrame().surrounds(pos))
|
||||||
@ -322,8 +338,8 @@ class Machine
|
|||||||
|
|
||||||
public PVector asCartesianCoords(PVector pgCoords)
|
public PVector asCartesianCoords(PVector pgCoords)
|
||||||
{
|
{
|
||||||
float calcX = int((pow(getWidth(), 2) - pow(pgCoords.y, 2) + pow(pgCoords.x, 2)) / (getWidth()*2));
|
float calcX = (pow(getWidth(), 2.0) - pow(pgCoords.y, 2.0) + pow(pgCoords.x, 2.0)) / (getWidth()*2.0);
|
||||||
float calcY = int(sqrt(pow(pgCoords.x,2)-pow(calcX,2)));
|
float calcY = sqrt(pow(pgCoords.x,2.0)-pow(calcX,2.0));
|
||||||
PVector vect = new PVector(calcX, calcY);
|
PVector vect = new PVector(calcX, calcY);
|
||||||
return vect;
|
return vect;
|
||||||
}
|
}
|
||||||
@ -364,7 +380,7 @@ class Machine
|
|||||||
public void loadDefinitionFromProperties(Properties props)
|
public void loadDefinitionFromProperties(Properties props)
|
||||||
{
|
{
|
||||||
// get these first because they are important to convert the rest of them
|
// get these first because they are important to convert the rest of them
|
||||||
setStepsPerRev(getFloatProperty("machine.motors.stepsPerRev", 800.0));
|
setStepsPerRev(getFloatProperty("machine.motors.stepsPerRev", 200.0));
|
||||||
setMMPerRev(getFloatProperty("machine.motors.mmPerRev", 95.0));
|
setMMPerRev(getFloatProperty("machine.motors.mmPerRev", 95.0));
|
||||||
|
|
||||||
// now stepsPerMM and mmPerStep should have been calculated. It's safe to get the rest.
|
// now stepsPerMM and mmPerStep should have been calculated. It's safe to get the rest.
|
||||||
@ -383,12 +399,12 @@ class Machine
|
|||||||
String pos = getStringProperty("controller.page.position.x", "CENTRE");
|
String pos = getStringProperty("controller.page.position.x", "CENTRE");
|
||||||
float px = 0.0;
|
float px = 0.0;
|
||||||
println("machine size: " + getSize().x + ", " + inSteps(pageSize.x));
|
println("machine size: " + getSize().x + ", " + inSteps(pageSize.x));
|
||||||
if (pos.equalsIgnoreCase("CENTRE"))
|
if (pos.equalsIgnoreCase("CENTRE")) {
|
||||||
{
|
|
||||||
px = inMM((getSize().x - pageSize.x) / 2.0);
|
px = inMM((getSize().x - pageSize.x) / 2.0);
|
||||||
}
|
}
|
||||||
else
|
else {
|
||||||
px = getFloatProperty("controller.page.position.x", (int) getDisplayMachine().getPageCentrePosition(pageSize.x));
|
px = getFloatProperty("controller.page.position.x", (int) getDisplayMachine().getPageCentrePosition(pageSize.x));
|
||||||
|
}
|
||||||
|
|
||||||
float py = getFloatProperty("controller.page.position.y", 120);
|
float py = getFloatProperty("controller.page.position.y", 120);
|
||||||
|
|
||||||
@ -620,7 +636,7 @@ class Machine
|
|||||||
PVector cartesianCoord = asCartesianCoords(nativeCoord);
|
PVector cartesianCoord = asCartesianCoords(nativeCoord);
|
||||||
if (selectedArea.surrounds(cartesianCoord))
|
if (selectedArea.surrounds(cartesianCoord))
|
||||||
{
|
{
|
||||||
if (isChromaKey(cartesianCoord, scalingFactor))
|
if (isMasked(cartesianCoord, scalingFactor))
|
||||||
{
|
{
|
||||||
nativeCoord.z = MASKED_PIXEL_BRIGHTNESS; // magic number
|
nativeCoord.z = MASKED_PIXEL_BRIGHTNESS; // magic number
|
||||||
nativeCoords.add(nativeCoord);
|
nativeCoords.add(nativeCoord);
|
||||||
|
32
Panel.pde
32
Panel.pde
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
sandy.noble@gmail.com
|
sandy.noble@gmail.com
|
||||||
http://www.polargraph.co.uk/
|
http://www.polargraph.co.uk/
|
||||||
http://code.google.com/p/polargraph/
|
https://github.com/euphy/polargraphcontroller
|
||||||
*/
|
*/
|
||||||
class Panel
|
class Panel
|
||||||
{
|
{
|
||||||
@ -120,9 +120,11 @@ class Panel
|
|||||||
|
|
||||||
public void draw()
|
public void draw()
|
||||||
{
|
{
|
||||||
//stroke(outlineColour);
|
if (debugPanels) {
|
||||||
//strokeWeight(2);
|
stroke(outlineColour);
|
||||||
//rect(getOutline().getLeft(), getOutline().getTop(), getOutline().getWidth(), getOutline().getHeight());
|
strokeWeight(2);
|
||||||
|
rect(getOutline().getLeft(), getOutline().getTop(), getOutline().getWidth(), getOutline().getHeight());
|
||||||
|
}
|
||||||
|
|
||||||
drawControls();
|
drawControls();
|
||||||
}
|
}
|
||||||
@ -131,7 +133,6 @@ class Panel
|
|||||||
{
|
{
|
||||||
for (Controller c : this.getControls())
|
for (Controller c : this.getControls())
|
||||||
{
|
{
|
||||||
// println("Control: " + c.getName());
|
|
||||||
PVector pos = getControlPositions().get(c.getName());
|
PVector pos = getControlPositions().get(c.getName());
|
||||||
float x = pos.x+getOutline().getLeft();
|
float x = pos.x+getOutline().getLeft();
|
||||||
float y = pos.y+getOutline().getTop();
|
float y = pos.y+getOutline().getTop();
|
||||||
@ -163,6 +164,13 @@ class Panel
|
|||||||
{
|
{
|
||||||
locked = true;
|
locked = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if there's no vector loaded, then hide vector controls
|
||||||
|
if (getControlsToLockIfVectorNotLoaded().contains(c.getName()) && vectorFilename == null)
|
||||||
|
{
|
||||||
|
locked = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (c.getName().equals(MODE_LOAD_VECTOR_FILE))
|
if (c.getName().equals(MODE_LOAD_VECTOR_FILE))
|
||||||
{
|
{
|
||||||
@ -200,34 +208,28 @@ class Panel
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void setHeight(float h)
|
void setSizeByHeight(float h)
|
||||||
{
|
{
|
||||||
|
// println("Setting size for " + this.getName());
|
||||||
if (this.isResizable())
|
if (this.isResizable())
|
||||||
{
|
{
|
||||||
if (h <= getMinimumHeight())
|
if (h <= getMinimumHeight())
|
||||||
this.getOutline().setHeight(getMinimumHeight());
|
this.getOutline().setHeight(getMinimumHeight());
|
||||||
else
|
else
|
||||||
this.getOutline().setHeight(h);
|
this.getOutline().setHeight(h);
|
||||||
|
|
||||||
setControlPositions(buildControlPositionsForPanel(this));
|
setControlPositions(buildControlPositionsForPanel(this));
|
||||||
|
|
||||||
float left = 0.0;
|
float left = 0.0;
|
||||||
String controlName = "";
|
|
||||||
for (String key : getControlPositions().keySet())
|
for (String key : getControlPositions().keySet())
|
||||||
{
|
{
|
||||||
PVector pos = getControlPositions().get(key);
|
PVector pos = getControlPositions().get(key);
|
||||||
if (pos.x >= left)
|
if (pos.x > left)
|
||||||
{
|
{
|
||||||
left = pos.x;
|
left = pos.x;
|
||||||
controlName = key;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, PVector> map = getControlSizes();
|
|
||||||
|
|
||||||
// PVector size = getControlSizes().get(controlName);
|
|
||||||
// println("size: " + size);
|
|
||||||
float right = left + DEFAULT_CONTROL_SIZE.x;
|
float right = left + DEFAULT_CONTROL_SIZE.x;
|
||||||
|
|
||||||
this.getOutline().setWidth(right);
|
this.getOutline().setWidth(right);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@ polargraphcontroller
|
|||||||
====================
|
====================
|
||||||
|
|
||||||
Polargraph controller
|
Polargraph controller
|
||||||
Copyright Sandy Noble 2015.
|
Copyright Sandy Noble 2018.
|
||||||
|
|
||||||
- Requires the excellent ControlP5 GUI library available from https://github.com/sojamo/controlp5.
|
- Requires the excellent ControlP5 GUI library available from https://github.com/sojamo/controlp5.
|
||||||
- Requires the excellent Geomerative library available from http://www.ricardmarxer.com/geomerative/.
|
- Requires the excellent Geomerative library available from http://www.ricardmarxer.com/geomerative/.
|
||||||
@ -13,5 +13,7 @@ This is a desktop application for controlling a polargraph machine, communicatin
|
|||||||
The [latest releases bundle] (https://github.com/euphy/polargraphcontroller/releases/latest) contains
|
The [latest releases bundle] (https://github.com/euphy/polargraphcontroller/releases/latest) contains
|
||||||
copies of all the libraries that I use, as well as all the source, and compiled versions of the code where sensible.
|
copies of all the libraries that I use, as well as all the source, and compiled versions of the code where sensible.
|
||||||
|
|
||||||
|
How to [run it from source](https://github.com/euphy/polargraph/wiki/Running-the-controller-from-source-code).
|
||||||
|
|
||||||
sandy.noble@gmail.com
|
sandy.noble@gmail.com
|
||||||
http://www.polargraph.co.uk/
|
http://www.polargraph.co.uk/
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*------------------------------------------------------------------------
|
/*------------------------------------------------------------------------
|
||||||
Class and controllers on the "serial port" subwindow
|
Class and controllers on the "serial port" subwindow
|
||||||
------------------------------------------------------------------------*/
|
------------------------------------------------------------------------*/
|
||||||
|
|
||||||
ControlFrameSimple addSerialPortControlFrame(String theName, int theWidth, int theHeight, int theX, int theY, int theColor ) {
|
ControlFrameSimple addSerialPortControlFrame(String theName, int theWidth, int theHeight, int theX, int theY, int theColor ) {
|
||||||
final Frame f = new Frame( theName );
|
final Frame f = new Frame( theName );
|
||||||
final ControlFrameSimple p = new ControlFrameSimple( this, theWidth, theHeight, theColor );
|
final ControlFrameSimple p = new ControlFrameSimple( this, theWidth, theHeight, theColor );
|
||||||
@ -28,36 +28,44 @@ ControlFrameSimple addSerialPortControlFrame(String theName, int theWidth, int t
|
|||||||
}
|
}
|
||||||
catch(Exception e) {
|
catch(Exception e) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// set up controls
|
|
||||||
RadioButton r = p.cp5().addRadioButton("radio_serialPort")
|
|
||||||
.setPosition(10, 10)
|
|
||||||
.setSize(15, 15)
|
|
||||||
.setSpacingRow(5)
|
|
||||||
.plugTo(this, "radio_serialPort");
|
|
||||||
|
|
||||||
r.addItem("No serial connection", -1);
|
ScrollableList sl = p.cp5().addScrollableList("dropdown_serialPort")
|
||||||
|
.setPosition(10, 10)
|
||||||
|
.setSize(150, 450)
|
||||||
|
.setBarHeight(20)
|
||||||
|
.setItemHeight(16)
|
||||||
|
.plugTo(this, "dropdown_serialPort");
|
||||||
|
|
||||||
|
sl.addItem("No serial connection", -1);
|
||||||
|
|
||||||
String[] ports = Serial.list();
|
String[] ports = Serial.list();
|
||||||
|
|
||||||
for (int i = 0; i < ports.length; i++) {
|
for (int i = 0; i < ports.length; i++) {
|
||||||
println("Adding " + ports[i]);
|
println("Adding " + ports[i]);
|
||||||
r.addItem(ports[i], i);
|
sl.addItem(ports[i], i);
|
||||||
}
|
}
|
||||||
|
|
||||||
int portNo = getSerialPortNumber();
|
int portNo = getSerialPortNumber();
|
||||||
if (portNo >= 0 && portNo < ports.length)
|
println("portNo: " + portNo);
|
||||||
r.activate(ports[portNo]);
|
if (portNo < 0 || portNo >= ports.length)
|
||||||
else
|
portNo = -1;
|
||||||
r.activate("No serial connection");
|
|
||||||
|
|
||||||
|
// set the value of the actual control
|
||||||
|
sl.setValue(portNo);
|
||||||
|
|
||||||
|
sl.setOpen(true);
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void radio_serialPort(int newSerialPort)
|
void dropdown_serialPort(int newSerialPort)
|
||||||
{
|
{
|
||||||
println("In radio_serialPort");
|
println("In dropdown_serialPort, newSerialPort: " + newSerialPort);
|
||||||
|
|
||||||
|
// No serial in list is slot 0 in code because of list index
|
||||||
|
// So shift port index by one
|
||||||
|
newSerialPort -= 1;
|
||||||
|
|
||||||
if (newSerialPort == -2)
|
if (newSerialPort == -2)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -163,12 +163,17 @@ void button_mode_liveConfirmDraw()
|
|||||||
float scaling = getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getWidth()) / captureShape.getWidth();
|
float scaling = getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getWidth()) / captureShape.getWidth();
|
||||||
PVector position = new PVector(getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getPosition().x),
|
PVector position = new PVector(getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getPosition().x),
|
||||||
getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getPosition().y));
|
getDisplayMachine().inMM(getDisplayMachine().getImageFrame().getPosition().y));
|
||||||
|
|
||||||
|
int oldPolygonizer = polygonizer;
|
||||||
|
polygonizer = RG.ADAPTATIVE;
|
||||||
|
setupPolygonizer();
|
||||||
sendVectorShapes(captureShape, scaling, position, PATH_SORT_CENTRE_FIRST);
|
sendVectorShapes(captureShape, scaling, position, PATH_SORT_CENTRE_FIRST);
|
||||||
button_mode_penUp();
|
button_mode_penUp();
|
||||||
|
|
||||||
// save shape as SVG
|
// save shape as SVG
|
||||||
trace_saveShape(captureShape);
|
trace_saveShape(captureShape);
|
||||||
|
polygonizer = oldPolygonizer;
|
||||||
|
setupPolygonizer();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void toggle_mode_showWebcamRawVideo(boolean flag)
|
void toggle_mode_showWebcamRawVideo(boolean flag)
|
||||||
@ -318,6 +323,7 @@ void button_mode_loadImage()
|
|||||||
getDisplayMachine().setImageFilename(null);
|
getDisplayMachine().setImageFilename(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void button_mode_loadVectorFile()
|
void button_mode_loadVectorFile()
|
||||||
{
|
{
|
||||||
if (getVectorShape() == null)
|
if (getVectorShape() == null)
|
||||||
@ -331,6 +337,7 @@ void button_mode_loadVectorFile()
|
|||||||
vectorFilename = null;
|
vectorFilename = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void numberbox_mode_pixelBrightThreshold(float value)
|
void numberbox_mode_pixelBrightThreshold(float value)
|
||||||
{
|
{
|
||||||
pixelExtractBrightThreshold = (int) value;
|
pixelExtractBrightThreshold = (int) value;
|
||||||
@ -526,12 +533,14 @@ void numberbox_mode_changeMachineWidth(float value)
|
|||||||
clearBoxVectors();
|
clearBoxVectors();
|
||||||
float steps = getDisplayMachine().inSteps((int) value);
|
float steps = getDisplayMachine().inSteps((int) value);
|
||||||
getDisplayMachine().getSize().x = steps;
|
getDisplayMachine().getSize().x = steps;
|
||||||
|
getDisplayMachine().maxLength = null;
|
||||||
}
|
}
|
||||||
void numberbox_mode_changeMachineHeight(float value)
|
void numberbox_mode_changeMachineHeight(float value)
|
||||||
{
|
{
|
||||||
clearBoxVectors();
|
clearBoxVectors();
|
||||||
float steps = getDisplayMachine().inSteps((int) value);
|
float steps = getDisplayMachine().inSteps((int) value);
|
||||||
getDisplayMachine().getSize().y = steps;
|
getDisplayMachine().getSize().y = steps;
|
||||||
|
getDisplayMachine().maxLength = null;
|
||||||
}
|
}
|
||||||
void numberbox_mode_changeMMPerRev(float value)
|
void numberbox_mode_changeMMPerRev(float value)
|
||||||
{
|
{
|
||||||
@ -608,7 +617,7 @@ void button_mode_sendPenWidth()
|
|||||||
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_SETPENWIDTH+df.format(currentPenWidth)+",END");
|
||||||
}
|
}
|
||||||
|
|
||||||
void numberbox_mode_changePenTestStartWidth(float value)
|
void numberbox_mode_changePenTestStartWidth(float value)
|
||||||
@ -725,4 +734,46 @@ void numberbox_mode_previewCordOffsetValue(int value)
|
|||||||
previewQueue(true);
|
previewQueue(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dropdown_mode_cycleDensityPreviewStyle(int index)
|
||||||
|
{
|
||||||
|
println("In dropdown_mode_cycleDensityPreviewStyle");
|
||||||
|
densityPreviewStyle = index;
|
||||||
|
println("Style: " + densityPreviewStyle);
|
||||||
|
}
|
||||||
|
|
||||||
|
void numberbox_mode_changeDensityPreviewPosterize(int value) {
|
||||||
|
if (value < 1) value = 1;
|
||||||
|
else if (value > 255) value = 255;
|
||||||
|
|
||||||
|
densityPreviewPosterize = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void minitoggle_mode_previewPixelDensityRange(boolean flag) {
|
||||||
|
previewPixelDensityRange = flag;
|
||||||
|
println("previewPixelDensityRange: " + previewPixelDensityRange);
|
||||||
|
}
|
||||||
|
|
||||||
|
void numberbox_mode_changePolygonizerLength(float value) {
|
||||||
|
polygonizerLength = value;
|
||||||
|
setupPolygonizer();
|
||||||
|
}
|
||||||
|
|
||||||
|
void numberbox_mode_changePolygonizerAdaptativeAngle(float value) {
|
||||||
|
println("numberbox_mode_changePolygonizerAdaptativeAngle");
|
||||||
|
polygonizerAdaptativeAngle = value;
|
||||||
|
setupPolygonizer();
|
||||||
|
}
|
||||||
|
|
||||||
|
void dropdown_mode_changePolygonizer(int value)
|
||||||
|
{
|
||||||
|
polygonizer = value;
|
||||||
|
setupPolygonizer();
|
||||||
|
}
|
||||||
|
|
||||||
|
void dropdown_mode_changeMaskInvert(int value)
|
||||||
|
{
|
||||||
|
invertMaskMode = value;
|
||||||
|
rebuildPixels();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ String DRAW_PIXELS_WINDOW_NAME = "drawPixelsWindow";
|
|||||||
String DRAW_WRITING_WINDOW_NAME = "drawWritingWindow";
|
String DRAW_WRITING_WINDOW_NAME = "drawWritingWindow";
|
||||||
|
|
||||||
void button_mode_serialPortDialog() {
|
void button_mode_serialPortDialog() {
|
||||||
ControlFrameSimple cf = addSerialPortControlFrame("Serial Port", 200, 200, 20, 240, color( 100 ) );
|
ControlFrameSimple cf = addSerialPortControlFrame("Serial Port", 200, 500, 20, 240, color( 100 ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void button_mode_machineStoreDialog() {
|
void button_mode_machineStoreDialog() {
|
||||||
|
@ -83,6 +83,14 @@ Set<String> getControlsToLockIfImageNotLoaded() {
|
|||||||
return this.controlsToLockIfImageNotLoaded;
|
return this.controlsToLockIfImageNotLoaded;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Set<String> getControlsToLockIfVectorNotLoaded() {
|
||||||
|
if (this.controlsToLockIfVectorNotLoaded == null)
|
||||||
|
{
|
||||||
|
this.controlsToLockIfVectorNotLoaded = buildControlsToLockIfVectorNotLoaded();
|
||||||
|
}
|
||||||
|
return this.controlsToLockIfVectorNotLoaded;
|
||||||
|
}
|
||||||
|
|
||||||
void hideAllControls() {
|
void hideAllControls() {
|
||||||
for (String key : allControls.keySet())
|
for (String key : allControls.keySet())
|
||||||
{
|
{
|
||||||
@ -95,9 +103,9 @@ Map<String, Panel> buildPanels() {
|
|||||||
Map<String, Panel> panels = new HashMap<String, Panel>();
|
Map<String, Panel> panels = new HashMap<String, Panel>();
|
||||||
|
|
||||||
float panelHeight = frame.getHeight() - getMainPanelPosition().y - (DEFAULT_CONTROL_SIZE.y*3);
|
float panelHeight = frame.getHeight() - getMainPanelPosition().y - (DEFAULT_CONTROL_SIZE.y*3);
|
||||||
Rectangle panelOutline = new Rectangle(getMainPanelPosition(),
|
Rectangle panelOutlineInput = new Rectangle(getMainPanelPosition(),
|
||||||
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
||||||
Panel inputPanel = new Panel(PANEL_NAME_INPUT, panelOutline);
|
Panel inputPanel = new Panel(PANEL_NAME_INPUT, panelOutlineInput);
|
||||||
inputPanel.setResizable(true);
|
inputPanel.setResizable(true);
|
||||||
inputPanel.setOutlineColour(color(200, 200, 200));
|
inputPanel.setOutlineColour(color(200, 200, 200));
|
||||||
// get controls
|
// get controls
|
||||||
@ -107,7 +115,9 @@ Map<String, Panel> buildPanels() {
|
|||||||
inputPanel.setControlSizes(buildControlSizesForPanel(inputPanel));
|
inputPanel.setControlSizes(buildControlSizesForPanel(inputPanel));
|
||||||
panels.put(PANEL_NAME_INPUT, inputPanel);
|
panels.put(PANEL_NAME_INPUT, inputPanel);
|
||||||
|
|
||||||
Panel rovingPanel = new Panel(PANEL_NAME_ROVING, panelOutline);
|
Rectangle panelOutlineRoving = new Rectangle(getMainPanelPosition(),
|
||||||
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
||||||
|
Panel rovingPanel = new Panel(PANEL_NAME_ROVING, panelOutlineRoving);
|
||||||
rovingPanel.setOutlineColour(color(100,200,200));
|
rovingPanel.setOutlineColour(color(100,200,200));
|
||||||
// get controls
|
// get controls
|
||||||
rovingPanel.setResizable(true);
|
rovingPanel.setResizable(true);
|
||||||
@ -117,7 +127,9 @@ Map<String, Panel> buildPanels() {
|
|||||||
rovingPanel.setControlSizes(buildControlSizesForPanel(rovingPanel));
|
rovingPanel.setControlSizes(buildControlSizesForPanel(rovingPanel));
|
||||||
panels.put(PANEL_NAME_ROVING, rovingPanel);
|
panels.put(PANEL_NAME_ROVING, rovingPanel);
|
||||||
|
|
||||||
Panel tracePanel = new Panel(PANEL_NAME_TRACE, panelOutline);
|
Rectangle panelOutlineTrace = new Rectangle(getMainPanelPosition(),
|
||||||
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
||||||
|
Panel tracePanel = new Panel(PANEL_NAME_TRACE, panelOutlineTrace);
|
||||||
tracePanel.setOutlineColour(color(200,255,200));
|
tracePanel.setOutlineColour(color(200,255,200));
|
||||||
// get controls
|
// get controls
|
||||||
tracePanel.setResizable(true);
|
tracePanel.setResizable(true);
|
||||||
@ -127,7 +139,9 @@ Map<String, Panel> buildPanels() {
|
|||||||
tracePanel.setControlSizes(buildControlSizesForPanel(tracePanel));
|
tracePanel.setControlSizes(buildControlSizesForPanel(tracePanel));
|
||||||
panels.put(PANEL_NAME_TRACE, tracePanel);
|
panels.put(PANEL_NAME_TRACE, tracePanel);
|
||||||
|
|
||||||
Panel detailsPanel = new Panel(PANEL_NAME_DETAILS, panelOutline);
|
Rectangle panelOutlineDetails = new Rectangle(getMainPanelPosition(),
|
||||||
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
||||||
|
Panel detailsPanel = new Panel(PANEL_NAME_DETAILS, panelOutlineDetails);
|
||||||
detailsPanel.setOutlineColour(color(200, 200, 255));
|
detailsPanel.setOutlineColour(color(200, 200, 255));
|
||||||
// get controls
|
// get controls
|
||||||
detailsPanel.setResizable(true);
|
detailsPanel.setResizable(true);
|
||||||
@ -137,7 +151,9 @@ Map<String, Panel> buildPanels() {
|
|||||||
detailsPanel.setControlSizes(buildControlSizesForPanel(detailsPanel));
|
detailsPanel.setControlSizes(buildControlSizesForPanel(detailsPanel));
|
||||||
panels.put(PANEL_NAME_DETAILS, detailsPanel);
|
panels.put(PANEL_NAME_DETAILS, detailsPanel);
|
||||||
|
|
||||||
Panel queuePanel = new Panel(PANEL_NAME_QUEUE, panelOutline);
|
Rectangle panelOutlineQueue = new Rectangle(getMainPanelPosition(),
|
||||||
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, panelHeight));
|
||||||
|
Panel queuePanel = new Panel(PANEL_NAME_QUEUE, panelOutlineQueue);
|
||||||
queuePanel.setOutlineColour(color(200, 200, 50));
|
queuePanel.setOutlineColour(color(200, 200, 50));
|
||||||
// get controls
|
// get controls
|
||||||
queuePanel.setResizable(true);
|
queuePanel.setResizable(true);
|
||||||
@ -147,10 +163,10 @@ Map<String, Panel> buildPanels() {
|
|||||||
queuePanel.setControlSizes(buildControlSizesForPanel(queuePanel));
|
queuePanel.setControlSizes(buildControlSizesForPanel(queuePanel));
|
||||||
panels.put(PANEL_NAME_QUEUE, queuePanel);
|
panels.put(PANEL_NAME_QUEUE, queuePanel);
|
||||||
|
|
||||||
panelOutline = new Rectangle(
|
Rectangle panelOutlineGeneral = new Rectangle(
|
||||||
new PVector(getMainPanelPosition().x, getMainPanelPosition().y-((DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y)*2)),
|
new PVector(getMainPanelPosition().x, getMainPanelPosition().y-((DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y)*2)),
|
||||||
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, (DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y)*2));
|
new PVector((DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x)*2, (DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y)*2));
|
||||||
Panel generalPanel = new Panel(PANEL_NAME_GENERAL, panelOutline);
|
Panel generalPanel = new Panel(PANEL_NAME_GENERAL, panelOutlineGeneral);
|
||||||
generalPanel.setResizable(false);
|
generalPanel.setResizable(false);
|
||||||
generalPanel.setOutlineColour(color(200, 50, 200));
|
generalPanel.setOutlineColour(color(200, 50, 200));
|
||||||
// get controls
|
// get controls
|
||||||
@ -159,6 +175,8 @@ Map<String, Panel> buildPanels() {
|
|||||||
generalPanel.setControlPositions(buildControlPositionsForPanel(generalPanel));
|
generalPanel.setControlPositions(buildControlPositionsForPanel(generalPanel));
|
||||||
generalPanel.setControlSizes(buildControlSizesForPanel(generalPanel));
|
generalPanel.setControlSizes(buildControlSizesForPanel(generalPanel));
|
||||||
panels.put(PANEL_NAME_GENERAL, generalPanel);
|
panels.put(PANEL_NAME_GENERAL, generalPanel);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return panels;
|
return panels;
|
||||||
}
|
}
|
||||||
@ -173,6 +191,18 @@ void updateNumberboxValues()
|
|||||||
initialiseNumberboxValues(getAllControls());
|
initialiseNumberboxValues(getAllControls());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void initConsoleWindow() {
|
||||||
|
consoleArea = cp5.addTextarea("txt")
|
||||||
|
.setPosition(300, 100)
|
||||||
|
.setSize(400, 600)
|
||||||
|
.setFont(createFont("", 12))
|
||||||
|
.setLineHeight(14)
|
||||||
|
.setColor(color(255))
|
||||||
|
.setColorBackground(color(0, 200))
|
||||||
|
.setColorForeground(color(255, 100))
|
||||||
|
.setVisible(false);
|
||||||
|
}
|
||||||
|
|
||||||
Set<String> buildControlsToLockIfBoxNotSpecified()
|
Set<String> buildControlsToLockIfBoxNotSpecified()
|
||||||
{
|
{
|
||||||
Set<String> result = new HashSet<String>();
|
Set<String> result = new HashSet<String>();
|
||||||
@ -205,11 +235,41 @@ Set<String> buildControlsToLockIfImageNotLoaded()
|
|||||||
result.add(MODE_CHANGE_SAMPLE_AREA);
|
result.add(MODE_CHANGE_SAMPLE_AREA);
|
||||||
result.add(MODE_SELECT_PICTUREFRAME);
|
result.add(MODE_SELECT_PICTUREFRAME);
|
||||||
|
|
||||||
|
result.add(MODE_CHANGE_PIXEL_SCALING);
|
||||||
|
result.add(MODE_CHOOSE_CHROMA_KEY_COLOUR);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Set<String> buildControlsToLockIfVectorNotLoaded()
|
||||||
|
{
|
||||||
|
Set<String> result = new HashSet<String>();
|
||||||
|
result.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
||||||
|
result.add(MODE_RESIZE_VECTOR);
|
||||||
|
result.add(MODE_MOVE_VECTOR);
|
||||||
|
result.add(MODE_CHANGE_POLYGONIZER_LENGTH);
|
||||||
|
result.add(MODE_CHANGE_POLYGONIZER);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
CallbackListener toFront = new CallbackListener() {
|
||||||
|
public void controlEvent(CallbackEvent theEvent) {
|
||||||
|
theEvent.getController().bringToFront();
|
||||||
|
((ScrollableList)theEvent.getController()).open();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
CallbackListener close = new CallbackListener() {
|
||||||
|
public void controlEvent(CallbackEvent theEvent) {
|
||||||
|
((ScrollableList)theEvent.getController()).close();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
Map<String, Controller> buildAllControls()
|
Map<String, Controller> buildAllControls()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
initConsoleWindow();
|
||||||
|
|
||||||
Map<String, Controller> map = new HashMap<String, Controller>();
|
Map<String, Controller> map = new HashMap<String, Controller>();
|
||||||
|
|
||||||
@ -220,6 +280,8 @@ Map<String, Controller> buildAllControls()
|
|||||||
Button b = cp5.addButton(controlName, 0, 100, 100, 100, 100);
|
Button b = cp5.addButton(controlName, 0, 100, 100, 100, 100);
|
||||||
b.setLabel(getControlLabels().get(controlName));
|
b.setLabel(getControlLabels().get(controlName));
|
||||||
b.hide();
|
b.hide();
|
||||||
|
controlP5.Label l = b.getCaptionLabel();
|
||||||
|
l.align(ControlP5.LEFT, CENTER);
|
||||||
map.put(controlName, b);
|
map.put(controlName, b);
|
||||||
// println("Added button " + controlName);
|
// println("Added button " + controlName);
|
||||||
}
|
}
|
||||||
@ -229,8 +291,8 @@ Map<String, Controller> buildAllControls()
|
|||||||
t.setLabel(getControlLabels().get(controlName));
|
t.setLabel(getControlLabels().get(controlName));
|
||||||
t.hide();
|
t.hide();
|
||||||
controlP5.Label l = t.getCaptionLabel();
|
controlP5.Label l = t.getCaptionLabel();
|
||||||
l.getStyle().marginTop = -17; //move upwards (relative to button size)
|
l.align(ControlP5.LEFT, CENTER);
|
||||||
l.getStyle().marginLeft = 4; //move to the right
|
l.getStyle().setPaddingLeft(4);
|
||||||
map.put(controlName, t);
|
map.put(controlName, t);
|
||||||
// println("Added toggle " + controlName);
|
// println("Added toggle " + controlName);
|
||||||
}
|
}
|
||||||
@ -240,8 +302,8 @@ Map<String, Controller> buildAllControls()
|
|||||||
t.setLabel(getControlLabels().get(controlName));
|
t.setLabel(getControlLabels().get(controlName));
|
||||||
t.hide();
|
t.hide();
|
||||||
controlP5.Label l = t.getCaptionLabel();
|
controlP5.Label l = t.getCaptionLabel();
|
||||||
l.getStyle().marginTop = -17; //move upwards (relative to button size)
|
l.align(ControlP5.LEFT, CENTER);
|
||||||
l.getStyle().marginLeft = 4; //move to the right
|
l.getStyle().setPaddingLeft(4);
|
||||||
map.put(controlName, t);
|
map.put(controlName, t);
|
||||||
// println("Added minitoggle " + controlName);
|
// println("Added minitoggle " + controlName);
|
||||||
}
|
}
|
||||||
@ -252,20 +314,56 @@ Map<String, Controller> buildAllControls()
|
|||||||
n.hide();
|
n.hide();
|
||||||
n.setDecimalPrecision(0);
|
n.setDecimalPrecision(0);
|
||||||
controlP5.Label l = n.getCaptionLabel();
|
controlP5.Label l = n.getCaptionLabel();
|
||||||
l.getStyle().marginTop = -17; //move upwards (relative to button size)
|
l.align(ControlP5.LEFT, CENTER);
|
||||||
l.getStyle().marginLeft = 40; //move to the right
|
l.getStyle().setPaddingLeft(35);
|
||||||
// change the control direction to left/right
|
// change the control direction to left/right
|
||||||
n.setDirection(Controller.VERTICAL);
|
n.setDirection(Controller.VERTICAL);
|
||||||
map.put(controlName, n);
|
map.put(controlName, n);
|
||||||
// println("Added numberbox " + controlName);
|
// println("Added numberbox " + controlName);
|
||||||
}
|
}
|
||||||
|
else if (controlName.startsWith("dropdown_"))
|
||||||
|
{
|
||||||
|
ScrollableList sl = cp5.addScrollableList(controlName, 100, 100, 100, 100);
|
||||||
|
sl.setBarHeight(20);
|
||||||
|
sl.setItemHeight(20);
|
||||||
|
sl.setLabel(getControlLabels().get(controlName));
|
||||||
|
sl.setType(ScrollableList.DROPDOWN);
|
||||||
|
sl.onEnter(toFront);
|
||||||
|
sl.onLeave(close);
|
||||||
|
sl.setHeight(100);
|
||||||
|
sl.hide();
|
||||||
|
|
||||||
|
controlP5.Label l = sl.getCaptionLabel();
|
||||||
|
map.put(controlName, sl);
|
||||||
|
println("Added dropdown " + controlName);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
initialiseButtonValues(map);
|
||||||
initialiseToggleValues(map);
|
initialiseToggleValues(map);
|
||||||
initialiseNumberboxValues(map);
|
initialiseNumberboxValues(map);
|
||||||
|
initialiseDropdownContents(map);
|
||||||
|
initialiseDropdownValues(map);
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Map<String, Controller> initialiseButtonValues(Map<String, Controller> map)
|
||||||
|
{
|
||||||
|
for (String key : map.keySet())
|
||||||
|
{
|
||||||
|
if (key.startsWith("button_"))
|
||||||
|
{
|
||||||
|
Button n = (Button) map.get(key);
|
||||||
|
if (MODE_CHANGE_POLYGONIZER.equals(key)) {
|
||||||
|
n.setValue(polygonizer);
|
||||||
|
n.setLabel(this.controlLabels.get(MODE_CHANGE_POLYGONIZER) + ": " + polygonizer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
||||||
{
|
{
|
||||||
for (String key : map.keySet())
|
for (String key : map.keySet())
|
||||||
@ -430,7 +528,7 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
|||||||
n.setDecimalPrecision(2);
|
n.setDecimalPrecision(2);
|
||||||
n.setValue(pixelScalingOverGridSize);
|
n.setValue(pixelScalingOverGridSize);
|
||||||
n.setMin(0.1);
|
n.setMin(0.1);
|
||||||
n.setMax(4.0);
|
// n.setMax(4.0);
|
||||||
n.setMultiplier(0.01);
|
n.setMultiplier(0.01);
|
||||||
}
|
}
|
||||||
else if (MODE_CHANGE_MIN_VECTOR_LINE_LENGTH.equals(key))
|
else if (MODE_CHANGE_MIN_VECTOR_LINE_LENGTH.equals(key))
|
||||||
@ -489,10 +587,31 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
|
|||||||
}
|
}
|
||||||
else if (MODE_ADJUST_PREVIEW_CORD_OFFSET.equals(key))
|
else if (MODE_ADJUST_PREVIEW_CORD_OFFSET.equals(key))
|
||||||
{
|
{
|
||||||
n.setDecimalPrecision(0);
|
n.setDecimalPrecision(2);
|
||||||
n.setValue(0);
|
n.setValue(0.0);
|
||||||
n.setMultiplier(0.5);
|
n.setMultiplier(0.5);
|
||||||
}
|
}
|
||||||
|
else if (MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE.equals(key))
|
||||||
|
{
|
||||||
|
n.setValue(densityPreviewPosterize);
|
||||||
|
n.setMin(1);
|
||||||
|
n.setMax(255);
|
||||||
|
n.setDecimalPrecision(1);
|
||||||
|
n.setMultiplier(0.1);
|
||||||
|
}
|
||||||
|
else if (MODE_CHANGE_POLYGONIZER_LENGTH.equals(key)) {
|
||||||
|
n.setValue(polygonizerLength);
|
||||||
|
n.setMin(1.0);
|
||||||
|
n.setDecimalPrecision(1);
|
||||||
|
n.setMultiplier(0.1);
|
||||||
|
}
|
||||||
|
else if (MODE_CHANGE_POLYGONIZER_ADAPTATIVE_ANGLE.equals(key)) {
|
||||||
|
n.setValue(polygonizerAdaptativeAngle);
|
||||||
|
n.setMin(0.0);
|
||||||
|
n.setMax(1.57079632679);
|
||||||
|
n.setDecimalPrecision(2);
|
||||||
|
n.setMultiplier(0.01);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
@ -543,11 +662,73 @@ Map<String, Controller> initialiseToggleValues(Map<String, Controller> map)
|
|||||||
Toggle t = (Toggle) map.get(key);
|
Toggle t = (Toggle) map.get(key);
|
||||||
t.setValue((rotateWebcamImage) ? 1 : 0);
|
t.setValue((rotateWebcamImage) ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
else if (MODE_PREVIEW_PIXEL_DENSITY_RANGE.equals(key))
|
||||||
|
{
|
||||||
|
Toggle t = (Toggle) map.get(key);
|
||||||
|
t.setValue((previewPixelDensityRange) ? 1 : 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Map<String, Controller> initialiseDropdownContents(Map<String, Controller> map)
|
||||||
|
{
|
||||||
|
println("Init dropdown contents");
|
||||||
|
for (String key : map.keySet())
|
||||||
|
{
|
||||||
|
if (MODE_CYCLE_DENSITY_PREVIEW_STYLE.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setItems(densityPreviewStyles);
|
||||||
|
}
|
||||||
|
if (MODE_CHANGE_POLYGONIZER.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setItems(polygonizerStyles);
|
||||||
|
}
|
||||||
|
if (MODE_CHANGE_INVERT_MASK.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setItems(invertMaskModes);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Controller> initialiseDropdownValues(Map<String, Controller> map)
|
||||||
|
{
|
||||||
|
println("Init dropdown values");
|
||||||
|
for (String key : map.keySet())
|
||||||
|
{
|
||||||
|
if (MODE_CYCLE_DENSITY_PREVIEW_STYLE.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setValue(densityPreviewStyle);
|
||||||
|
sl.close();
|
||||||
|
}
|
||||||
|
else if (MODE_CHANGE_POLYGONIZER.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setValue(polygonizer);
|
||||||
|
sl.close();
|
||||||
|
}
|
||||||
|
else if (MODE_CHANGE_INVERT_MASK.equals(key))
|
||||||
|
{
|
||||||
|
println("Adding " + key);
|
||||||
|
ScrollableList sl = (ScrollableList) map.get(key);
|
||||||
|
sl.setValue(polygonizer);
|
||||||
|
sl.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
String getControlLabel(String butName)
|
String getControlLabel(String butName)
|
||||||
{
|
{
|
||||||
if (controlLabels.containsKey(butName))
|
if (controlLabels.containsKey(butName))
|
||||||
@ -564,6 +745,7 @@ Map<String, PVector> buildControlPositionsForPanel(Panel panel)
|
|||||||
int row = 0;
|
int row = 0;
|
||||||
for (Controller controller : panel.getControls())
|
for (Controller controller : panel.getControls())
|
||||||
{
|
{
|
||||||
|
|
||||||
if (controller.getName().startsWith("minitoggle_"))
|
if (controller.getName().startsWith("minitoggle_"))
|
||||||
{
|
{
|
||||||
PVector p = new PVector(col*(DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x), row*(DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y));
|
PVector p = new PVector(col*(DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x), row*(DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y));
|
||||||
@ -575,6 +757,18 @@ Map<String, PVector> buildControlPositionsForPanel(Panel panel)
|
|||||||
col++;
|
col++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (controller.getName().startsWith("dropdown_"))
|
||||||
|
{
|
||||||
|
PVector p = new PVector(col*(DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x), row*(DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y));
|
||||||
|
println(controller);
|
||||||
|
map.put(controller.getName(), p);
|
||||||
|
row++;
|
||||||
|
if (p.y + (DEFAULT_CONTROL_SIZE.y*2) >= panel.getOutline().getHeight())
|
||||||
|
{
|
||||||
|
row = 0;
|
||||||
|
col++;
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PVector p = new PVector(col*(DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x), row*(DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y));
|
PVector p = new PVector(col*(DEFAULT_CONTROL_SIZE.x+CONTROL_SPACING.x), row*(DEFAULT_CONTROL_SIZE.y+CONTROL_SPACING.y));
|
||||||
@ -604,6 +798,11 @@ Map<String, PVector> buildControlSizesForPanel(Panel panel)
|
|||||||
PVector s = new PVector(DEFAULT_CONTROL_SIZE.y, DEFAULT_CONTROL_SIZE.y);
|
PVector s = new PVector(DEFAULT_CONTROL_SIZE.y, DEFAULT_CONTROL_SIZE.y);
|
||||||
map.put(controller.getName(), s);
|
map.put(controller.getName(), s);
|
||||||
}
|
}
|
||||||
|
else if (controller.getName().startsWith("dropdown_"))
|
||||||
|
{
|
||||||
|
PVector s = new PVector(DEFAULT_CONTROL_SIZE.x, DEFAULT_CONTROL_SIZE.y * 4);
|
||||||
|
map.put(controller.getName(), s);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PVector s = new PVector(DEFAULT_CONTROL_SIZE.x, DEFAULT_CONTROL_SIZE.y);
|
PVector s = new PVector(DEFAULT_CONTROL_SIZE.x, DEFAULT_CONTROL_SIZE.y);
|
||||||
@ -664,8 +863,9 @@ List<String> getControlNamesForInputPanel()
|
|||||||
controlNames.add(MODE_CHANGE_GRID_SIZE);
|
controlNames.add(MODE_CHANGE_GRID_SIZE);
|
||||||
controlNames.add(MODE_CHANGE_SAMPLE_AREA);
|
controlNames.add(MODE_CHANGE_SAMPLE_AREA);
|
||||||
controlNames.add(MODE_CHOOSE_CHROMA_KEY_COLOUR);
|
controlNames.add(MODE_CHOOSE_CHROMA_KEY_COLOUR);
|
||||||
|
controlNames.add(MODE_CHANGE_INVERT_MASK);
|
||||||
controlNames.add(MODE_CHANGE_PIXEL_SCALING);
|
controlNames.add(MODE_CHANGE_PIXEL_SCALING);
|
||||||
|
|
||||||
controlNames.add(MODE_RENDER_PIXEL_DIALOG);
|
controlNames.add(MODE_RENDER_PIXEL_DIALOG);
|
||||||
// controlNames.add(MODE_DRAW_GRID);
|
// controlNames.add(MODE_DRAW_GRID);
|
||||||
controlNames.add(MODE_DRAW_OUTLINE_BOX);
|
controlNames.add(MODE_DRAW_OUTLINE_BOX);
|
||||||
@ -675,18 +875,24 @@ List<String> getControlNamesForInputPanel()
|
|||||||
controlNames.add(MODE_LOAD_VECTOR_FILE);
|
controlNames.add(MODE_LOAD_VECTOR_FILE);
|
||||||
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_VECTOR_PATH_LENGTH_HIGHPASS_CUTOFF);
|
|
||||||
controlNames.add(MODE_RENDER_VECTORS);
|
|
||||||
|
|
||||||
controlNames.add(MODE_ADJUST_PREVIEW_CORD_OFFSET);
|
controlNames.add(MODE_ADJUST_PREVIEW_CORD_OFFSET);
|
||||||
|
|
||||||
|
controlNames.add(MODE_RENDER_VECTORS);
|
||||||
|
controlNames.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
||||||
|
controlNames.add(MODE_CHANGE_POLYGONIZER);
|
||||||
|
controlNames.add(MODE_CHANGE_POLYGONIZER_LENGTH);
|
||||||
|
// controlNames.add(MODE_CHANGE_POLYGONIZER_ADAPTATIVE_ANGLE);
|
||||||
|
|
||||||
controlNames.add(MODE_SHOW_IMAGE);
|
controlNames.add(MODE_SHOW_IMAGE);
|
||||||
controlNames.add(MODE_SHOW_VECTOR);
|
controlNames.add(MODE_SHOW_VECTOR);
|
||||||
controlNames.add(MODE_SHOW_QUEUE_PREVIEW);
|
controlNames.add(MODE_SHOW_QUEUE_PREVIEW);
|
||||||
controlNames.add(MODE_SHOW_DENSITY_PREVIEW);
|
|
||||||
controlNames.add(MODE_SHOW_GUIDES);
|
controlNames.add(MODE_SHOW_GUIDES);
|
||||||
|
|
||||||
|
controlNames.add(MODE_SHOW_DENSITY_PREVIEW);
|
||||||
|
controlNames.add(MODE_PREVIEW_PIXEL_DENSITY_RANGE);
|
||||||
|
controlNames.add(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE);
|
||||||
|
controlNames.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE);
|
||||||
|
|
||||||
|
|
||||||
return controlNames;
|
return controlNames;
|
||||||
}
|
}
|
||||||
@ -913,6 +1119,7 @@ Map<String, String> buildControlLabels()
|
|||||||
result.put(MODE_MOVE_VECTOR, "Move vector");
|
result.put(MODE_MOVE_VECTOR, "Move vector");
|
||||||
result.put(MODE_RENDER_PIXEL_DIALOG, "Render pixels...");
|
result.put(MODE_RENDER_PIXEL_DIALOG, "Render pixels...");
|
||||||
result.put(MODE_CHOOSE_CHROMA_KEY_COLOUR, "Choose mask colour");
|
result.put(MODE_CHOOSE_CHROMA_KEY_COLOUR, "Choose mask colour");
|
||||||
|
result.put(MODE_CHANGE_INVERT_MASK, "Mask mode");
|
||||||
result.put(MODE_CHANGE_PIXEL_SCALING, "Pixel scaling");
|
result.put(MODE_CHANGE_PIXEL_SCALING, "Pixel scaling");
|
||||||
|
|
||||||
result.put(MODE_PEN_LIFT_UP, "Pen lift");
|
result.put(MODE_PEN_LIFT_UP, "Pen lift");
|
||||||
@ -953,6 +1160,14 @@ Map<String, String> buildControlLabels()
|
|||||||
result.put(MODE_SEND_BUTTON_DEACTIVATE, "Deactivate button");
|
result.put(MODE_SEND_BUTTON_DEACTIVATE, "Deactivate button");
|
||||||
|
|
||||||
result.put(MODE_ADJUST_PREVIEW_CORD_OFFSET, "Cord offset");
|
result.put(MODE_ADJUST_PREVIEW_CORD_OFFSET, "Cord offset");
|
||||||
|
result.put(MODE_CYCLE_DENSITY_PREVIEW_STYLE, "Density preview style");
|
||||||
|
|
||||||
|
result.put(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE, "Pixel posterize");
|
||||||
|
result.put(MODE_PREVIEW_PIXEL_DENSITY_RANGE, "Show density range");
|
||||||
|
|
||||||
|
result.put(MODE_CHANGE_POLYGONIZER, "Polygonizer style");
|
||||||
|
result.put(MODE_CHANGE_POLYGONIZER_LENGTH, "Polygonizer length");
|
||||||
|
result.put(MODE_CHANGE_POLYGONIZER_ADAPTATIVE_ANGLE, "Polygonizer angle");
|
||||||
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -1060,6 +1275,7 @@ Set<String> buildControlNames()
|
|||||||
result.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
result.add(MODE_CHANGE_MIN_VECTOR_LINE_LENGTH);
|
||||||
|
|
||||||
result.add(MODE_CHOOSE_CHROMA_KEY_COLOUR);
|
result.add(MODE_CHOOSE_CHROMA_KEY_COLOUR);
|
||||||
|
result.add(MODE_CHANGE_INVERT_MASK);
|
||||||
result.add(MODE_CHANGE_PIXEL_SCALING);
|
result.add(MODE_CHANGE_PIXEL_SCALING);
|
||||||
result.add(MODE_PEN_LIFT_UP);
|
result.add(MODE_PEN_LIFT_UP);
|
||||||
result.add(MODE_PEN_LIFT_DOWN);
|
result.add(MODE_PEN_LIFT_DOWN);
|
||||||
@ -1098,6 +1314,14 @@ Set<String> buildControlNames()
|
|||||||
result.add(MODE_SEND_BUTTON_DEACTIVATE);
|
result.add(MODE_SEND_BUTTON_DEACTIVATE);
|
||||||
|
|
||||||
result.add(MODE_ADJUST_PREVIEW_CORD_OFFSET);
|
result.add(MODE_ADJUST_PREVIEW_CORD_OFFSET);
|
||||||
|
result.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE);
|
||||||
|
|
||||||
|
result.add(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE);
|
||||||
|
result.add(MODE_PREVIEW_PIXEL_DENSITY_RANGE);
|
||||||
|
|
||||||
|
result.add(MODE_CHANGE_POLYGONIZER_LENGTH);
|
||||||
|
result.add(MODE_CHANGE_POLYGONIZER);
|
||||||
|
result.add(MODE_CHANGE_POLYGONIZER_ADAPTATIVE_ANGLE);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
44
drawing.pde
44
drawing.pde
@ -27,9 +27,9 @@
|
|||||||
https://github.com/euphy/polargraphcontroller
|
https://github.com/euphy/polargraphcontroller
|
||||||
*/
|
*/
|
||||||
static final String CMD_CHANGELENGTH = "C01,";
|
static final String CMD_CHANGELENGTH = "C01,";
|
||||||
static final String CMD_CHANGEPENWIDTH = "C02,";
|
static final String CMD_SETPENWIDTH = "C02,";
|
||||||
static final String CMD_CHANGEMOTORSPEED = "C03,";
|
//static final String CMD_CHANGEMOTORSPEED = "C03,";
|
||||||
static final String CMD_CHANGEMOTORACCEL = "C04,";
|
//static final String CMD_CHANGEMOTORACCEL = "C04,";
|
||||||
static final String CMD_DRAWPIXEL = "C05,";
|
static final String CMD_DRAWPIXEL = "C05,";
|
||||||
static final String CMD_DRAWSCRIBBLEPIXEL = "C06,";
|
static final String CMD_DRAWSCRIBBLEPIXEL = "C06,";
|
||||||
static final String CMD_DRAWRECT = "C07,";
|
static final String CMD_DRAWRECT = "C07,";
|
||||||
@ -120,9 +120,7 @@ void sendRequestMachineSize()
|
|||||||
void sendMachineSpec()
|
void sendMachineSpec()
|
||||||
{
|
{
|
||||||
// ask for input to get the new machine size
|
// ask for input to get the new machine size
|
||||||
String command = CMD_CHANGEMACHINENAME+newMachineName+",END";
|
String command = CMD_CHANGEMACHINESIZE+getDisplayMachine().inMM(getDisplayMachine().getWidth())+","+getDisplayMachine().inMM(getDisplayMachine().getHeight())+",END";
|
||||||
addToCommandQueue(command);
|
|
||||||
command = CMD_CHANGEMACHINESIZE+getDisplayMachine().inMM(getDisplayMachine().getWidth())+","+getDisplayMachine().inMM(getDisplayMachine().getHeight())+",END";
|
|
||||||
addToCommandQueue(command);
|
addToCommandQueue(command);
|
||||||
command = CMD_CHANGEMACHINEMMPERREV+int(getDisplayMachine().getMMPerRev())+",END";
|
command = CMD_CHANGEMACHINEMMPERREV+int(getDisplayMachine().getMMPerRev())+",END";
|
||||||
addToCommandQueue(command);
|
addToCommandQueue(command);
|
||||||
@ -199,13 +197,13 @@ void sendTestPenWidth()
|
|||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append(testPenWidthCommand)
|
sb.append(testPenWidthCommand)
|
||||||
.append(int(gridSize))
|
.append(int(gridSize))
|
||||||
.append(",")
|
.append(",")
|
||||||
.append(df.format(testPenWidthStartSize))
|
.append(df.format(testPenWidthStartSize))
|
||||||
.append(",")
|
.append(",")
|
||||||
.append(df.format(testPenWidthEndSize))
|
.append(df.format(testPenWidthEndSize))
|
||||||
.append(",")
|
.append(",")
|
||||||
.append(df.format(testPenWidthIncrementSize))
|
.append(df.format(testPenWidthIncrementSize))
|
||||||
.append(",END");
|
.append(",END");
|
||||||
addToCommandQueue(sb.toString());
|
addToCommandQueue(sb.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -684,7 +682,6 @@ void sendVectorShapes(RShape vec, float scaling, PVector position, int pathSorti
|
|||||||
if (pointPaths[i] != null)
|
if (pointPaths[i] != null)
|
||||||
{
|
{
|
||||||
boolean firstPointFound = false;
|
boolean firstPointFound = false;
|
||||||
|
|
||||||
if (pointPaths[i].length > pathLengthHighPassCutoff)
|
if (pointPaths[i].length > pathLengthHighPassCutoff)
|
||||||
{
|
{
|
||||||
List<PVector> filteredPoints = filterPoints(pointPaths[i], VECTOR_FILTER_LOW_PASS, minimumVectorLineLength, scaling, position);
|
List<PVector> filteredPoints = filterPoints(pointPaths[i], VECTOR_FILTER_LOW_PASS, minimumVectorLineLength, scaling, position);
|
||||||
@ -701,7 +698,7 @@ void sendVectorShapes(RShape vec, float scaling, PVector position, int pathSorti
|
|||||||
if (liftToGetToNewPoint)
|
if (liftToGetToNewPoint)
|
||||||
addToCommandQueue(CMD_PENUP+"END");
|
addToCommandQueue(CMD_PENUP+"END");
|
||||||
// move to this point and put the pen down
|
// move to this point and put the pen down
|
||||||
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
command = CMD_CHANGELENGTHDIRECT+Math.round(p.x)+","+Math.round(p.y)+","+getMaxSegmentLength()+",END";
|
||||||
addToCommandQueue(command);
|
addToCommandQueue(command);
|
||||||
if (liftToGetToNewPoint)
|
if (liftToGetToNewPoint)
|
||||||
addToCommandQueue(CMD_PENDOWN+"END");
|
addToCommandQueue(CMD_PENDOWN+"END");
|
||||||
@ -712,7 +709,7 @@ void sendVectorShapes(RShape vec, float scaling, PVector position, int pathSorti
|
|||||||
for (int j=1; j<filteredPoints.size(); j++)
|
for (int j=1; j<filteredPoints.size(); j++)
|
||||||
{
|
{
|
||||||
p = filteredPoints.get(j);
|
p = filteredPoints.get(j);
|
||||||
command = CMD_CHANGELENGTHDIRECT+(int)p.x+","+(int)p.y+","+getMaxSegmentLength()+",END";
|
command = CMD_CHANGELENGTHDIRECT+Math.round(p.x)+","+Math.round(p.y)+","+getMaxSegmentLength()+",END";
|
||||||
addToCommandQueue(command);
|
addToCommandQueue(command);
|
||||||
}
|
}
|
||||||
lastPoint = new PVector(p.x, p.y);
|
lastPoint = new PVector(p.x, p.y);
|
||||||
@ -890,6 +887,7 @@ List<PVector> filterPointsLowPass(RPoint[] points, long filterParam, float scali
|
|||||||
|
|
||||||
// scale and convert all the points first
|
// scale and convert all the points first
|
||||||
List<PVector> scaled = new ArrayList<PVector>(points.length);
|
List<PVector> scaled = new ArrayList<PVector>(points.length);
|
||||||
|
println("a filterPointsLowPass: Scaled length: " + points.length);
|
||||||
for (int j = 0; j<points.length; j++)
|
for (int j = 0; j<points.length; j++)
|
||||||
{
|
{
|
||||||
RPoint firstPoint = points[j];
|
RPoint firstPoint = points[j];
|
||||||
@ -904,7 +902,8 @@ List<PVector> filterPointsLowPass(RPoint[] points, long filterParam, float scali
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scaled.size() > 1)
|
println("b filterPointsLowPass: Scaled length: " + scaled.size());
|
||||||
|
if (scaled.size() > 1.0)
|
||||||
{
|
{
|
||||||
PVector p = scaled.get(0);
|
PVector p = scaled.get(0);
|
||||||
result.add(p);
|
result.add(p);
|
||||||
@ -913,17 +912,18 @@ List<PVector> filterPointsLowPass(RPoint[] points, long filterParam, float scali
|
|||||||
{
|
{
|
||||||
p = scaled.get(j);
|
p = scaled.get(j);
|
||||||
// and even then, only bother drawing if it's a move of over "x" steps
|
// and even then, only bother drawing if it's a move of over "x" steps
|
||||||
int diffx = int(p.x) - int(result.get(result.size()-1).x);
|
int diffx = abs(int(p.x) - int(result.get(result.size()-1).x));
|
||||||
int diffy = int(p.y) - int(result.get(result.size()-1).y);
|
int diffy = abs(int(p.y) - int(result.get(result.size()-1).y));
|
||||||
|
|
||||||
if (abs(diffx) > filterParam || abs(diffy) > filterParam)
|
if (diffx > filterParam || diffy > filterParam)
|
||||||
{
|
{
|
||||||
//println("Adding point " + p + ", last: " + result.get(result.size()-1));
|
println(j + ". Adding point " + p + " because diffx (" + diffx + ") or diffy (" + diffy + ") is > " + filterParam + ", last: " + result.get(result.size()-1));
|
||||||
result.add(p);
|
result.add(p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
println("c filterPointsLowPass: Scaled length: " + result.size());
|
||||||
if (result.size() < 2)
|
if (result.size() < 2)
|
||||||
result.clear();
|
result.clear();
|
||||||
|
|
||||||
@ -968,5 +968,3 @@ void sendDrawRandomSprite(String spriteFilename)
|
|||||||
{
|
{
|
||||||
addToCommandQueue(CMD_DRAW_RANDOM_SPRITE+","+spriteFilename+",100,500,END");
|
addToCommandQueue(CMD_DRAW_RANDOM_SPRITE+","+spriteFilename+",100,500,END");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
7
queue.pde
Normal file
7
queue.pde
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
/**
|
||||||
|
Tools for dealing with a full command queue.
|
||||||
|
|
||||||
|
Optimise queue.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
42
tabSetup.pde
42
tabSetup.pde
@ -83,25 +83,35 @@ List<String> buildTabNames()
|
|||||||
|
|
||||||
void initTabs()
|
void initTabs()
|
||||||
{
|
{
|
||||||
cp5.getTab(TAB_NAME_INPUT).setLabel(TAB_LABEL_INPUT);
|
int tabWidth = (int)DEFAULT_CONTROL_SIZE.x;
|
||||||
cp5.getTab(TAB_NAME_INPUT).activateEvent(true);
|
int tabHeight = (int)DEFAULT_CONTROL_SIZE.y;
|
||||||
cp5.getTab(TAB_NAME_INPUT).setId(1);
|
|
||||||
|
Tab.padding = 13; // that's a weird thing to do
|
||||||
|
|
||||||
|
Tab input = cp5.getTab(TAB_NAME_INPUT);
|
||||||
|
input.setLabel(TAB_LABEL_INPUT);
|
||||||
|
input.activateEvent(true);
|
||||||
|
input.setId(1);
|
||||||
|
|
||||||
cp5.getTab(TAB_NAME_DETAILS).setLabel(TAB_LABEL_DETAILS);
|
Tab details = cp5.getTab(TAB_NAME_DETAILS);
|
||||||
cp5.getTab(TAB_NAME_DETAILS).activateEvent(true);
|
details.setLabel(TAB_LABEL_DETAILS);
|
||||||
cp5.getTab(TAB_NAME_DETAILS).setId(2);
|
details.activateEvent(true);
|
||||||
|
details.setId(2);
|
||||||
|
|
||||||
|
Tab roving = cp5.getTab(TAB_NAME_ROVING);
|
||||||
|
roving.setLabel(TAB_LABEL_ROVING);
|
||||||
|
roving.activateEvent(true);
|
||||||
|
roving.setId(3);
|
||||||
|
|
||||||
cp5.getTab(TAB_NAME_ROVING).setLabel(TAB_LABEL_ROVING);
|
Tab trace = cp5.getTab(TAB_NAME_TRACE);
|
||||||
cp5.getTab(TAB_NAME_ROVING).activateEvent(true);
|
trace.setLabel(TAB_LABEL_TRACE);
|
||||||
cp5.getTab(TAB_NAME_ROVING).setId(3);
|
trace.activateEvent(true);
|
||||||
|
trace.setId(4);
|
||||||
|
|
||||||
cp5.getTab(TAB_NAME_TRACE).setLabel(TAB_LABEL_TRACE);
|
Tab queue = cp5.getTab(TAB_NAME_QUEUE);
|
||||||
cp5.getTab(TAB_NAME_TRACE).activateEvent(true);
|
queue.setLabel(TAB_LABEL_QUEUE);
|
||||||
cp5.getTab(TAB_NAME_TRACE).setId(4);
|
queue.activateEvent(true);
|
||||||
|
queue.setId(5);
|
||||||
cp5.getTab(TAB_NAME_QUEUE).setLabel(TAB_LABEL_QUEUE);
|
|
||||||
cp5.getTab(TAB_NAME_QUEUE).activateEvent(true);
|
|
||||||
cp5.getTab(TAB_NAME_QUEUE).setId(5);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<String> buildPanelNames()
|
public Set<String> buildPanelNames()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user