| Home » Eclipse Projects » GEF » Is it possible to have two figures attached to the same model?
 Goto Forum:| 
| Is it possible to have two figures attached to the same model? [message #48485] | Sun, 08 December 2002 20:38  |  | 
| Eclipse User  |  |  |  |  | Originally posted by: rspbr.hotmail.com 
 Hi,
 
 I'm trying to implement an editor that shows a figure for a particular
 element of a model and a label for that figure.
 
 The problem is that I wished that the label could be manipulated as an
 independent figure - the user should be able to move it around separately
 from the "main" figure, allowing him to better place the labels to avoid
 collisions.
 
 Even better than that: Would it be possible to have that label to act like a
 connection figure? I mean, the user can modify it but when the main figure
 is selected the label is unselected?
 
 I was trying to "brute force" adding those extra labels by overriding the
 add(IEditorPart) method, but without success. Anybody has any idea on the
 right way of doing this?
 
 Thanks for any help,
 Ricardo
 
 
 ---
 
 Checked by AVG anti-virus system (http://www.grisoft.com).
 Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 |  |  |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #48576 is a reply to message #48517] | Mon, 09 December 2002 14:13   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: rspbr.hotmail.com 
 Hi,
 
 > Can you give a better description of what you want to do? Instead of
 > describing the behavior completely, maybe there is another program that
 does
 > the same thing.
 
 Well, I'm working in a complete Petri net editor for Eclipse. Normally,
 places and transitions have a label associated to them, but this label has
 to be "moveable" so users can place them out of the arcs' way.
 
 The problem is that I'm having trouble adding this label as an independent
 figure. For example, the idea is to have a figure (EllipseFigure) that
 represents the place and a figure (Label) to display the place's label.
 
 The question is: how to make this label independent from the ellipse, even
 if they do refer to the same model?
 
 At a later time, I wish that the label would behave like connections. That
 means: user can select it directly and move it around, but when a marquee
 selection is made, the labels are excluded.
 
 That way I could update the position of the label each time that the ellipse
 is moved around. The label would have then a "relative" position to the
 ellipse instead of an "absolute" position to the canvas.
 
 Thanks again for any help,
 Ricardo
 
 
 ---
 
 Checked by AVG anti-virus system (http://www.grisoft.com).
 Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #48606 is a reply to message #48576] | Mon, 09 December 2002 20:23   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: hudsonr.us.eye-bee-em.com 
 I've had to do the same thing in an Editor.  Basically, I made the labels
 child EditParts to the things which they label (connection or node). It
 isn't really a child in the model, so the EditPart returns a bogus list of
 model children (one for each label), which are simply strings.  You could
 make something more elaborate, but I didn't see the point.
 
 List getModelChildren() {
 ArrayList list = new ArrayList();
 list.add("Source label");
 list.add("Target label");
 return list;
 }
 
 Now, for each item in the List, and you may have just one, an EditPart needs
 to get created. So, you can override createEditPart(Object model) in that
 EditPart, and instantiate a LabelEditPart, passing it the real model (the
 node or connection), and perhaps the label type if you display 2 or more
 labels.
 
 If you want to prevent these EditParts from getting found by Marquee, please
 open a bugzilla, and any suggestions are welcome.
 
 "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 news:at2pr9$a19$1@rogue.oti.com...
 > Hi,
 >
 > > Can you give a better description of what you want to do? Instead of
 > > describing the behavior completely, maybe there is another program that
 > does
 > > the same thing.
 >
 > Well, I'm working in a complete Petri net editor for Eclipse. Normally,
 > places and transitions have a label associated to them, but this label has
 > to be "moveable" so users can place them out of the arcs' way.
 >
 > The problem is that I'm having trouble adding this label as an independent
 > figure. For example, the idea is to have a figure (EllipseFigure) that
 > represents the place and a figure (Label) to display the place's label.
 >
 > The question is: how to make this label independent from the ellipse, even
 > if they do refer to the same model?
 >
 > At a later time, I wish that the label would behave like connections. That
 > means: user can select it directly and move it around, but when a marquee
 > selection is made, the labels are excluded.
 >
 > That way I could update the position of the label each time that the
 ellipse
 > is moved around. The label would have then a "relative" position to the
 > ellipse instead of an "absolute" position to the canvas.
 >
 > Thanks again for any help,
 > Ricardo
 >
 >
 > ---
 >
 > Checked by AVG anti-virus system (http://www.grisoft.com).
 > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 >
 >
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #49356 is a reply to message #48606] | Thu, 12 December 2002 17:49   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: rspbr.hotmail.com 
 Hi,
 
 Thanks for the help, but (correct me if I'm wrong) this method creates the
 label _inside_ the "parent" figure (in terms of painting). What I had in
 mind was something like a label that could be moved outside the boundaries
 of the parent figure and still be visible.
 
 Any suggestions?
 
 "Randy Hudson" <hudsonr@us.eye-bee-em.com> wrote in message
 news:at3fhc$m7k$1@rogue.oti.com...
 > I've had to do the same thing in an Editor.  Basically, I made the labels
 > child EditParts to the things which they label (connection or node). It
 > isn't really a child in the model, so the EditPart returns a bogus list of
 > model children (one for each label), which are simply strings.  You could
 > make something more elaborate, but I didn't see the point.
 >
 > List getModelChildren() {
 >     ArrayList list = new ArrayList();
 >     list.add("Source label");
 >     list.add("Target label");
 >     return list;
 > }
 >
 > Now, for each item in the List, and you may have just one, an EditPart
 needs
 > to get created. So, you can override createEditPart(Object model) in that
 > EditPart, and instantiate a LabelEditPart, passing it the real model (the
 > node or connection), and perhaps the label type if you display 2 or more
 > labels.
 >
 > If you want to prevent these EditParts from getting found by Marquee,
 please
 > open a bugzilla, and any suggestions are welcome.
 >
 > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > news:at2pr9$a19$1@rogue.oti.com...
 > > Hi,
 > >
 > > > Can you give a better description of what you want to do? Instead of
 > > > describing the behavior completely, maybe there is another program
 that
 > > does
 > > > the same thing.
 > >
 > > Well, I'm working in a complete Petri net editor for Eclipse. Normally,
 > > places and transitions have a label associated to them, but this label
 has
 > > to be "moveable" so users can place them out of the arcs' way.
 > >
 > > The problem is that I'm having trouble adding this label as an
 independent
 > > figure. For example, the idea is to have a figure (EllipseFigure) that
 > > represents the place and a figure (Label) to display the place's label.
 > >
 > > The question is: how to make this label independent from the ellipse,
 even
 > > if they do refer to the same model?
 > >
 > > At a later time, I wish that the label would behave like connections.
 That
 > > means: user can select it directly and move it around, but when a
 marquee
 > > selection is made, the labels are excluded.
 > >
 > > That way I could update the position of the label each time that the
 > ellipse
 > > is moved around. The label would have then a "relative" position to the
 > > ellipse instead of an "absolute" position to the canvas.
 > >
 > > Thanks again for any help,
 > > Ricardo
 > >
 > >
 > > ---
 > >
 > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > >
 > >
 >
 >
 
 
 ---
 
 Checked by AVG anti-virus system (http://www.grisoft.com).
 Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #49446 is a reply to message #49356] | Fri, 13 December 2002 09:28   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: hudsonr.us.eye-bee-em.com 
 For a connection, children can be anywhere, and the connections bounds will
 automatically include the children.
 
 For a node, you could do some work to make the children EditParts have
 Figures that are *not* children.  You would have to override
 addChildVisual(), removeChildVisual().  Perhaps these methods would place
 the labels on another layer, instead of inside the contents pane. You need
 to be sure that these figures are removed when the EditPart is removed.
 This won't happen automatically, since the figures aren't contained, so you
 would have to override removeNotify().
 
 "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 news:atb3js$k0$1@rogue.oti.com...
 > Hi,
 >
 > Thanks for the help, but (correct me if I'm wrong) this method creates the
 > label _inside_ the "parent" figure (in terms of painting). What I had in
 > mind was something like a label that could be moved outside the boundaries
 > of the parent figure and still be visible.
 >
 > Any suggestions?
 >
 > "Randy Hudson" <hudsonr@us.eye-bee-em.com> wrote in message
 > news:at3fhc$m7k$1@rogue.oti.com...
 > > I've had to do the same thing in an Editor.  Basically, I made the
 labels
 > > child EditParts to the things which they label (connection or node). It
 > > isn't really a child in the model, so the EditPart returns a bogus list
 of
 > > model children (one for each label), which are simply strings.  You
 could
 > > make something more elaborate, but I didn't see the point.
 > >
 > > List getModelChildren() {
 > >     ArrayList list = new ArrayList();
 > >     list.add("Source label");
 > >     list.add("Target label");
 > >     return list;
 > > }
 > >
 > > Now, for each item in the List, and you may have just one, an EditPart
 > needs
 > > to get created. So, you can override createEditPart(Object model) in
 that
 > > EditPart, and instantiate a LabelEditPart, passing it the real model
 (the
 > > node or connection), and perhaps the label type if you display 2 or more
 > > labels.
 > >
 > > If you want to prevent these EditParts from getting found by Marquee,
 > please
 > > open a bugzilla, and any suggestions are welcome.
 > >
 > > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > > news:at2pr9$a19$1@rogue.oti.com...
 > > > Hi,
 > > >
 > > > > Can you give a better description of what you want to do? Instead of
 > > > > describing the behavior completely, maybe there is another program
 > that
 > > > does
 > > > > the same thing.
 > > >
 > > > Well, I'm working in a complete Petri net editor for Eclipse.
 Normally,
 > > > places and transitions have a label associated to them, but this label
 > has
 > > > to be "moveable" so users can place them out of the arcs' way.
 > > >
 > > > The problem is that I'm having trouble adding this label as an
 > independent
 > > > figure. For example, the idea is to have a figure (EllipseFigure) that
 > > > represents the place and a figure (Label) to display the place's
 label.
 > > >
 > > > The question is: how to make this label independent from the ellipse,
 > even
 > > > if they do refer to the same model?
 > > >
 > > > At a later time, I wish that the label would behave like connections.
 > That
 > > > means: user can select it directly and move it around, but when a
 > marquee
 > > > selection is made, the labels are excluded.
 > > >
 > > > That way I could update the position of the label each time that the
 > > ellipse
 > > > is moved around. The label would have then a "relative" position to
 the
 > > > ellipse instead of an "absolute" position to the canvas.
 > > >
 > > > Thanks again for any help,
 > > > Ricardo
 > > >
 > > >
 > > > ---
 > > >
 > > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > > >
 > > >
 > >
 > >
 >
 >
 > ---
 >
 > Checked by AVG anti-virus system (http://www.grisoft.com).
 > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 >
 >
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #49475 is a reply to message #48606] | Fri, 13 December 2002 17:21   |  | 
| Eclipse User  |  |  |  |  | Hi! 
 I have the same need in my project.
 
 I have written a ConnectionLabelEditPart that creates a draw2d.Label and
 added a getModelChildren as you said below that returns a List of one
 String.
 
 Running this code I get a call to my EditPartFactory with this string as
 model and I returned a new ConnectionLabelEditPart here that get displayed
 in the window.
 
 But then I'm confused. Where can I override a createEditPart? This method is
 not part of EditPart. Do you mean createChild of the parent EditPart (a
 ConnectionEditPart in my case) and filter away this bogus model from getting
 to the EditPartFactory?
 This works for me, but I get an error later if I do setModel of the new
 ConnectionLabelEditPart to the ConnectionEditPart model.
 
 /Dag
 -
 "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 news:at3fhc$m7k$1@rogue.oti.com...
 > I've had to do the same thing in an Editor.  Basically, I made the labels
 > child EditParts to the things which they label (connection or node). It
 > isn't really a child in the model, so the EditPart returns a bogus list of
 > model children (one for each label), which are simply strings.  You could
 > make something more elaborate, but I didn't see the point.
 >
 > List getModelChildren() {
 >     ArrayList list = new ArrayList();
 >     list.add("Source label");
 >     list.add("Target label");
 >     return list;
 > }
 >
 > Now, for each item in the List, and you may have just one, an EditPart
 needs
 > to get created. So, you can override createEditPart(Object model) in that
 > EditPart, and instantiate a LabelEditPart, passing it the real model (the
 > node or connection), and perhaps the label type if you display 2 or more
 > labels.
 >
 > If you want to prevent these EditParts from getting found by Marquee,
 please
 > open a bugzilla, and any suggestions are welcome.
 >
 > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > news:at2pr9$a19$1@rogue.oti.com...
 > > Hi,
 > >
 > > > Can you give a better description of what you want to do? Instead of
 > > > describing the behavior completely, maybe there is another program
 that
 > > does
 > > > the same thing.
 > >
 > > Well, I'm working in a complete Petri net editor for Eclipse. Normally,
 > > places and transitions have a label associated to them, but this label
 has
 > > to be "moveable" so users can place them out of the arcs' way.
 > >
 > > The problem is that I'm having trouble adding this label as an
 independent
 > > figure. For example, the idea is to have a figure (EllipseFigure) that
 > > represents the place and a figure (Label) to display the place's label.
 > >
 > > The question is: how to make this label independent from the ellipse,
 even
 > > if they do refer to the same model?
 > >
 > > At a later time, I wish that the label would behave like connections.
 That
 > > means: user can select it directly and move it around, but when a
 marquee
 > > selection is made, the labels are excluded.
 > >
 > > That way I could update the position of the label each time that the
 > ellipse
 > > is moved around. The label would have then a "relative" position to the
 > > ellipse instead of an "absolute" position to the canvas.
 > >
 > > Thanks again for any help,
 > > Ricardo
 > >
 > >
 > > ---
 > >
 > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > >
 > >
 >
 >
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #49505 is a reply to message #49475] | Fri, 13 December 2002 17:39   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: hudsonr.us.eye-bee-em.com 
 "Dag Rende" <dag.rende@applied.se> wrote in message
 news:atdm5o$gag$1@rogue.oti.com...
 > Hi!
 >
 > I have the same need in my project.
 >
 > I have written a ConnectionLabelEditPart that creates a draw2d.Label and
 > added a getModelChildren as you said below that returns a List of one
 > String.
 >
 > Running this code I get a call to my EditPartFactory with this string as
 > model and I returned a new ConnectionLabelEditPart here that get displayed
 > in the window.
 >
 > But then I'm confused. Where can I override a createEditPart? This method
 is
 > not part of EditPart. Do you mean createChild of the parent EditPart (a
 > ConnectionEditPart in my case) and filter away this bogus model from
 getting
 > to the EditPartFactory?
 > This works for me, but I get an error later if I do setModel of the new
 > ConnectionLabelEditPart to the ConnectionEditPart model.
 
 Yes, I meant createChild().  What error do you get?
 You generally should set the model immediately on the LabelEditPart.
 
 > /Dag
 > -
 > "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 > news:at3fhc$m7k$1@rogue.oti.com...
 > > I've had to do the same thing in an Editor.  Basically, I made the
 labels
 > > child EditParts to the things which they label (connection or node). It
 > > isn't really a child in the model, so the EditPart returns a bogus list
 of
 > > model children (one for each label), which are simply strings.  You
 could
 > > make something more elaborate, but I didn't see the point.
 > >
 > > List getModelChildren() {
 > >     ArrayList list = new ArrayList();
 > >     list.add("Source label");
 > >     list.add("Target label");
 > >     return list;
 > > }
 > >
 > > Now, for each item in the List, and you may have just one, an EditPart
 > needs
 > > to get created. So, you can override createEditPart(Object model) in
 that
 > > EditPart, and instantiate a LabelEditPart, passing it the real model
 (the
 > > node or connection), and perhaps the label type if you display 2 or more
 > > labels.
 > >
 > > If you want to prevent these EditParts from getting found by Marquee,
 > please
 > > open a bugzilla, and any suggestions are welcome.
 > >
 > > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > > news:at2pr9$a19$1@rogue.oti.com...
 > > > Hi,
 > > >
 > > > > Can you give a better description of what you want to do? Instead of
 > > > > describing the behavior completely, maybe there is another program
 > that
 > > > does
 > > > > the same thing.
 > > >
 > > > Well, I'm working in a complete Petri net editor for Eclipse.
 Normally,
 > > > places and transitions have a label associated to them, but this label
 > has
 > > > to be "moveable" so users can place them out of the arcs' way.
 > > >
 > > > The problem is that I'm having trouble adding this label as an
 > independent
 > > > figure. For example, the idea is to have a figure (EllipseFigure) that
 > > > represents the place and a figure (Label) to display the place's
 label.
 > > >
 > > > The question is: how to make this label independent from the ellipse,
 > even
 > > > if they do refer to the same model?
 > > >
 > > > At a later time, I wish that the label would behave like connections.
 > That
 > > > means: user can select it directly and move it around, but when a
 > marquee
 > > > selection is made, the labels are excluded.
 > > >
 > > > That way I could update the position of the label each time that the
 > > ellipse
 > > > is moved around. The label would have then a "relative" position to
 the
 > > > ellipse instead of an "absolute" position to the canvas.
 > > >
 > > > Thanks again for any help,
 > > > Ricardo
 > > >
 > > >
 > > > ---
 > > >
 > > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > > >
 > > >
 > >
 > >
 >
 >
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #50308 is a reply to message #49505] | Tue, 17 December 2002 11:32   |  | 
| Eclipse User  |  |  |  |  | OK. Now I think I know how to do this. 
 In MyConnectionEditPart i override getModelChildren() and createChild(Object
 model).
 I let getModelChildren return a List of a unique object - a string for
 example. In createChild, i check if the model is the unique object above,
 and create MyConnectionLabelEditPart and set its model. Here it is important
 to not use the same model as for the parent (the MyConnectionEditPart),
 because GEF keeps a map of all models and their corresponding EditParts. If
 I use the same model for two edit parts GEF will not be able to find the
 right EditPart later on. In my test code i simply wrap the
 MyConnectionEditPart model in an array to get a unique object of it, and now
 it works.
 
 The above code is only a proof of concept, and places the label in the wrong
 position relative to the connection figure.
 What is left now to design is handling of placement of connection label
 figures, policies for moving them with the mouse, updating their text as the
 main model changes etc. I think the main ConnectionEditPart may take the
 reponsibility to create the label part and connect them with a Locator
 object that has an offset from midpoint o any end point so that the labels
 will be placed relative to the right part of the connection figure. The
 moving policy could then change the locator offset when the user uses the
 mose on the label.
 
 /Dag
 ------------
 Here is my test code for the above methods and the label edit part class:
 
 in MyCoonectionEditPart:
 /**
 * fake model children for the label
 */
 public List getModelChildren() {
 ArrayList list = new ArrayList();
 list.add("Connection label");
 return list;
 }
 
 /**
 * @see  org.eclipse.gef.editparts.AbstractEditPart#createChild(Objec t)
 */
 protected EditPart createChild(Object model) {
 if (model instanceof String
 && "Connection label".equals(model)) {
 EditPart editPart = new ConnectionLabelEditPart();
 editPart.setModel(new Object[] {getModel()});
 return editPart;
 }
 return super.createChild(model);
 }
 
 ---------------------
 public class AssociationLabelEditPart extends AbstractGraphicalEditPart {
 protected IFigure createFigure() {
 MyConnectionModel[] model = (MyConnectionModel[])getModel();
 IFigure labelFigure = new Label(model[0].getName());
 labelFigure.setOpaque(true);
 return labelFigure;
 }
 
 protected void createEditPolicies() {
 }
 }
 
 "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 news:atdnbk$gtp$1@rogue.oti.com...
 >
 > "Dag Rende" <dag.rende@applied.se> wrote in message
 > news:atdm5o$gag$1@rogue.oti.com...
 > > Hi!
 > >
 > > I have the same need in my project.
 > >
 > > I have written a ConnectionLabelEditPart that creates a draw2d.Label and
 > > added a getModelChildren as you said below that returns a List of one
 > > String.
 > >
 > > Running this code I get a call to my EditPartFactory with this string as
 > > model and I returned a new ConnectionLabelEditPart here that get
 displayed
 > > in the window.
 > >
 > > But then I'm confused. Where can I override a createEditPart? This
 method
 > is
 > > not part of EditPart. Do you mean createChild of the parent EditPart (a
 > > ConnectionEditPart in my case) and filter away this bogus model from
 > getting
 > > to the EditPartFactory?
 > > This works for me, but I get an error later if I do setModel of the new
 > > ConnectionLabelEditPart to the ConnectionEditPart model.
 >
 > Yes, I meant createChild().  What error do you get?
 > You generally should set the model immediately on the LabelEditPart.
 >
 > > /Dag
 > > -
 > > "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 > > news:at3fhc$m7k$1@rogue.oti.com...
 > > > I've had to do the same thing in an Editor.  Basically, I made the
 > labels
 > > > child EditParts to the things which they label (connection or node).
 It
 > > > isn't really a child in the model, so the EditPart returns a bogus
 list
 > of
 > > > model children (one for each label), which are simply strings.  You
 > could
 > > > make something more elaborate, but I didn't see the point.
 > > >
 > > > List getModelChildren() {
 > > >     ArrayList list = new ArrayList();
 > > >     list.add("Source label");
 > > >     list.add("Target label");
 > > >     return list;
 > > > }
 > > >
 > > > Now, for each item in the List, and you may have just one, an EditPart
 > > needs
 > > > to get created. So, you can override createEditPart(Object model) in
 > that
 > > > EditPart, and instantiate a LabelEditPart, passing it the real model
 > (the
 > > > node or connection), and perhaps the label type if you display 2 or
 more
 > > > labels.
 > > >
 > > > If you want to prevent these EditParts from getting found by Marquee,
 > > please
 > > > open a bugzilla, and any suggestions are welcome.
 > > >
 > > > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > > > news:at2pr9$a19$1@rogue.oti.com...
 > > > > Hi,
 > > > >
 > > > > > Can you give a better description of what you want to do? Instead
 of
 > > > > > describing the behavior completely, maybe there is another program
 > > that
 > > > > does
 > > > > > the same thing.
 > > > >
 > > > > Well, I'm working in a complete Petri net editor for Eclipse.
 > Normally,
 > > > > places and transitions have a label associated to them, but this
 label
 > > has
 > > > > to be "moveable" so users can place them out of the arcs' way.
 > > > >
 > > > > The problem is that I'm having trouble adding this label as an
 > > independent
 > > > > figure. For example, the idea is to have a figure (EllipseFigure)
 that
 > > > > represents the place and a figure (Label) to display the place's
 > label.
 > > > >
 > > > > The question is: how to make this label independent from the
 ellipse,
 > > even
 > > > > if they do refer to the same model?
 > > > >
 > > > > At a later time, I wish that the label would behave like
 connections.
 > > That
 > > > > means: user can select it directly and move it around, but when a
 > > marquee
 > > > > selection is made, the labels are excluded.
 > > > >
 > > > > That way I could update the position of the label each time that the
 > > > ellipse
 > > > > is moved around. The label would have then a "relative" position to
 > the
 > > > > ellipse instead of an "absolute" position to the canvas.
 > > > >
 > > > > Thanks again for any help,
 > > > > Ricardo
 > > > >
 > > > >
 > > > > ---
 > > > >
 > > > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > > > >
 > > > >
 > > >
 > > >
 > >
 > >
 >
 >
 |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #50454 is a reply to message #50308] | Wed, 18 December 2002 12:27   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: hudsonr.us.eye-bee-em.com 
 "Dag Rende" <dag.rende@applied.se> wrote in message
 news:atnj4v$fj2$1@rogue.oti.com...
 > OK. Now I think I know how to do this.
 >
 > In MyConnectionEditPart i override getModelChildren() and
 createChild(Object
 > model).
 > I let getModelChildren return a List of a unique object - a string for
 > example. In createChild, i check if the model is the unique object above,
 > and create MyConnectionLabelEditPart and set its model. Here it is
 important
 > to not use the same model as for the parent (the MyConnectionEditPart),
 > because GEF keeps a map of all models and their corresponding EditParts.
 If
 
 Actually, if one of the two EditParts does not require connection support
 (it is neither the source or target of connections), then you can prevent
 that EditPart from registering its model by overriding the appropriate
 method to do nothing.  The only reason EditParts are registered by model is
 so a Connection can find its source/target. This will remove the collision
 you describe, and you can use the same model for both.
 
 > I use the same model for two edit parts GEF will not be able to find the
 > right EditPart later on. In my test code i simply wrap the
 > MyConnectionEditPart model in an array to get a unique object of it, and
 now
 > it works.
 >
 > The above code is only a proof of concept, and places the label in the
 wrong
 > position relative to the connection figure.
 > What is left now to design is handling of placement of connection label
 > figures, policies for moving them with the mouse, updating their text as
 the
 > main model changes etc. I think the main ConnectionEditPart may take the
 > reponsibility to create the label part and connect them with a Locator
 > object that has an offset from midpoint o any end point so that the labels
 > will be placed relative to the right part of the connection figure. The
 > moving policy could then change the locator offset when the user uses the
 > mose on the label.
 
 We provide half of this already in ConnectionEndpointLocator.  This locator
 supports an offset from the node (u distance), and an offset from the
 connection (v distance).  You would still have to write your own
 NonResizableEditPolicy to interpret "move" requests, and re-calculate the
 new U and V values.  This would imply that you have the inverse algorithm of
 our ConnecitonEndpointLocator . . . good luck!  Feel free to submit anything
 you come up with.
 
 >
 > /Dag
 > ------------
 > Here is my test code for the above methods and the label edit part class:
 >
 > in MyCoonectionEditPart:
 > /**
 > * fake model children for the label
 > */
 > public List getModelChildren() {
 >   ArrayList list = new ArrayList();
 >   list.add("Connection label");
 >   return list;
 > }
 >
 > /**
 > * @see  org.eclipse.gef.editparts.AbstractEditPart#createChild(Objec t)
 > */
 > protected EditPart createChild(Object model) {
 >   if (model instanceof String
 >     && "Connection label".equals(model)) {
 >     EditPart editPart = new ConnectionLabelEditPart();
 >     editPart.setModel(new Object[] {getModel()});
 >     return editPart;
 >   }
 >   return super.createChild(model);
 > }
 >
 > ---------------------
 > public class AssociationLabelEditPart extends AbstractGraphicalEditPart {
 >   protected IFigure createFigure() {
 >     MyConnectionModel[] model = (MyConnectionModel[])getModel();
 >     IFigure labelFigure = new Label(model[0].getName());
 >     labelFigure.setOpaque(true);
 >     return labelFigure;
 >   }
 >
 >   protected void createEditPolicies() {
 >   }
 > }
 >
 > "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 > news:atdnbk$gtp$1@rogue.oti.com...
 > >
 > > "Dag Rende" <dag.rende@applied.se> wrote in message
 > > news:atdm5o$gag$1@rogue.oti.com...
 > > > Hi!
 > > >
 > > > I have the same need in my project.
 > > >
 > > > I have written a ConnectionLabelEditPart that creates a draw2d.Label
 and
 > > > added a getModelChildren as you said below that returns a List of one
 > > > String.
 > > >
 > > > Running this code I get a call to my EditPartFactory with this string
 as
 > > > model and I returned a new ConnectionLabelEditPart here that get
 > displayed
 > > > in the window.
 > > >
 > > > But then I'm confused. Where can I override a createEditPart? This
 > method
 > > is
 > > > not part of EditPart. Do you mean createChild of the parent EditPart
 (a
 > > > ConnectionEditPart in my case) and filter away this bogus model from
 > > getting
 > > > to the EditPartFactory?
 > > > This works for me, but I get an error later if I do setModel of the
 new
 > > > ConnectionLabelEditPart to the ConnectionEditPart model.
 > >
 > > Yes, I meant createChild().  What error do you get?
 > > You generally should set the model immediately on the LabelEditPart.
 > >
 > > > /Dag
 > > > -
 > > > "Randy Hudson" <hudsonr@us.eye-bee-em.com> skrev i meddelandet
 > > > news:at3fhc$m7k$1@rogue.oti.com...
 > > > > I've had to do the same thing in an Editor.  Basically, I made the
 > > labels
 > > > > child EditParts to the things which they label (connection or node).
 > It
 > > > > isn't really a child in the model, so the EditPart returns a bogus
 > list
 > > of
 > > > > model children (one for each label), which are simply strings.  You
 > > could
 > > > > make something more elaborate, but I didn't see the point.
 > > > >
 > > > > List getModelChildren() {
 > > > >     ArrayList list = new ArrayList();
 > > > >     list.add("Source label");
 > > > >     list.add("Target label");
 > > > >     return list;
 > > > > }
 > > > >
 > > > > Now, for each item in the List, and you may have just one, an
 EditPart
 > > > needs
 > > > > to get created. So, you can override createEditPart(Object model) in
 > > that
 > > > > EditPart, and instantiate a LabelEditPart, passing it the real model
 > > (the
 > > > > node or connection), and perhaps the label type if you display 2 or
 > more
 > > > > labels.
 > > > >
 > > > > If you want to prevent these EditParts from getting found by
 Marquee,
 > > > please
 > > > > open a bugzilla, and any suggestions are welcome.
 > > > >
 > > > > "Ricardo Sangoi Padilha" <rspbr@hotmail.com> wrote in message
 > > > > news:at2pr9$a19$1@rogue.oti.com...
 > > > > > Hi,
 > > > > >
 > > > > > > Can you give a better description of what you want to do?
 Instead
 > of
 > > > > > > describing the behavior completely, maybe there is another
 program
 > > > that
 > > > > > does
 > > > > > > the same thing.
 > > > > >
 > > > > > Well, I'm working in a complete Petri net editor for Eclipse.
 > > Normally,
 > > > > > places and transitions have a label associated to them, but this
 > label
 > > > has
 > > > > > to be "moveable" so users can place them out of the arcs' way.
 > > > > >
 > > > > > The problem is that I'm having trouble adding this label as an
 > > > independent
 > > > > > figure. For example, the idea is to have a figure (EllipseFigure)
 > that
 > > > > > represents the place and a figure (Label) to display the place's
 > > label.
 > > > > >
 > > > > > The question is: how to make this label independent from the
 > ellipse,
 > > > even
 > > > > > if they do refer to the same model?
 > > > > >
 > > > > > At a later time, I wish that the label would behave like
 > connections.
 > > > That
 > > > > > means: user can select it directly and move it around, but when a
 > > > marquee
 > > > > > selection is made, the labels are excluded.
 > > > > >
 > > > > > That way I could update the position of the label each time that
 the
 > > > > ellipse
 > > > > > is moved around. The label would have then a "relative" position
 to
 > > the
 > > > > > ellipse instead of an "absolute" position to the canvas.
 > > > > >
 > > > > > Thanks again for any help,
 > > > > > Ricardo
 > > > > >
 > > > > >
 > > > > > ---
 > > > > >
 > > > > > Checked by AVG anti-virus system (http://www.grisoft.com).
 > > > > > Version: 6.0.427 / Virus Database: 240 - Release Date: 6/12/2002
 > > > > >
 > > > > >
 > > > >
 > > > >
 > > >
 > > >
 > >
 > >
 >
 >
 |  |  |  |  |  |  |  |  | 
| Re: Is it possible to have two figures attached to the same model? [message #59616 is a reply to message #59595] | Wed, 29 January 2003 11:43  |  | 
| Eclipse User  |  |  |  |  | Originally posted by: none.us.ibm.com 
 "Randy Hudson" <none@us.ibm.com> wrote in message
 news:b18v93$2lh$1@rogue.oti.com...
 > Selecting just the label is useful in programs like Rational Rose, where
 the
 > user can say that he doesn't want to see the multiplicity label by
 deleting
 > it.
 >
 > Go back and read my original suggestions.  Making the labels children of
 the
 > connection is the easiest way to do this.
 >
 >
 
 To clarify "this" == what you are describing, as well as the behavior of
 Rational Rose.  i.e. either way.
 |  |  |  | 
 
 
 Current Time: Sat Oct 25 05:52:49 EDT 2025 
 Powered by FUDForum . Page generated in 0.05630 seconds |