Fixing merge

This commit is contained in:
Sandy Noble 2016-01-26 12:50:48 +00:00
commit 69ab977f90
7 changed files with 106 additions and 51 deletions

View File

@ -719,7 +719,12 @@ class DisplayMachine extends Machine
// scale em, danno. // scale em, danno.
PVector scaledPos = scaleToScreen(cartesianPos); PVector scaledPos = scaleToScreen(cartesianPos);
noStroke(); noStroke();
fill(cartesianPos.z);
// Posterize the density value
int reduced = int(map(cartesianPos.z, 1, 255, 1, densityPreviewPosterize)+0.5);
int brightness = int(map(reduced, 1, densityPreviewPosterize, 1, 255));
fill(brightness);
switch (getDensityPreviewStyle()) switch (getDensityPreviewStyle())
{ {
case DENSITY_PREVIEW_ROUND: case DENSITY_PREVIEW_ROUND:
@ -727,21 +732,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, densityPreviewPosterize, 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, densityPreviewPosterize, pixelSize, 1), 50);
break; break;
case DENSITY_PREVIEW_NATIVE_ARC: case DENSITY_PREVIEW_NATIVE_ARC:
previewNativePixel(scaledPos, map(cartesianPos.z, 1, 255, pixelSize, 1), 50); previewRoundPixel(scaledPos, pixelSize*0.8);
// previewRoundPixel(scaledPos, pixelSize*0.8); previewNativeArcPixel(scaledPos, pixelSize, brightness);
previewNativeArcPixel(scaledPos, pixelSize, cartesianPos.z);
break; break;
default: default:
previewRoundPixel(scaledPos, pixelSize); previewRoundPixel(scaledPos, pixelSize);

View File

@ -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;
@ -364,7 +364,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 +383,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);

View File

@ -738,4 +738,11 @@ void button_mode_cycleDensityPreviewStyle()
} }
} }
void numberbox_mode_changeDensityPreviewPosterize(int value) {
if (value < 1) value = 1;
else if (value > 255) value = 255;
densityPreviewPosterize = value;
}

View File

@ -183,6 +183,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>();
@ -221,6 +233,8 @@ Set<String> buildControlsToLockIfImageNotLoaded()
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>();
for (String controlName : getControlNames()) for (String controlName : getControlNames())
@ -507,6 +521,14 @@ Map<String, Controller> initialiseNumberboxValues(Map<String, Controller> map)
{ {
n.setValue(densityPreviewStyle); n.setValue(densityPreviewStyle);
} }
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);
}
} }
} }
return map; return map;
@ -680,6 +702,7 @@ List<String> getControlNamesForInputPanel()
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_PIXEL_SCALING); controlNames.add(MODE_CHANGE_PIXEL_SCALING);
controlNames.add(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE);
controlNames.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE); controlNames.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE);
controlNames.add(MODE_RENDER_PIXEL_DIALOG); controlNames.add(MODE_RENDER_PIXEL_DIALOG);
@ -971,6 +994,8 @@ Map<String, String> buildControlLabels()
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, "Cycle preview style"); result.put(MODE_CYCLE_DENSITY_PREVIEW_STYLE, "Cycle preview style");
result.put(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE, "Pixel posterize");
return result; return result;
@ -1118,6 +1143,8 @@ Set<String> buildControlNames()
result.add(MODE_ADJUST_PREVIEW_CORD_OFFSET); result.add(MODE_ADJUST_PREVIEW_CORD_OFFSET);
result.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE); result.add(MODE_CYCLE_DENSITY_PREVIEW_STYLE);
result.add(MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE);
return result; return result;
} }

View File

@ -57,8 +57,8 @@ import java.awt.BorderLayout;
import java.lang.reflect.Method; import java.lang.reflect.Method;
int majorVersionNo = 2; int majorVersionNo = 2;
int minorVersionNo = 1; int minorVersionNo = 2;
int buildNo = 0; int buildNo = 2;
String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo; String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo;
ControlP5 cp5; ControlP5 cp5;
@ -190,7 +190,7 @@ float testPenWidthStartSize = 0.5;
float testPenWidthEndSize = 2.0; float testPenWidthEndSize = 2.0;
float testPenWidthIncrementSize = 0.5; float testPenWidthIncrementSize = 0.5;
int machineStepMultiplier = 1; int machineStepMultiplier = 8;
int maxSegmentLength = 2; int maxSegmentLength = 2;
@ -342,6 +342,8 @@ static final String MODE_ADJUST_PREVIEW_CORD_OFFSET = "numberbox_mode_previewCor
static final String MODE_CYCLE_DENSITY_PREVIEW_STYLE = "button_mode_cycleDensityPreviewStyle"; static final String MODE_CYCLE_DENSITY_PREVIEW_STYLE = "button_mode_cycleDensityPreviewStyle";
static final String MODE_CHANGE_DENSITY_PREVIEW_POSTERIZE = "numberbox_mode_changeDensityPreviewPosterize";
PVector statusTextPosition = new PVector(300.0, 12.0); PVector statusTextPosition = new PVector(300.0, 12.0);
@ -387,6 +389,7 @@ static final int DENSITY_PREVIEW_NATIVE_SIZE = 5;
static final int DEFAULT_DENSITY_PREVIEW_STYLE = DENSITY_PREVIEW_NATIVE; static final int DEFAULT_DENSITY_PREVIEW_STYLE = DENSITY_PREVIEW_NATIVE;
int densityPreviewStyle = DEFAULT_DENSITY_PREVIEW_STYLE; int densityPreviewStyle = DEFAULT_DENSITY_PREVIEW_STYLE;
int densityPreviewPosterize = 255;
static final byte COORD_MODE_NATIVE_STEPS = 0; static final byte COORD_MODE_NATIVE_STEPS = 0;
static final byte COORD_MODE_NATIVE_MM = 1; static final byte COORD_MODE_NATIVE_MM = 1;
@ -422,6 +425,9 @@ public Integer windowHeight = 400;
public static Integer serialPortNumber = -1; public static Integer serialPortNumber = -1;
public Textarea consoleArea = null;
public Println console = null;
public PrintStream savedOut = null;
Properties props = null; Properties props = null;
public static String propertiesFilename = "default.properties.txt"; public static String propertiesFilename = "default.properties.txt";
@ -485,9 +491,6 @@ public static final int VECTOR_FILTER_LOW_PASS = 0;
String storeFilename = "comm.txt"; String storeFilename = "comm.txt";
boolean overwriteExistingStoreFile = true; boolean overwriteExistingStoreFile = true;
//private static Logger logger;
public static Console console;
public boolean useWindowedConsole = false;
static boolean drawingTraceShape = true; static boolean drawingTraceShape = true;
static boolean retraceShape = true; static boolean retraceShape = true;
@ -537,7 +540,8 @@ void setup()
parentPapplet = this; parentPapplet = this;
RG.init(this); RG.init(this);
RG.setPolygonizer(RG.ADAPTATIVE); RG.setPolygonizer(RG.UNIFORMLENGTH);
// RG.setPolygonizer(RG.ADAPTATIVE);
try try
{ {
@ -600,6 +604,7 @@ void setup()
addEventListeners(); addEventListeners();
frameRate(8); frameRate(8);
noLoop();
} }
void fitDisplayMachineToWindow() { void fitDisplayMachineToWindow() {
@ -619,6 +624,10 @@ void fitDisplayMachineToWindow() {
machineScaling = (targetHeight / machineHeight); machineScaling = (targetHeight / machineHeight);
println(machineScaling); println(machineScaling);
if (machineScaling < 0) {
machineScaling = 1.0;
}
getDisplayMachine().getOffset().x = ((gr.getRight() > ir.getRight()) ? gr.getRight() : ir.getRight()) + CONTROL_SPACING.x; getDisplayMachine().getOffset().x = ((gr.getRight() > ir.getRight()) ? gr.getRight() : ir.getRight()) + CONTROL_SPACING.x;
getDisplayMachine().getOffset().y = gr.getTop(); getDisplayMachine().getOffset().y = gr.getTop();
@ -675,6 +684,7 @@ void windowResized()
} }
void draw() void draw()
{ {
if (getCurrentTab() == TAB_NAME_INPUT) { if (getCurrentTab() == TAB_NAME_INPUT) {
drawImagePage(); drawImagePage();
} }
@ -1680,12 +1690,7 @@ void keyPressed()
} }
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_C)) else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_C))
{ {
if (isUseWindowedConsole()) toggleShowConsole();
setUseWindowedConsole(false);
else
setUseWindowedConsole(true);
initLogging();
} }
else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_S)) else if (checkKey(CONTROL) && checkKey(KeyEvent.VK_S))
{ {
@ -1915,6 +1920,26 @@ boolean isPreviewable(String command)
} }
} }
boolean toggleShowConsole() {
if (console == null) {
savedOut = System.out;
console = cp5.addConsole(consoleArea);
consoleArea.setVisible(true);
console.play();
}
else {
console.pause();
consoleArea.setVisible(false);
cp5.remove(console);
console = null;
System.setOut(savedOut);
}
println("Ow");
return console == null;
}
/** /**
This will comb the command queue and attempt to draw a picture of what it contains. This will comb the command queue and attempt to draw a picture of what it contains.
Coordinates here are in pixels. Coordinates here are in pixels.
@ -1930,6 +1955,8 @@ void previewQueue(boolean forceRebuild)
{ {
println("regenerating preview queue."); println("regenerating preview queue.");
previewCommandList.clear(); previewCommandList.clear();
for (String command : commandQueue) for (String command : commandQueue)
{ {
if (command.startsWith(CMD_CHANGELENGTHDIRECT) || command.startsWith(CMD_CHANGELENGTH) || command.startsWith(CMD_DRAWPIXEL)) if (command.startsWith(CMD_CHANGELENGTHDIRECT) || command.startsWith(CMD_CHANGELENGTH) || command.startsWith(CMD_DRAWPIXEL))
@ -1943,8 +1970,8 @@ void previewQueue(boolean forceRebuild)
String bLenStr = splitted[2]; String bLenStr = splitted[2];
PVector endPoint = new PVector(Integer.parseInt(aLenStr)+previewCordOffset, Integer.parseInt(bLenStr)+previewCordOffset); PVector endPoint = new PVector(Integer.parseInt(aLenStr)+previewCordOffset, Integer.parseInt(bLenStr)+previewCordOffset);
endPoint = getDisplayMachine().asCartesianCoords(endPoint);
endPoint = getDisplayMachine().inMM(endPoint); endPoint = getDisplayMachine().inMM(endPoint);
endPoint = getDisplayMachine().asCartesianCoords(endPoint);
pv.x = endPoint.x; pv.x = endPoint.x;
pv.y = endPoint.y; pv.y = endPoint.y;
@ -2537,7 +2564,7 @@ public PVector getHomePoint()
public DisplayMachine getDisplayMachine() public DisplayMachine getDisplayMachine()
{ {
if (displayMachine == null) if (displayMachine == null)
displayMachine = new DisplayMachine(new Machine(5000, 5000, 800.0, 95.0), machinePosition, machineScaling); displayMachine = new DisplayMachine(new Machine(5000, 5000, 200.0, 95.0), machinePosition, machineScaling);
displayMachine.setOffset(machinePosition); displayMachine.setOffset(machinePosition);
displayMachine.setScale(machineScaling); displayMachine.setScale(machineScaling);
@ -2953,9 +2980,9 @@ void loadFromPropertiesFile()
this.currentPenWidth = getFloatProperty("machine.pen.size", 0.8); this.currentPenWidth = getFloatProperty("machine.pen.size", 0.8);
// motor settings // motor settings
this.currentMachineMaxSpeed = getFloatProperty("machine.motors.maxSpeed", 600.0); this.currentMachineMaxSpeed = getFloatProperty("machine.motors.maxSpeed", 2000.0);
this.currentMachineAccel = getFloatProperty("machine.motors.accel", 400.0); this.currentMachineAccel = getFloatProperty("machine.motors.accel", 2000.0);
this.machineStepMultiplier = getIntProperty("machine.step.multiplier", 1); this.machineStepMultiplier = getIntProperty("machine.step.multiplier", 8);
// serial port // serial port
this.serialPortNumber = getIntProperty("controller.machine.serialport", 0); this.serialPortNumber = getIntProperty("controller.machine.serialport", 0);
@ -3248,16 +3275,6 @@ Integer getBaudRate()
return baudRate; return baudRate;
} }
boolean isUseWindowedConsole()
{
return this.useWindowedConsole;
}
void setUseWindowedConsole(boolean use)
{
this.useWindowedConsole = use;
}
void initLogging() void initLogging()
{ {
try try