I have a canvas where I can draw, resize and move rectangles around.
I'm looking for an algorithm to prevent overlap and enable snapping of the rectangle I'm editing with other rectangles.
I'm tried different approaches but I couldn't get one working properly.
All my approaches are based on a simple loop that check the rectangle I'm editing (E) with other rectangles (O[n]).
Preventing overlap is not the problem, my problem is snapping as it can modify E while iterating O.
For example, if I'm moving E near O[1] it will snap with it, but this snap might create an overlap with O[0], overlap that won't be checked.
Before I start doing something recursive or too naïve, I was wondering if anybody kn开发者_JAVA技巧ew a better approach.
Would a two-pass approach help, e.g.
In the first pass, check E against the O's and generate a short list of snap candidates.
In the second pass, check each of the snap candidates for overlap against the O's.
If scanning the entire list of O's is prohibitively expensive (the effort grows linearly with the number of objects), consider a quad-tree for storing the objects and/or their vertices. A quadtree lets you narrow down on nearby points much faster.
精彩评论