| 
 | Search this API | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objecty.view.YLabel
y.view.EdgeLabel
public class EdgeLabel
This class represents a label associated with an EdgeRealizer.
EdgeLabel has special label models and positions that are suitable for placing the label along an edge path.
| Nested Class Summary | 
|---|
| Nested classes/interfaces inherited from class y.view.YLabel | 
|---|
| YLabel.BoundsProvider, YLabel.Factory, YLabel.Layout, YLabel.Painter, YLabel.SelectionChangeHandler, YLabel.UserDataHandler | 
| Field Summary | |
|---|---|
| static byte | ANYWHEREEdge label position specifier. | 
| static byte | CENTEREdge label position specifier. | 
| static byte | CENTER_RATIOEdge label position specifier. | 
| static byte | CENTER_SLIDEREdge label model specifier. | 
| static byte | CENTEREDEdge label model specifier. | 
| static byte | CUSTOM_LABEL_MODELEdge label model specifier that signals that a user-defined, custom EdgeLabelModelis used. | 
| static byte | DYNAMICEdge label position specifier for label models SIDE_SLIDERandCENTER_SLIDER. | 
| static byte | FREEEdge label model specifier. | 
| static byte | HEADEdge label position specifier. | 
| static byte | HEAD_RATIOEdge label position specifier. | 
| static byte | SCENTREdge label position specifier. | 
| static byte | SHEADEdge label position specifier. | 
| static byte | SIDE_SLIDEREdge label model specifier. | 
| static byte | SIX_POSEdge label model specifier. | 
| static byte | STAILEdge label position specifier. | 
| static byte | TAILEdge label position specifier. | 
| static byte | TAIL_RATIOEdge label position specifier. | 
| static byte | TCENTREdge label position specifier. | 
| static byte | THEADEdge label position specifier. | 
| static byte | THREE_CENTEREdge label model specifier. | 
| static byte | TTAILEdge label position specifier. | 
| static byte | TWO_POSEdge label model specifier. | 
| static byte | UNDEFINED | 
| Fields inherited from interface y.layout.LabelLayoutConstants | 
|---|
| PLACE_ANYWHERE, PLACE_AT_CENTER, PLACE_AT_SOURCE, PLACE_AT_TARGET, PLACE_LEFT_OF_EDGE, PLACE_ON_EDGE, PLACE_RIGHT_OF_EDGE, PLACEMENT_ALONG_EDGE_MASK, PLACEMENT_ON_SIDE_OF_EDGE_MASK | 
| Constructor Summary | |
|---|---|
| EdgeLabel()Default is visible label with empty text, model 2-pos | |
| EdgeLabel(String str)Default: CENTERED labeling and visible. | |
| EdgeLabel(String st,
          byte mode)Edge Label with positioning model mode. | |
| Method Summary | |
|---|---|
|  void | adoptValues(YLabel label)Adopts the values from the given label. | 
| static Vector | availablePositions(Byte model)Returns the possible edge label position specifiers for the given model. | 
|  void | bindRealizer(EdgeRealizer r)Binds the given edge realizer to this label. | 
|  void | calculateOffset()Calculates the offset coordinates of this label. | 
|  Object | clone()Returns a copy of this instance | 
|  Object | getBestModelParameterForBounds(OrientedRectangle bounds)Returns the best model parameter for this label such that the label's oriented boundswill match the specified bounds
 as closely as possible within the label's currentlabel model. | 
|  Object | getBestModelParameterForLocation(double x,
                                 double y)Returns the best model parameter for this label at the given location. | 
|  Object | getBestModelParameterForOffset(double offsetX,
                               double offsetY)Returns the best model parameter for this label with the given offset. | 
|  double | getDistance()Returns the distance of the label to the edge. | 
|  Edge | getEdge()Returns the Edge this EdgeLabel is associated with. | 
| static YLabel.Factory | getFactory()Retrieves the factory instance that can be used to store different configurationsof pluggable node label behaviors. | 
| protected  Graph2D | getGraph2D()Returns that Graph2D instance that owns the Edge this edge is associated with or nullif this label is not associated with an Edge. | 
|  EdgeLabelModel | getLabelModel()Returns the edge label model that determines the placement of this label instance. | 
|  Object | getModelParameter()Returns the current parameter of the edge label model. | 
|  byte[] | getModelPositions()Returns the possible positions for the model that is set for this label instance. | 
| static byte[] | getModelPositions(byte model)Returns the possible edge label position specifiers for the given model specifier. | 
|  OrientedRectangle | getOrientedBox()Returns the label's oriented bounding box. | 
|  EdgeRealizer | getOwner()Returns the realizer that is bound to this edge label. | 
|  byte | getPosition()Returns the actual position of the label. | 
|  byte | getPreferredPlacement()Deprecated. use getPreferredPlacementDescriptor()instead. | 
|  PreferredPlacementDescriptor | getPreferredPlacementDescriptor()Determines a descriptor that holds information about where, on which side of the edge and with which orientation to place the edge label, preferably. | 
|  double | getRatio()Returns the source-target distance ratio of the label. | 
|  EdgeRealizer | getRealizer()Returns the realizer that is bound to this edge label. | 
|  boolean | hasFreePositioning()Determines whether or not this label has free positioning. | 
|  boolean | hasSliderPositioning()Determines whether the model is CENTER_SLIDERorSIDE_SLIDER. | 
| static Map | modelToStringMap()Creates a map that maps the model constants to strings. | 
| static Map | positionToStringMap()Creates a map that maps the position constants to strings. | 
| static Map | preferredPlacementsToStringMap()Creates a map that maps the preferred placement constant to strings. | 
|  void | read(ObjectInputStream in)Deprecated. Use the GraphML formatinstead. | 
|  void | repaint()Triggers a repaint of the bounds of this label in all views. | 
|  void | setConfiguration(String name)Configures this instance to use the configuration specified by the given name. | 
|  void | setDistance(double _distance)Sets the distance of the label to the edge. | 
|  void | setLabelModel(EdgeLabelModel m)Deprecated. Use setLabelModel(y.layout.EdgeLabelModel, Object)instead. | 
|  void | setLabelModel(EdgeLabelModel m,
              Object p)Sets the edgeLabelModelimplementation and a suitable
 model parameter. | 
|  void | setModel(byte mo)Sets the placement model for this label. | 
|  void | setModelParameter(Object param)Sets the current parameter for the edge label model. | 
|  void | setOffset(double x,
          double y)Deprecated. Client code should not set a label's offset directly, but rather use getBestModelParameterForBounds(y.geom.OrientedRectangle)andsetModelParameter(Object)to create and specify a parameter that
 represents the desired label position in the label's model. | 
|  void | setOffsetDirty()Marks the label offsets as dirty. | 
|  void | setPosition(byte p)Determines which position the label should have in relation to the node. | 
|  void | setPreferredPlacement(byte placement)Deprecated. use setPreferredPlacementDescriptor(y.layout.PreferredPlacementDescriptor)instead. | 
|  void | setPreferredPlacementDescriptor(PreferredPlacementDescriptor descriptor)Specifies a descriptor that holds information about where, on which side of the edge, and with which orientation to place edge label, preferably. | 
|  void | setRatio(double rat)Sets the source-target distance ratio of the label. | 
|  void | setSizeDirty()Marks the size of the label as dirty | 
|  void | setText(String text)Sets the text of this edge label. | 
|  void | write(ObjectOutputStream out)Deprecated. Use the GraphML formatinstead. | 
| Methods inherited from class java.lang.Object | 
|---|
| equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Methods inherited from interface y.layout.LabelLayout | 
|---|
| getBox | 
| Field Detail | 
|---|
public static final byte HEAD
public static final byte TAIL
public static final byte CENTER
public static final byte SHEAD
public static final byte THEAD
public static final byte STAIL
public static final byte TTAIL
public static final byte SCENTR
public static final byte TCENTR
public static final byte ANYWHERE
public static final byte CENTER_RATIO
public static final byte TAIL_RATIO
public static final byte HEAD_RATIO
public static final byte DYNAMIC
SIDE_SLIDER
 and CENTER_SLIDER.
 Places the label dynamically.
public static final byte UNDEFINED
public static final byte TWO_POS
HEAD and TAIL.
setModel(byte), 
Constant Field Valuespublic static final byte CENTERED
CENTER.
setModel(byte), 
Constant Field Valuespublic static final byte SIX_POS
HEAD, SHEAD, THEAD,
 TAIL, STAIL and TTAIL.
setModel(byte), 
Constant Field Valuespublic static final byte THREE_CENTER
CENTER, SCENTR and TCENTR.
setModel(byte), 
Constant Field Valuespublic static final byte FREE
ANYWHERE.
setModel(byte), 
Constant Field Valuespublic static final byte CENTER_SLIDER
DYNAMIC.
setModel(byte), 
Constant Field Valuespublic static final byte SIDE_SLIDER
DYNAMIC.
setModel(byte), 
Constant Field Valuespublic static final byte CUSTOM_LABEL_MODEL
EdgeLabelModel is used.
 This specifier should not be used directly, rather a custom
 NodeLabelModel should be set using
 setLabelModel(y.layout.EdgeLabelModel,java.lang.Object).
 
 Note:
 When copying/cloning an edge label (via adoptValues(YLabel)),
 custom label models are copied by reference. I.e. the original/prototype
 label instance and the copied label instance will share the custom model
 instance.
 
| Constructor Detail | 
|---|
public EdgeLabel(String st,
                 byte mode)
public EdgeLabel(String str)
public EdgeLabel()
| Method Detail | 
|---|
public Object clone()
clone in class Objectpublic void adoptValues(YLabel label)
adoptValues in class YLabelpublic void calculateOffset()
calculateOffset in class YLabelpublic void setText(String text)
setText in class YLabelpublic void setDistance(double _distance)
public void setOffset(double x,
                      double y)
getBestModelParameterForBounds(y.geom.OrientedRectangle) and
 setModelParameter(Object) to create and specify a parameter that
 represents the desired label position in the label's model.
source intersection point of
 the label's edge.
 Invoking this method is equivalent to calling
 setOffset(new OrientedRectangle(x, y + height, width, height));
setOffset in class YLabelx - the x-offset of the upper left corner of a paraxial rectangle
 relative to the x-coordinate of the
 source intersection point of
 the label's edge.y - the y-offset of the upper left corner of a paraxial rectangle
 relative to the y-coordinate of the
 source intersection point of
 the label's edge.public double getDistance()
public void setPreferredPlacement(byte placement)
setPreferredPlacementDescriptor(y.layout.PreferredPlacementDescriptor) instead.
 Defaults to LabelLayoutConstants.PLACE_ANYWHERE.
 
 Note: Invoking this method will replace the edge label's
 preferred placement descriptor
 with an immutable
 descriptor instance
 corresponding
 to the specified placement mask.
 
placement - an ORed combination of
 LabelLayoutConstants.PLACE_ANYWHERE, LabelLayoutConstants.PLACE_AT_SOURCE,
 LabelLayoutConstants.PLACE_AT_TARGET, or LabelLayoutConstants.PLACE_AT_CENTER and 
 LabelLayoutConstants.PLACE_LEFT_OF_EDGE, LabelLayoutConstants.PLACE_RIGHT_OF_EDGE, or
 LabelLayoutConstants.PLACE_ON_EDGE.setPreferredPlacement(byte)public byte getPreferredPlacement()
getPreferredPlacementDescriptor() instead.
 Defaults to LabelLayoutConstants.PLACE_ANYWHERE.
 
LabelLayoutConstants.PLACE_ANYWHERE, LabelLayoutConstants.PLACE_AT_SOURCE,
 LabelLayoutConstants.PLACE_AT_TARGET, or LabelLayoutConstants.PLACE_AT_CENTER and 
 LabelLayoutConstants.PLACE_LEFT_OF_EDGE, LabelLayoutConstants.PLACE_RIGHT_OF_EDGE, or
 LabelLayoutConstants.PLACE_ON_EDGE.setPreferredPlacement(byte)public PreferredPlacementDescriptor getPreferredPlacementDescriptor()
 Note: The default descriptor is
 immutable.
 Moreover, a cloned label shares the original label's
 descriptor instance. (Most notably, labels are cloned when
 copying an
 EdgeRealizer instance with labels.)
 Therefore client code should set a new descriptor instance to adjust
 preferred placement of edge labels.
 
getPreferredPlacementDescriptor in interface EdgeLabelLayoutsetPreferredPlacementDescriptor(y.layout.PreferredPlacementDescriptor)public void setPreferredPlacementDescriptor(PreferredPlacementDescriptor descriptor)
IllegalArgumentException - if the specified descriptor is
 null.descriptor - the new preferred placement descriptor.getPreferredPlacementDescriptor()public double getRatio()
setRatio(double)public void setRatio(double rat)
getRatio()public Object getBestModelParameterForBounds(OrientedRectangle bounds)
oriented bounds will match the specified bounds
 as closely as possible within the label's current label model.
 This method will return null if no suitable parameter can be
 determined (e.g. if this label is not associated to a "live" edge).
getBestModelParameterForBounds in class YLabelbounds - the desired label bounds in absolute world coordinates.
null if no suitable model parameter could
 be determined.
public Object getBestModelParameterForOffset(double offsetX,
                                             double offsetY)
offsetX - the offset in x-direction from the source intersection point
 of this label's associated edge to the desired label bounds.offsetY - the offset in y-direction from the source intersection point
 of this label's associated edge to the desired label bounds.
public Object getBestModelParameterForLocation(double x,
                                               double y)
x - the x-coordinate of the upper left corner of the desired label
 bounds.y - the y-coordinate of the upper left corner of the desired label
 bounds.
public boolean hasFreePositioning()
 label.setModelParameter(label.getBestModelParameterForBounds(newBounds));
 
 with an OrientedRectangle newBounds
 that specifies the desired position (and orientation) for the label.
public boolean hasSliderPositioning()
CENTER_SLIDER or SIDE_SLIDER.
public void setModel(byte mo)
 Note:
 Client code should not use CUSTOM_LABEL_MODEL here.
 Custom edge label models should be set using
 setLabelModel(y.layout.EdgeLabelModel,java.lang.Object).
 
setModel in class YLabelmo - one of
 public byte getPosition()
getPosition in class YLabelpublic void setPosition(byte p)
setPosition in class YLabelpublic static Map modelToStringMap()
public static Map positionToStringMap()
public static Map preferredPlacementsToStringMap()
public static final byte[] getModelPositions(byte model)
model - An edge label model specifier.
public byte[] getModelPositions()
public static Vector availablePositions(Byte model)
model - A Byte whose byte value represents a valid edge label model specifier.public Edge getEdge()
protected Graph2D getGraph2D()
null
 if this label is not associated with an Edge.
public EdgeRealizer getRealizer()
getOwner().
EdgeRealizer.addLabel(EdgeLabel), 
bindRealizer(EdgeRealizer)public EdgeRealizer getOwner()
EdgeRealizer.addLabel(EdgeLabel), 
bindRealizer(EdgeRealizer)public void bindRealizer(EdgeRealizer r)
r - the realizer to which this label will be associated.public EdgeLabelModel getLabelModel()
getLabelModel in interface EdgeLabelLayoutpublic Object getModelParameter()
getModelParameter in interface LabelLayoutpublic void setModelParameter(Object param)
setModelParameter in interface LabelLayoutsetModelParameter in class YLabelparam - the model parameter that determines the placement of this
 label instance.public void setLabelModel(EdgeLabelModel m)
setLabelModel(y.layout.EdgeLabelModel, Object) instead.
public void setLabelModel(EdgeLabelModel m,
                          Object p)
edgeLabelModel implementation and a suitable
 model parameter.
 
 Additionally, this realizer's model property is updated
 according to the specified EdgeLabelModel:
 
DiscreteEdgeLabelModel,
 the model property will be set to one of TWO_POS,
 CENTERED, SIX_POS, or THREE_CENTER as
 appropriate for the model's candidate mask.FreeEdgeLabelModel,
 the model property will be set to FREE.SliderEdgeLabelModel,
 the model property will be set to CENTER_SLIDER or
 SIDE_SLIDER as appropriate for the model's mode.
 For all other EdgeLabelModel implementations (including
 subclasses of the above mentioned types),
 the model property will be set to CUSTOM_LABEL_MODEL.
 
m - the EdgeLabelModel implementation to be used.p - a model parameter suitable for the specified label model.public void setOffsetDirty()
YLabel
setOffsetDirty in class YLabelpublic void setSizeDirty()
YLabel
setSizeDirty in class YLabelpublic OrientedRectangle getOrientedBox()
offset relative to the
 source intersection
 point of the label's associated realizer.
 The oriented box is given in absolute world coordinates.
getOrientedBox in interface LabelLayoutgetOrientedBox in class YLabelYLabel.getContentBox()public void repaint()
repaint in class YLabelYLabel.getBox(), 
View.updateView(double, double, double, double)
public void write(ObjectOutputStream out)
           throws IOException
GraphML format instead.
YLabel
write in class YLabelIOException
public void read(ObjectInputStream in)
          throws IOException,
                 ClassNotFoundException
GraphML format instead.
YLabelYLabel.write(ObjectOutputStream) method.
read in class YLabelIOException
ClassNotFoundExceptionpublic void setConfiguration(String name)
YLabelNodeLabel.getFactory()
 and getFactory() respectively.
setConfiguration in class YLabelname - the name of the configuration as it has been specified in YLabel.Factory.addConfiguration(String, java.util.Map)YLabel.Factory, 
YLabel.Factory.addConfiguration(String, java.util.Map)public static YLabel.Factory getFactory()
configurations
 of pluggable node label behaviors.
YLabel.Factory.addConfiguration(String, java.util.Map), 
setConfiguration(String)| 
 | © Copyright 2000-2013, yWorks GmbH. All rights reserved. | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||