#2506 closed enhancement (fixed)
Keep connecting lines manhattanized
Reported by: | massimo ceraolo | Owned by: | Adeel Asghar |
---|---|---|---|
Priority: | normal | Milestone: | 1.9.2 |
Component: | OMEdit | Version: | trunk |
Keywords: | Cc: |
Description
Connecting lines must typically stay manhattanized (i.e. horziontal or vertical, not oblique) when components are dragged.
However, very often OMEdit creates strange lines, with several oblique segments.
For instance try moving around the components of the enclosed circuit.
I think that OMEdit should keep lines manhattanized when dragging, at least as an option.
Attachments (1)
Change History (15)
by , 11 years ago
comment:1 by , 11 years ago
comment:2 by , 11 years ago
Priority: | low → normal |
---|
comment:3 by , 10 years ago
Two additions to my original post on this issue.
1) I've checked that connecting lines don't stay manhattanised in models originally created in Dymola. I din not observe this behaviour in models originally drawn in OMEdit.
Is this issue caused by non-standard annotations from Dymola or it is an OM issue?
2) When I first posted this thicket I tried to move objects with mouse.
I've recently also found that (on the attached RLC.mo model( if we try to move objects with keyboard arrows an even stranger behaviour is observed! (r20668)
comment:4 by , 10 years ago
A good management of manhattanized connections should make sure that one can start from the RLC model posted above (which is written in perfectly legal and standard Modelica) and move any of its components so that:
- the motion takes place on a step-2 grid (currently it is much more than that)
- manhattanized connections are preserved as such, and not transformed into oblique connections
comment:6 by , 10 years ago
Milestone: | 1.9.1 → 1.9.2 |
---|
This ticket was not closed for 1.9.1, which has now been released. It was batch modified for milestone 1.9.2 (but maybe an empty milestone was more appropriate; feel free to change it).
comment:7 by , 10 years ago
The situation has improved after the fixing of tickets #2477 and #2956.
Now moving around an object has less weird effects.
Maybe a simple and effective solution to this ticket can now be obtained allowing the user to add a node in a line (using context menu).
Now (r23316) if for instance in rlc.mo one moves "resistor" upwards, a line at its right becomes oblique. Would the user be allowed to add a node in that line, exploiting the now effective snap-to-grid function, I expect will be very easy to obtain the wished result, acting on that node.
comment:8 by , 10 years ago
You can add more points using the Connection Properties
dialog. Double click the connection or right click and select properties.
However, note that currently I am working on this ticket. I want to keep lines manhattanized when things move around and add points automatically if required.
follow-up: 11 comment:9 by , 10 years ago
Aha.
I didn't see that dialog.
However that dialog asks you to write X and Y coordinates, that is a bit tricky.
Maybe you could add in the context menu an "add point" item, which adds the point where the mouse is (but snapped to grid).
Naturally, if you are able to manage auto-manhattanize with automatic addition of points, this could be even better.
One thing does not exclude the other.
follow-up: 12 comment:10 by , 10 years ago
In r23357 I have added some support for keeping the lines manhattanized which works pretty fine with Dymola (even with the attached model) & SystemModeler models. But there are still some glitches e.g when you add/remove points using the dialog then things won't remain very smooth. I will fix those minor issues soon so I am keeping the ticket open.
comment:11 by , 10 years ago
Replying to ceraolo:
Aha.
I didn't see that dialog.
However that dialog asks you to write X and Y coordinates, that is a bit tricky.
Yes, but it also suggests the center of two points automatically which is same what Dymola do on insert point
.
Maybe you could add in the context menu an "add point" item, which adds the point where the mouse is (but snapped to grid).
Naturally, if you are able to manage auto-manhattanize with automatic addition of points, this could be even better.
One thing does not exclude the other.
True. I will introduce a new context menu item.
comment:12 by , 10 years ago
Replying to adeas31:
In r23357 I have added some support for keeping the lines manhattanized which works pretty fine with Dymola (even with the attached model) & SystemModeler models. But there are still some glitches e.g when you add/remove points using the dialog then things won't remain very smooth. I will fix those minor issues soon so I am keeping the ticket open.
I've checked the behaviour and I like it a lot.
I've also seen that if the user adds manually a node, he can then move a corner node to create "Z-shaped" connecting lines that in several cases are useful.
The only suggestion I would make is to make it easier to add a generic point (=node): either by addition of an item in the context menu, as already discussed, and/or making more friendly the "Connection Properties" dialog.
follow-up: 14 comment:13 by , 10 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
This was one hell of an enhancement. It is fixed now. I completed it in four different revisions r23357, r23371, r23376 and r23379.
In my opinion with my changes addPoint
option in context menu is not needed. If you add a point in the middle of two points it will be automatically removed by removeRedundantPoints
method. If you add a point which creates an oblique line then it will be automatically removed by manhattanizeShape
method. I don't see a real use of addPoint
.
If you provide me a case where addPoint
is really important then I will add it but perhaps now when you use the new OMEdit you will probably agree with me.
comment:14 by , 10 years ago
You are perfectly right: only by everyday usage some feature is seen to be really useful or not.
I hoped for the addPoint command to be added when we did not have a well-performing manhattanizing algorithm.
BTW, thank you for the tremendous effort you are putting in fixing tickets about OMEdit during recent weeks. The program is fast enhancing every day, thanks to this excellent work.
Hi ceraolo!
You are totally right. Wiring in OMEdit is almost unusable.
(No snap to grid, no undo, no manhattanized, no standard conform code generation)
Probably the whole connection representation must be reworked:
When I create a model (with Dymola or SystemModeler) for example, the wires in OMEdit are totally messed up.