Made pixel transparenter and added machine messages

This commit is contained in:
Sandy Noble 2014-08-02 17:49:14 +01:00
parent 5e78877b19
commit 8222d2a8ce
2 changed files with 55 additions and 2 deletions

View File

@ -723,7 +723,7 @@ class DisplayMachine extends Machine
previewNativePixel(scaledPos, pixelSize, cartesianPos.z); previewNativePixel(scaledPos, pixelSize, cartesianPos.z);
break; break;
case DENSITY_PREVIEW_NATIVE_SIZE: case DENSITY_PREVIEW_NATIVE_SIZE:
previewNativePixel(scaledPos, map(cartesianPos.z, 1, 255, pixelSize, 1), 0); previewNativePixel(scaledPos, map(cartesianPos.z, 1, 255, 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);

View File

@ -51,7 +51,7 @@ import java.awt.event.KeyEvent;
import java.awt.event.*; import java.awt.event.*;
int majorVersionNo = 1; int majorVersionNo = 1;
int minorVersionNo = 8; int minorVersionNo = 9;
int buildNo = 0; int buildNo = 0;
String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo; String programTitle = "Polargraph Controller v" + majorVersionNo + "." + minorVersionNo + " build " + buildNo;
@ -136,6 +136,7 @@ float MACHINE_MAXSPEED_INCREMENT = 25.0;
List<String> commandQueue = new ArrayList<String>(); List<String> commandQueue = new ArrayList<String>();
List<String> realtimeCommandQueue = new ArrayList<String>(); List<String> realtimeCommandQueue = new ArrayList<String>();
List<String> commandHistory = new ArrayList<String>(); List<String> commandHistory = new ArrayList<String>();
List<String> machineMessageLog = new ArrayList<String>();
List<PreviewVector> previewCommandList = new ArrayList<PreviewVector>(); List<PreviewVector> previewCommandList = new ArrayList<PreviewVector>();
long lastCommandQueueHash = 0L; long lastCommandQueueHash = 0L;
@ -761,6 +762,7 @@ void drawImagePage()
drawStatusText((int)statusTextPosition.x, (int)statusTextPosition.y); drawStatusText((int)statusTextPosition.x, (int)statusTextPosition.y);
showCommandQueue((int) getDisplayMachine().getOutline().getRight()+6, 20); showCommandQueue((int) getDisplayMachine().getOutline().getRight()+6, 20);
showmachineMessageLog((int) getDisplayMachine().getOutline().getRight()+306, 20);
} }
void drawMachineOutline() void drawMachineOutline()
@ -2198,6 +2200,40 @@ void drawCommandQueueStatus(int x, int y, int tSize)
setCommandQueueFont(); setCommandQueueFont();
} }
void showmachineMessageLog(int xPos, int yPos)
{
setCommandQueueFont();
int tRow = 15;
int textPositionX = xPos;
int textPositionY = yPos;
int tRowNo = 1;
int pos = textPositionY+(tRow*tRowNo++);
topEdgeOfQueue = pos-queueRowHeight;
leftEdgeOfQueue = textPositionX;
rightEdgeOfQueue = textPositionX+300;
bottomEdgeOfQueue = height;
pos+=queueRowHeight;
fill(255);
// Write out the commands into the window, stop when you fall off the bottom of the window
// Or run out of commands
int entryNo = machineMessageLog.size()-1;
while (pos <= height && entryNo >= 0)
{
String s = machineMessageLog.get(entryNo);
String type = s.substring(0,1);
if ("E".equals(type)) fill(255,128,128);
else if ("D".equals(type)) fill(50,50,50);
else if ("I".equals(type)) fill(255);
text(s, textPositionX, pos);
pos+=queueRowHeight;
entryNo--;
}
}
long getCurrentPixelTime() long getCurrentPixelTime()
{ {
if (pixelTimerRunning) if (pixelTimerRunning)
@ -2415,6 +2451,8 @@ void serialEvent(Serial myPort)
drawbotReady = true; drawbotReady = true;
setHardwareVersionFromIncoming(incoming); setHardwareVersionFromIncoming(incoming);
} }
else if (incoming.startsWith("MSG"))
readMachineMessage(incoming);
else if (incoming.startsWith("SYNC")) else if (incoming.startsWith("SYNC"))
readMachinePosition(incoming); readMachinePosition(incoming);
else if (incoming.startsWith("CARTESIAN")) else if (incoming.startsWith("CARTESIAN"))
@ -2457,6 +2495,21 @@ void extractMemoryUsage(String mem)
} }
} }
void readMachineMessage(String msg)
{
msg = msg.substring(4, msg.length());
String type = msg.substring(0,1);
msg = msg.substring(2, msg.length());
String timestamp = new SimpleDateFormat("HH:mm:ss").format(new Date());
msg = type + timestamp + " " + msg;
machineMessageLog.add(msg);
if (machineMessageLog.size() > 200)
{
machineMessageLog.remove(0);
}
}
void readMachinePosition(String sync) void readMachinePosition(String sync)
{ {
String[] splitted = split(sync, ","); String[] splitted = split(sync, ",");