From 400e7fed5496334f7081c2a2b46f8d82d43fa3c6 Mon Sep 17 00:00:00 2001 From: Paul Falstad Date: Wed, 23 Oct 2024 14:10:19 -0700 Subject: [PATCH] circular symbol #110 --- .../circuitjs1/client/AmmeterElm.java | 52 +++++++++++++++++-- 1 file changed, 47 insertions(+), 5 deletions(-) diff --git a/src/com/lushprojects/circuitjs1/client/AmmeterElm.java b/src/com/lushprojects/circuitjs1/client/AmmeterElm.java index b3ad9cc6..843c22fa 100644 --- a/src/com/lushprojects/circuitjs1/client/AmmeterElm.java +++ b/src/com/lushprojects/circuitjs1/client/AmmeterElm.java @@ -41,7 +41,7 @@ class AmmeterElm extends CircuitElm { public AmmeterElm(int xx, int yy) { super(xx, yy); - flags = FLAG_SHOWCURRENT; + flags = FLAG_SHOWCURRENT|FLAG_CIRCLE; scale = SCALE_AUTO; } public AmmeterElm(int xa, int ya, int xb, int yb, int f, @@ -68,10 +68,14 @@ String getMeter(){ void setPoints(){ super.setPoints(); mid = interpPoint(point1,point2,0.6); + center = interpPoint(point1,point2,0.5); arrowPoly = calcArrow(point1, mid, 14, 7); } + Point center; Point mid; static final int FLAG_SHOWCURRENT = 1; + static final int FLAG_CIRCLE = 2; // Add this line + void stepFinished(){ count++;//how many counts are in a cycle total += current*current; //sum of squares @@ -145,10 +149,35 @@ void stepFinished(){ void draw(Graphics g) { super.draw(g);//BC required for highlighting setVoltageColor(g, volts[0]); - drawThickLine(g, point1, point2); - g.fillPolygon(arrowPoly); + double width = 4; + if (!drawAsCircle()) { + drawThickLine(g, point1, point2); + g.fillPolygon(arrowPoly); + } else { + g.setColor(needsHighlight() ? selectColor : lightGrayColor); + drawThickCircle(g, center.x, center.y, circleSize); + drawCenteredText(g, "A", center.x, center.y, true); + + calcLeads(circleSize*2); + setVoltageColor(g, volts[0]); + drawThickLine(g, point1, lead1); + drawThickLine(g, lead2, point2); + + g.setColor(whiteColor); + g.setFont(unitsFont); + double len = circleSize*2; + Point plusPoint = interpPoint(point1, point2, (dn/2-len/2-4)/dn, -10*dsign ); + if (y2 > y) + plusPoint.y += 4; + if (y > y2) + plusPoint.y += 3; + int w = (int)g.context.measureText("+").getWidth(); + g.drawString("+", plusPoint.x-w/2, plusPoint.y); + width = circleSize; + } + doDots(g); - setBbox(point1, point2, 3); + setBbox(point1, point2, width); String s = "A"; switch (meter) { case AM_VOL: @@ -159,9 +188,12 @@ void draw(Graphics g) { break; } - drawValues(g, s, 4); + drawValues(g, s, width); drawPosts(g); } + + final int circleSize = 12; + int getDumpType() { return 370; } void stamp() { sim.stampVoltageSource(nodes[0], nodes[1], voltSource, 0); @@ -188,6 +220,10 @@ void getInfo(String arr[]) { // (because we need current calculated every timestep) boolean isWireEquivalent() { return true; } + boolean drawAsCircle() { + return (flags & FLAG_CIRCLE) != 0; + } + public EditInfo getEditInfo(int n) { if (n==0){ EditInfo ei = new EditInfo("Value", selectedValue, -1, -1); @@ -207,13 +243,19 @@ public EditInfo getEditInfo(int n) { ei.choice.select(scale); return ei; } + if (n == 2) { + return EditInfo.createCheckbox("Circular Symbol", drawAsCircle()); + } return null; } + public void setEditValue(int n, EditInfo ei) { if (n==0) meter = ei.choice.getSelectedIndex(); if (n==1) scale = ei.choice.getSelectedIndex(); + if (n==2) + flags = ei.changeFlag(flags, FLAG_CIRCLE); } }