|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectcom.nwoods.jgo.JGoObject
com.nwoods.jgo.JGoDrawable
com.nwoods.jgo.instruments.AbstractGraduatedScale
com.nwoods.jgo.instruments.GraduatedScaleElliptical
A subclass of AbstractGraduatedScale, which represents the scale as an ellipse defined by a Rectangle, a starting angle, and a sweep angle.
| Field Summary | |
static int |
ChangedStartAngle
This is a JGoObject update subhint. |
static int |
ChangedSweepAngle
This is a JGoObject update subhint. |
| Fields inherited from class com.nwoods.jgo.JGoObject |
Bottom, BottomCenter, BottomLeft, BottomMiddle, BottomRight, Center, CenterLeft, CenterRight, Changed4ResizeHandles, ChangedAutoRescale, ChangedBrush, ChangedDraggable, ChangedDragsNode, ChangedGeometry, ChangedGrabChildSelection, ChangedInitializing, ChangedPen, ChangedResizable, ChangedSelectable, ChangedUpdatePartner, ChangedVisible, ChangedZOrder, LastChangedHint, Left, LeftCenter, NoHandle, NoSpot, NumReservedHandles, RepaintAll, Right, RightCenter, SideLeft, SideRight, Top, TopCenter, TopLeft, TopMiddle, TopRight |
| Constructor Summary | |
GraduatedScaleElliptical()
Construct an elliptical graduated scale, whose start and sweep angles cover everything. |
|
| Method Summary | |
void |
changeValue(JGoDocumentChangedEdit e,
boolean undo)
Handle undo and redo changes. |
protected void |
computePath(java.awt.geom.GeneralPath path)
Determines the main path of the AbstractGraduatedScale. |
void |
copyNewValueForRedo(JGoDocumentChangedEdit e)
This method is called when a JGoDocumentChangedEdit is created for a JGoDocumentEvent.CHANGED event, when a JGoObject has been changed. |
JGoObject |
copyObject(JGoCopyEnvironment env)
Copy the field values and the internal data structures to avoid sharing references |
protected void |
gainedSelection(JGoSelection selection)
Display the appropriate selected appearance. |
boolean |
getIntersectionWithLine(java.awt.geom.Point2D.Float p1,
java.awt.geom.Point2D.Float p2,
DoubleRef outval)
Finds the value that corresponds to the point where the scale and the line defined by p1 and p2 interesct. |
java.awt.Point |
getLabelCenter(double val,
boolean drawLeft)
Compute the label center to be appropriately positioned relative to the tick marks. |
protected double |
getLength()
The length must be measured along the circumference of the ellipse. |
java.awt.geom.Point2D.Float |
getPointForValue(double v)
Returns the point on the AbstractGraduatedScale that corresponds to the given value. |
double |
getStartAngle()
Gets the angle (in degrees) where the drawing of the GraduatedScaleElliptical begins. |
double |
getSweepAngle()
Gets the arc length (in degrees) through which the GraduatedScaleElliptical is drawn. |
void |
getTickEnds(double v,
boolean isMajor,
java.awt.geom.Point2D.Float outp1,
java.awt.geom.Point2D.Float outp2)
Calculates the two end points of a tick mark corresponding to the given value. |
double |
getValueAtPoint(java.awt.geom.Point2D.Float pf)
Returns the value that is associated with a point. |
protected java.awt.Rectangle |
handleResize(java.awt.Graphics2D g,
JGoView view,
java.awt.Rectangle origRect,
java.awt.Point newPoint,
int whichHandle,
int event,
int minWidth,
int minHeight)
Called when a user resizes this object; this updates the StartAngle and the SweepAngle if the user is resizing one of those two special resize handles. |
boolean |
isPointInObj(java.awt.Point p)
Determine if a given point is inside and on this object. |
void |
setStartAngle(double value)
Sets the angle (in degrees) where the drawing of the GraduatedScaleElliptical begins. |
void |
setSweepAngle(double value)
Sets the arc length (in degrees) through which the GraduatedScaleElliptical is drawn. |
DomNode |
SVGReadObject(DomDoc svgDoc,
JGoDocument jGoDoc,
DomElement svgElement,
DomElement jGoChildElement)
Read this object in from a DomDoc representing a Scalable Vector Graphics (SVG) XML document. |
void |
SVGWriteObject(DomDoc svgDoc,
DomElement jGoElementGroup)
Write this object out to a DomDoc representing a Scalable Vector Graphics (SVG) XML document. |
| Methods inherited from class com.nwoods.jgo.JGoDrawable |
draw3DRect, draw3DRect, drawEllipse, drawEllipse, drawEllipse, drawLine, drawLine, drawPath, drawPolygon, drawPolygon, drawRect, drawRect, drawRect, drawRoundRect, drawRoundRect, getBrush, getNearestIntersectionPoint, getPen, setBrush, setPen, SVGAddPathArgs, SVGReadAttributes, SVGWriteAttributes |
| Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Field Detail |
public static final int ChangedStartAngle
public static final int ChangedSweepAngle
| Constructor Detail |
public GraduatedScaleElliptical()
| Method Detail |
public JGoObject copyObject(JGoCopyEnvironment env)
copyObject in class AbstractGraduatedScaleenv - the environment for the copy operation - keeps track of copied objects.
public double getStartAngle()
public void setStartAngle(double value)
value - the value should be greater than or equal to -360 and less than 720public double getSweepAngle()
public void setSweepAngle(double value)
value - values are limited to the range of -360 and 360.
public boolean getIntersectionWithLine(java.awt.geom.Point2D.Float p1,
java.awt.geom.Point2D.Float p2,
DoubleRef outval)
getIntersectionWithLine in interface GraduatedScalegetIntersectionWithLine in class AbstractGraduatedScalep1 - a Point2D.Float in document coordinatesp2 - a Point2D.Float in document coordinatesoutval - a DoubleRef that is modified to hold the double value of the scale at the intersection point
public double getValueAtPoint(java.awt.geom.Point2D.Float pf)
getValueAtPoint in interface GraduatedScalegetValueAtPoint in class AbstractGraduatedScalepf - a Point2D.Float in document coordinates
public java.awt.geom.Point2D.Float getPointForValue(double v)
getPointForValue in interface GraduatedScalegetPointForValue in class AbstractGraduatedScalev -
protected java.awt.Rectangle handleResize(java.awt.Graphics2D g,
JGoView view,
java.awt.Rectangle origRect,
java.awt.Point newPoint,
int whichHandle,
int event,
int minWidth,
int minHeight)
handleResize in class JGoObjectg - a Graphics2Dview - the JGoVieworigRect - newPoint - whichHandle - event - minWidth - minHeight -
protected void gainedSelection(JGoSelection selection)
gainedSelection in class JGoObjectselection - public boolean isPointInObj(java.awt.Point p)
isPointInObj in class JGoObjectp -
protected void computePath(java.awt.geom.GeneralPath path)
computePath in class AbstractGraduatedScalepath - a GeneralPath that is modified
public void getTickEnds(double v,
boolean isMajor,
java.awt.geom.Point2D.Float outp1,
java.awt.geom.Point2D.Float outp2)
getTickEnds in class AbstractGraduatedScalev - the double-precision floating point value that the tick mark would representisMajor - whether to find the end points for a major or a minor tick markoutp1 - a Point2D.Float that is modified with one end pointoutp2 - a Point2D.Float that is modified with the other end point
public java.awt.Point getLabelCenter(double val,
boolean drawLeft)
getLabelCenter in class AbstractGraduatedScaleval - drawLeft -
protected double getLength()
getLength in class AbstractGraduatedScalepublic void copyNewValueForRedo(JGoDocumentChangedEdit e)
JGoObjectJust as the previous/old value/state information is stored as one or both of an integer and an Object, the new value/state information may be stored as either or both of an integer or an Object.
The responsibility for copying rests with the document event listener rather than the code calling JGoObject.update for efficiency when there is no undo/redo manager.
copyNewValueForRedo in class AbstractGraduatedScale
public void changeValue(JGoDocumentChangedEdit e,
boolean undo)
changeValue in class AbstractGraduatedScalee - undo -
public void SVGWriteObject(DomDoc svgDoc,
DomElement jGoElementGroup)
JGoXMLSaveRestoreThis method will be called by com.nwoods.jgo.svg.DefaultDocument.SVGWriteDoc() for every JGoObject contained within a JGoDocument. The following example uses a JGoRectangle to illustrate the format of a generated SVG JGoObject:
<g>
<JGoClass class="com.nwoods.jgo.JGoRectangle"\>
<rect height="75" style="stroke:black;stroke-width:1;fill:rgb(255,0,0);" width="75" x="65" y="71"/>
<JGoClass class="com.nwoods.jgo.JGoDrawable" drawablebrush="jgoid1" drawablepen="jgoid2" embeddedpenbrush="false"/>
<JGoClass class="com.nwoods.jgo.JGoObject" obj_flags="1054"/>
</g>
Note that the entire JGoObject is enclosed in a group (<g>). Each subclass of the JGoObject is described by a <JGoClass> element, starting with the most specific class and moving to the more general. Each <JGoClass> element has a "class" attribute which defines the class name. Each <JGoClass> element may also have several other attributes which uniquely describe that state of that class. Following the <JGoClass> element, each class may also genereate any other elements that are required, including representations of contained objects and standard SVG elements such as the <rect> element shown in the above example. The generation of SVG elements in the output makes it possible for the output to be read by SVG viewers and other SVG aware applications. The information contained in the <JGoClass> elements allows us to accurately save and restore all the information in a particular JGoObject subclass.
If this class contains a reference to another object, call DomDoc.registerReferencingNode() to register that reference. This will cause the element representing the referenced object to be identified with a unique id attribute, and cause the element representing the referring object to have a user defined attribute containing a reference to that id. See DomDoc.registerReferencingNode() for more information.
Typically, an implementation of this method will generate a <JGoClass> element using the DomDoc.createJGoClassElement() method, adding whatever attributes are necessary to describe the class. It will then call its superclass so that the superclass can add its own <JGoClass> element and other information to jGoElementGroup within the DomDoc.
Refer to com.nwoods.jgo.examples.flower.ActivityNode.SVGWriteObject() and com.nwoods.jgo.examples.SimpleNode.SVGWriteObject() for examples using this method.
Refer to the file com.nwoods.jgo.svg\xsvg.dtd for a formal description of JGo extensions to the SVG document type.
SVGWriteObject in interface JGoXMLSaveRestoreSVGWriteObject in class AbstractGraduatedScale
public DomNode SVGReadObject(DomDoc svgDoc,
JGoDocument jGoDoc,
DomElement svgElement,
DomElement jGoChildElement)
JGoXMLSaveRestoreThis method will be called by com.nwoods.jgo.svg.DefaultDocument.SVGReadDoc() for every <JGoClass> element encountered in a DomDoc. First, an object of the type specified by the class attribute will be created and then the SVGReadObject() method will be called on that newly created object. Refer to SVGWriteObject() for a description of the expected format of the SVG document.
This method may also be called by com.nwoods.jgo.svg.DefaultDocument.SVGReadDoc() when reading any SVG document, including those not generated by JGo and therefore not containing any <JGoClass> elements. In such cases, the DefaultDocument.SVGReadElement() method may be subclassed to examine the SVG element and cause the appropriate JGoObject to be created to represent that element and call SVGReadObject() on that newly created object. By default, standard JGoObjects such as JGoRectangles, JGoStrokes, etc will be created to represent these objects.
If this class contains a reference to another object, call DomDoc.registerReferencingObject() to register that reference. This will cause the JGoObject.SVGUpdateReference() to be called on the referencing object after all the objects have been created, passing in the object befing referenced. See DomDoc.registerReferencingObject() for more information.
Typically, an implementation of this method starts by verifying that the element being read is a <JGoClass> element (which will be true if jGoChildElement is not null). This will always be true unless you have subclassed the DefaultDocument.SVGReadElement() method as described above. It will then read the expected attributes of the <JGoClass> element (as written by SVGReadObject()), call SVGReadObject() on its superclass, and finally return the next element by calling svgElement.getNextSibling().
Refer to com.nwoods.jgo.examples.flower.ActivityNode.SVGReadObject() and com.nwoods.jgo.examples.SimpleNode.SVGReadObject() for examples using this method.
SVGReadObject in interface JGoXMLSaveRestoreSVGReadObject in class AbstractGraduatedScale
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||