Ok, excellent! Alexandre -- _,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;: Alexandre Bergel http://www.bergel.eu ^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;.
On Aug 11, 2014, at 4:37 AM, Peter Uhnák <i.uh...@gmail.com> wrote: > Hi Alex, > > unfortunately I've been quite busy with other stuff however it's on my todo > list so I'm planning to get back to it later this week. > I'll keep you posted. > > Peter > > > On Fri, Aug 8, 2014 at 11:57 PM, Alexandre Bergel <alexandre.ber...@me.com> > wrote: > Hi Peter, > > How things are going with having a snapOnGrid behavior? > > Cheers, > Alexandre > -- > _,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;: > Alexandre Bergel http://www.bergel.eu > ^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;. > > > > On Aug 1, 2014, at 2:36 PM, Peter Uhnák <i.uh...@gmail.com> wrote: > >> Hi Alex, >> >> While the "snap to grid" might be complicated I thought of simpler solution >> that might be achievable purely at Roassal level without the need to change >> Trachel classes. You can look at Umlet, since I am trying to copy it's grid >> behavior here. >> Basically you don't move objects with mouse immediately but only after fixed >> increments. However I've encountered a problem with TRMouseDragging>>step, >> since I would probably need to continuously sum the individual steps and >> then reset them when dragging has started. >> >> Here is a _very_ crude prototype: >> --------------------- >> "i subclassed RTDraggable and changed initializeElement: method as follows" >> initializeElement: element >> | sum gridSize | >> gridSize := 20. >> sum := 0 @ 0. >> element >> when: TRMouseDragging >> do: [ :e | >> | d t | >> t := RTGroup withAll: groupToDrag. >> (t includes: element) >> ifFalse: [ t add: element ]. >> d := element view canvas camera >> distanceFromPixelToSpace: e step. >> sum := sum + d. >> "move element only in increments of gridSize" >> d := gridSize * ((sum x / gridSize) truncated @ (sum y >> / gridSize) truncated). >> sum := sum - d. >> t translateBy: d. >> e signalUpdate ] >> --------------------- >> >> and here is a demo utilizing it >> >> ----------------------------- >> | v e1 e2 line gridSize b1 b2 b3 b4 edge | >> v := RTView new. >> >> "draw grid" >> gridSize := 20. >> >> (-20 to: 20) do: [ :i | >> b1 := RTBox element. >> b2 := RTBox element. >> b3 := RTBox element. >> b4 := RTBox element. >> b1 translateTo: (i * gridSize) @ -1000. "top side" >> b2 translateTo: (i * gridSize) @ 1000. "bottom side" >> b3 translateTo: -1000 @ (i * gridSize). "left side" >> b4 translateTo: 1000 @ (i * gridSize). "right side" >> "vertical line" >> edge := RTLine edgeFrom: b1 to: b2. >> v add: edge. >> "horizontal line" >> edge := RTLine edgeFrom: b3 to: b4. >> v add: edge. >> ]. >> >> e1 := (RTEllipse new size: 30; color: Color magenta) element. >> e1 translateTo: -20 @ 0. >> e1 @ RGGridDraggable. >> >> e2 := (RTEllipse new size: 30; color: Color magenta) element. >> e2 translateTo: 20 @ 0. >> e2 @ RGGridDraggable. >> >> (line := RTLine edgeFrom: e1 to: e2) shape color:Color black. >> >> v add: e1; add: e2; add: line. >> >> v open. >> ----------------------------- >> >> Obviously it needs a lot of fine-tuning and such. Since RTInteraction >> (RTDraggable) instances are not created directly the gridSize would have to >> be stored probably class side. Also there is a problem with resetting the >> "sum" variable when dragging starts. (There is no TRMouseDragStart event as >> far as I've seen). And also drawing the grid itself the way I've done is >> very brutal and doesn't really work if I want to move the canvas camera >> (perhaps image pattern as a background would work better). >> >> What are your thoughts on this? >> >> Peter >> >> >> >> >> On Fri, Aug 1, 2014 at 4:07 PM, Alexandre Bergel <alexandre.ber...@me.com> >> wrote: >> Hi Peter! >> >> > While playing with RTMultiLine I thought that it would be nice to have >> > option for RTDraggable elements to snap to a grid / move only by fixed >> > increments - for example the position could only be divisible by 10 (grid >> > size would be 10), so dragging from 20@10 to 26@4 would jump to 30@0. Is >> > something like this possible with current implementation? >> >> >> I first thought this would be easy. But actually it is not. >> The way to achieve the snap on grid behavior is to have an indirection in >> the Trachel classes. Each trachel shape knows its position (the position is >> contained in the matrix attached to each shape). The snap-on-grid means you >> need to slightly process the matrix coordinate. Maybe there are other way to >> do this, but it does not look like. Changing Trachel because of this seems a >> bit overkill... >> >> Cheers, >> Alexandre >> -- >> _,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;: >> Alexandre Bergel http://www.bergel.eu >> ^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;._,.;:~^~:;. >> >> >> >> On Jul 31, 2014, at 3:58 PM, Peter Uhnák <i.uh...@gmail.com> wrote: >> >> > While playing with RTMultiLine I thought that it would be nice to have >> > option for RTDraggable elements to snap to a grid / move only by fixed >> > increments - for example the position could only be divisible by 10 (grid >> > size would be 10), so dragging from 20@10 to 26@4 would jump to 30@0. Is >> > something like this possible with current implementation? >> > >> > The second question is: is it possible for element to subscribe for >> > position updates of another element? (I.e. element A watches for movement >> > of element B and moves accordingly). I know I could add both of them to a >> > composite shape or RTGroup (RTDraggable>>groupToDrag:), however I would >> > prefer something more loosely coupled. >> > >> > In RTDraggable>>initializeElement: i found >> > " element when: TRMouseDragging do: [ :e | e element translateBy: e >> > step. e signalUpdate ]" >> > however it is commented out so perhaps there some other way? >> > >> > Peter >> >> >> > >