Manage {config} token in -setp option
This commit is contained in:
@@ -3,21 +3,10 @@
|
||||
*/
|
||||
package ch.psi.mxsc;
|
||||
|
||||
import ch.psi.mxsc.BasePlate.SelectionMode;
|
||||
import ch.psi.pshell.device.Device;
|
||||
import ch.psi.pshell.device.DeviceBase;
|
||||
import ch.psi.pshell.imaging.DimensionDouble;
|
||||
import ch.psi.pshell.imaging.PointDouble;
|
||||
import ch.psi.utils.swing.MainFrame;
|
||||
import ch.psi.utils.swing.SwingUtils;
|
||||
import java.awt.BasicStroke;
|
||||
import java.awt.Color;
|
||||
import java.awt.Dimension;
|
||||
import java.awt.Font;
|
||||
import java.awt.Graphics;
|
||||
import java.awt.Graphics2D;
|
||||
import java.awt.Point;
|
||||
import java.awt.Rectangle;
|
||||
import java.util.ArrayList;
|
||||
|
||||
/**
|
||||
@@ -80,7 +69,7 @@ public class Puck extends DeviceBase {
|
||||
final static PointDouble ledMinispinePosition = new PointDouble(0.0, -36.0);
|
||||
final static Double unipuckLedSize = 10.0;
|
||||
final static Double minispineLedSize = 8.0;
|
||||
final static PointDouble labelPositionWithImage = new PointDouble(0.0, 36.0);
|
||||
|
||||
|
||||
|
||||
PuckType puckType = PuckType.Unknown;
|
||||
@@ -155,52 +144,7 @@ public class Puck extends DeviceBase {
|
||||
}
|
||||
return ret.toArray(new Sample[0]);
|
||||
}
|
||||
|
||||
public PointDouble getRotatedPosition(PointDouble ref) {
|
||||
double rotation = - angle * Math.PI / 180.0;
|
||||
double x = ref.x * Math.cos(rotation) - ref.y * Math.sin(rotation);
|
||||
double y = ref.y * Math.cos(rotation) + ref.x * Math.sin(rotation);
|
||||
return new PointDouble(x,y );
|
||||
}
|
||||
|
||||
public PointDouble getSamplePosition(Sample sample) {
|
||||
//PointDouble ref = samplesPosition[sample.index];
|
||||
//return getRotatedPosition(ref);
|
||||
return samplesPosition[sample.index];
|
||||
}
|
||||
|
||||
public Point getDrawUnipuckLedPosition(){
|
||||
PointDouble ref = ledUnipuckPosition;
|
||||
return getDrawPosition(ref);
|
||||
}
|
||||
|
||||
public Point getDrawMinispineLedPosition(){
|
||||
PointDouble ref = ledMinispinePosition;
|
||||
return getDrawPosition(ref);
|
||||
}
|
||||
|
||||
|
||||
int getUnipuckLedSize() {
|
||||
return getDrawSize(unipuckLedSize) ;
|
||||
}
|
||||
|
||||
int getMinispineLedSize() {
|
||||
return getDrawSize(minispineLedSize) ;
|
||||
}
|
||||
|
||||
int getDrawSize(double refSize) {
|
||||
return (int) ((refSize / getSize().getWidth()) * getDrawSize()) ;
|
||||
}
|
||||
|
||||
Point getDrawPosition(PointDouble refPosition) {
|
||||
Point puckCenter = getDrawPosition();
|
||||
int puckDrawSize = getDrawSize();
|
||||
DimensionDouble puckSize = getSize();
|
||||
PointDouble pos = getRotatedPosition(refPosition);
|
||||
return new Point( (int) ((pos.x / puckSize.getWidth())* puckDrawSize/2 + puckCenter.x) ,
|
||||
(int) ((pos.y / puckSize.getHeight())* puckDrawSize/2 + puckCenter.y) );
|
||||
}
|
||||
|
||||
|
||||
public boolean isSegmentSelected() {
|
||||
/*
|
||||
@@ -219,10 +163,6 @@ public class Puck extends DeviceBase {
|
||||
return ("" + getSegment()).equalsIgnoreCase(Controller.getInstance().getHexiposiPosition());
|
||||
}
|
||||
|
||||
public boolean isHighlithted() {
|
||||
return isSelected() || isSegmentSelected();
|
||||
}
|
||||
|
||||
public int getIndex() {
|
||||
return index;
|
||||
}
|
||||
@@ -285,7 +225,7 @@ public class Puck extends DeviceBase {
|
||||
private boolean selected;
|
||||
|
||||
public boolean isSelected() {
|
||||
return selected && (getBasePlate().getSelectionMode()!=SelectionMode.None);
|
||||
return selected;
|
||||
}
|
||||
|
||||
public void toggleSelected(boolean value) {
|
||||
@@ -315,192 +255,5 @@ public class Puck extends DeviceBase {
|
||||
public int getNumberOfSamples() {
|
||||
return numberOfSamples;
|
||||
}
|
||||
|
||||
Color getColor() {
|
||||
Color ret = Color.LIGHT_GRAY;
|
||||
switch (detection) {
|
||||
case Empty:
|
||||
//ret = isHighlithted() ? new Color(224, 224, 224) : Color.LIGHT_GRAY;
|
||||
ret = isHighlithted() ? new Color(212, 212, 212) : Color.LIGHT_GRAY;
|
||||
break;
|
||||
case Present:
|
||||
if ((puckType != null) && (puckType != PuckType.Unknown)){
|
||||
switch (puckType){
|
||||
case Minispine:
|
||||
ret = isHighlithted() ? new Color(0, 200, 80) : new Color(128, 232, 152);
|
||||
break;
|
||||
case Unipuck:
|
||||
ret = isHighlithted() ? new Color(0, 140, 140) : new Color(128, 192, 192);
|
||||
break;
|
||||
case Empty:
|
||||
case Error:
|
||||
ret = isHighlithted() ? new Color(192, 10, 10) : new Color(192, 128, 128);
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
ret = isHighlithted() ? new Color(0, 140, 140) : new Color(128, 192, 192);
|
||||
}
|
||||
break;
|
||||
case Error:
|
||||
ret = isHighlithted() ? new Color(192, 10, 10) : new Color(192, 128, 128);
|
||||
break;
|
||||
case Offline:
|
||||
ret = isHighlithted() ? new Color(250, 255, 48) : new Color(253, 194, 41);
|
||||
//ret = isHighlithted() ? new Color(230, 142, 40) : new Color(216, 159, 93);
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
int getDrawSize() {
|
||||
//Single puck plot
|
||||
if (plotRect != null) {
|
||||
return Math.min(plotRect.width, plotRect.height);
|
||||
}
|
||||
//All pucks
|
||||
Rectangle plotRect = getBasePlate().getBoundingBox();
|
||||
int ret = Math.min(
|
||||
(int) ((getSize().getWidth() / getBasePlate().getSize().getWidth()) * plotRect.width),
|
||||
(int) ((getSize().getHeight() / getBasePlate().getSize().getHeight()) * plotRect.height)
|
||||
);
|
||||
if (isSelected()) {
|
||||
ret += 2;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Point getDrawPosition() {
|
||||
//Single puck plot
|
||||
if (plotRect != null) {
|
||||
return new Point((int) plotRect.getCenterX(), (int) plotRect.getCenterY());
|
||||
}
|
||||
//All pucks
|
||||
Rectangle plotRect = getBasePlate().getBoundingBox();
|
||||
DimensionDouble plateSize = getBasePlate().getSize();
|
||||
PointDouble pos = getBasePlate().getPuckPosition(this);
|
||||
return new Point((int) ((pos.x / plateSize.getWidth()) * plotRect.width + plotRect.getCenterX()),
|
||||
(int) ((pos.y / plateSize.getHeight()) * plotRect.height + plotRect.getCenterY())
|
||||
);
|
||||
}
|
||||
|
||||
Color getLabelColor(boolean drawBackground) {
|
||||
return drawBackground ? (isHighlithted() ? Color.BLACK : new Color(92, 92, 92)) : (isHighlithted() ? new Color(0, 255, 0) : new Color(0, 162, 0));
|
||||
|
||||
}
|
||||
|
||||
Font getLabelFont() {
|
||||
/*
|
||||
if (plotRect != null) {
|
||||
return new Font("Times New Roman", Font.BOLD, 18);
|
||||
}
|
||||
return new Font("Times New Roman", Font.BOLD, 10);
|
||||
*/
|
||||
if (plotRect != null) {
|
||||
return new Font("Segoe UI", Font.BOLD, 18);
|
||||
}
|
||||
return new Font("Segoe UI", Font.BOLD, 12);
|
||||
}
|
||||
|
||||
Font getIdFont() {
|
||||
if (plotRect != null) {
|
||||
return new Font("Times New Roman", Font.PLAIN, 12);
|
||||
}
|
||||
return new Font("Times New Roman", Font.PLAIN, 9);
|
||||
}
|
||||
|
||||
Point getLabelDrawPosition(String text, Graphics g, boolean drawBackground) {
|
||||
Point pos = drawBackground ? getDrawPosition() : getDrawPosition(labelPositionWithImage);
|
||||
Dimension textSize = SwingUtils.getTextSize(text, g.getFontMetrics());
|
||||
return new Point(pos.x - textSize.width / 2 , pos.y + (g.getFontMetrics().getAscent() / 2));
|
||||
}
|
||||
|
||||
Color getBorderColor(boolean drawBackground) {
|
||||
if (drawBackground) {
|
||||
/*if (!isEnabled()){
|
||||
return Color.GRAY;
|
||||
} else */
|
||||
if (isHighlithted()) {
|
||||
return new Color(0, 0, 0);
|
||||
}
|
||||
return Color.GRAY;
|
||||
}
|
||||
return isHighlithted() ? new Color(0, 208, 0) : new Color(0, 128, 0);
|
||||
}
|
||||
|
||||
int getBorderWidth(boolean drawBackground) {
|
||||
return drawBackground ? isSegmentSelected() ? 2 : 1 : isSegmentSelected() ? 2 : 1;
|
||||
}
|
||||
|
||||
int getReferenceDrawSize() {
|
||||
return getDrawSize(referenceSize) ;
|
||||
}
|
||||
|
||||
Point getReferenceDrawPosition() {
|
||||
return getDrawPosition(new PointDouble(0, -67.0));
|
||||
|
||||
}
|
||||
|
||||
Rectangle plotRect;
|
||||
|
||||
void draw(Graphics2D g, Rectangle plotRect, boolean drawSamples, boolean drawId, boolean drawBackground, BasePlate enclosingPlate) {
|
||||
this.plotRect = plotRect;
|
||||
Point position = getDrawPosition();
|
||||
int size = getDrawSize();
|
||||
if (drawBackground) {
|
||||
g.setColor(getColor());
|
||||
g.fillOval(position.x - size / 2, position.y - size / 2, size, size);
|
||||
}
|
||||
g.setColor(getBorderColor(drawBackground));
|
||||
g.setStroke(new BasicStroke(getBorderWidth(drawBackground)));
|
||||
g.drawOval(position.x - size / 2, position.y - size / 2, size, size);
|
||||
g.setStroke(new BasicStroke(1f));
|
||||
if (drawSamples) {
|
||||
//Draw samples
|
||||
for (Sample sample : getSamples()) {
|
||||
sample.draw(g, drawBackground);
|
||||
}
|
||||
}
|
||||
|
||||
//Draw reference
|
||||
Color refColor = MainFrame.isDark() ? Color.DARK_GRAY : new Color(214, 217, 223);
|
||||
if ((enclosingPlate != null) && enclosingPlate.drawContour) {
|
||||
refColor = enclosingPlate.getColor();
|
||||
}
|
||||
|
||||
if (drawBackground){
|
||||
g.setColor(refColor);
|
||||
position = getReferenceDrawPosition();
|
||||
size = getReferenceDrawSize();
|
||||
//size+=1;
|
||||
g.fillArc(position.x - size / 2, position.y - size / 2 , size, size, (int) (180 + angle), 180);
|
||||
g.setColor(getBorderColor(drawBackground));
|
||||
g.drawArc(position.x - size / 2, position.y - size / 2 , size, size, (int) (180 + angle), 180);
|
||||
} else {
|
||||
Point pu = getDrawUnipuckLedPosition();
|
||||
Point pm = getDrawMinispineLedPosition();
|
||||
int unipuckSize = getUnipuckLedSize();
|
||||
int minispineSize = getMinispineLedSize();
|
||||
g.setColor(getBorderColor(drawBackground));
|
||||
g.drawOval(pu.x - unipuckSize / 2, pu.y - unipuckSize / 2, unipuckSize, unipuckSize);
|
||||
g.drawOval(pm.x - minispineSize / 2, pm.y - minispineSize / 2, minispineSize, minispineSize);
|
||||
}
|
||||
|
||||
//Draw text
|
||||
String text = getName(); //String.valueOf(getIndex() + 1);
|
||||
g.setColor(getLabelColor(drawBackground));
|
||||
g.setFont(getLabelFont());
|
||||
Point labelPosition = getLabelDrawPosition(text, g, drawBackground);
|
||||
g.drawString(text, labelPosition.x, labelPosition.y);
|
||||
if (drawId) {
|
||||
String id = getId();
|
||||
if (id != null) {
|
||||
labelPosition.setLocation(labelPosition.x, labelPosition.y - 6);
|
||||
g.setFont(getIdFont());
|
||||
Dimension textSize = SwingUtils.getTextSize(id, g.getFontMetrics());
|
||||
g.drawString(id, getDrawPosition().x - textSize.width/2 , getDrawPosition().y + 10 );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user