Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
a7963fe8db |
@ -508,6 +508,7 @@ text.circle=Circle around % through %
|
||||
text.circle.fixed=Circle around % through % with radius %
|
||||
text.fixedcircle=Circle around % with radius %
|
||||
text.circle3=Circle around % with radius from % to %
|
||||
text.circle3d=3D Circle around % with radius % and normal %
|
||||
text.parallel=Parallel line through % to %
|
||||
text.midpoint=Midpoint between % and %
|
||||
text.quadric=Conic section through %
|
||||
|
125
rene/zirkel/objects/Circle3DObject.java
Normal file
125
rene/zirkel/objects/Circle3DObject.java
Normal file
@ -0,0 +1,125 @@
|
||||
/*
|
||||
|
||||
Coyright 2018 Glen Whitney
|
||||
|
||||
This file is contributed to C.a.R./CaRMetal software.
|
||||
|
||||
C.a.R. is a 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, version 3 of the License.
|
||||
|
||||
C.a.R. 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
*/
|
||||
|
||||
package rene.zirkel.objects;
|
||||
|
||||
import rene.gui.Global;
|
||||
import rene.zirkel.construction.Construction;
|
||||
import rene.zirkel.construction.ConstructionException;
|
||||
import rene.zirkel.expression.Expression;
|
||||
|
||||
/* A three dimensional circle determined by a 3D point (the "midpoint" of the super
|
||||
object), an expression giving its radius, and a TwoPointLineObject
|
||||
determined by two 3D points, giving its normal direction. (The line does
|
||||
not have to go through the center.
|
||||
*/
|
||||
public class Circle3DObject extends PrimitiveCircleObject {
|
||||
Expression E_R; // Expression for the radius
|
||||
TwoPointLineObject N;
|
||||
|
||||
public Circle3DObject(final Construction c, final PointObject C,
|
||||
final String s, final TwoPointLineObject L)
|
||||
throws ConstructionException {
|
||||
super(c, C);
|
||||
if (!C.is3D()) {
|
||||
throw new ConstructionException("Cannot create Circle3D with "
|
||||
+ "non-3D center " + C.getName());
|
||||
}
|
||||
if (!L.getP1().is3D() || !L.getP2().is3D()) {
|
||||
throw new ConstructionException("Cannot create Circle3D with "
|
||||
+ "non-3D normal " + L.getName());
|
||||
}
|
||||
E_R = new Expression(s, c, this);
|
||||
N = L;
|
||||
validate();
|
||||
updateText();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getTag() {
|
||||
return "Circle3D";
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateText() {
|
||||
setText(text3(Global.name("text.circle3D"),
|
||||
M.getName(), E_R.toString(), N.getName()));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void validate() {
|
||||
super.validate();
|
||||
Valid = false;
|
||||
if (!M.valid() || !E_R.valid() || !N.valid()) {
|
||||
return;
|
||||
}
|
||||
try { R = E_R.getValue(); } catch (final Exception e) {
|
||||
R = 0;
|
||||
return;
|
||||
}
|
||||
if (R < 0) { return; }
|
||||
Valid = true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void printArgs(final XmlWriter xml) {
|
||||
xml.printArg("radius", E_R.toString());
|
||||
xml.printArg("normal", N.getName());
|
||||
super.printArgs(xml);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getStringLength() {
|
||||
return E_R.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public double getValue() throws ConstructionException {
|
||||
if (!Valid) {
|
||||
throw new InvalidException("exception.invalid");
|
||||
} else {
|
||||
return R;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Enumeration depending() {
|
||||
super.depending();
|
||||
final Enumeration e = E_R.getDepList().elements();
|
||||
while (e.hasMoreElements()) {
|
||||
DL.add((ConstructionObject) e.nextElement());
|
||||
}
|
||||
DL.add(N);
|
||||
return DL.elements();
|
||||
}
|
||||
|
||||
/* A (rudimentary version) of the class is almost done at this point, but
|
||||
it still needs a paint() method. This we want to share with the
|
||||
QuadricObject. The best way I could think of was to create a class that
|
||||
encapsulates the X[..] data in QuadricObject, with a method to set that
|
||||
up from 5 (x,y) pairs. In QuadricObject, I woul just use the 5 (x,y)
|
||||
values of the Point members. Here, in validate, I would use the center,
|
||||
radius, and normal data to compute 5 equally-spaced (x,y,z) coordinates
|
||||
around the circle. The sticking point is then projecting those to
|
||||
(x,y). There does not seem to be any good way to do it -- it seems like
|
||||
Expressions that do it are littered all around the code. Ugh. So I am
|
||||
giving up for now.
|
||||
*/
|
||||
}
|
Loading…
Reference in New Issue
Block a user