You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have implemented a new snapper tool with a magnetic snap behaviour. In different to the gridSnapper this snapper does not orientate on the diagram grid but on the alignment of other Elements in the modelling plane. Together with my HelperLine you can now much easier align elements in a fast and precise way:
The implementation looks like this:
@injectable()exportclassBPMNElementSnapperimplementsISnapper{getsnapRange(): number{return10;}/* Find a possible snapPoint. * a SnapPoint is found if the x or y coordinates matching the position * of another element Node */snap(position: Point,element: SModelElement): Point{constsnapPoint:Point=this.findSnapPoint(element);// if a snapPoint was found and this snapPoint is still in the snapRange,// then we adjust the current mouse Postion. Otherwise we return the current positionconsty=(snapPoint.y>-1&&Math.abs(position.y-snapPoint.y)<=this.snapRange)?snapPoint.y:position.y;constx=(snapPoint.x>-1&&Math.abs(position.x-snapPoint.x)<=this.snapRange)?snapPoint.x:position.x;return{x:x,y:y};}/* * This helper method searches the model for model elements * matching the horizontal and/or vertical alligment of the given modelElement. * * A ModelElement is a alligned to another element if its center point matches * the same x or y axis. The method retuns up to two elements - vertical and/or horizontal * * The method takes into account an approximation of 10. (See method 'isNear') * */privatefindSnapPoint(modelElement: SModelElement): Point{
let root:any;try{root=modelElement.root;}catch(e: unknown){// unable to get root (during creation)}
let x: number=-1;
let y: number=-1;if(root&&isBoundsAware(modelElement)){constchilds=root.children;constmodelElementCenter=Bounds.center(modelElement.bounds);// In the following we iterate over all model elements// and compare the x and y axis of the center pointsfor(constelementofchilds){if(element.id!==modelElement.id&&isBoundsAware(element)&&!(elementinstanceofSLabel)){constelementCenter=Bounds.center(element.bounds);if(elementCenter&&modelElementCenter){// test horizontal alligment...if(y==-1&&this.isNear(elementCenter.y,modelElementCenter.y)){// fount horizontal snap pointy=elementCenter.y-(modelElement.bounds.height*0.5);}// test vertical alligment...if(x==-1&&this.isNear(elementCenter.x,modelElementCenter.x)){// found vertical snap point!x=elementCenter.x-(modelElement.bounds.width*0.5);}}}if(x>-1&&y>-1){// we can break here as we found already the maximum of two possible matches.break;}}}// return snapoint (-1,-1 if not match was found)return{x:x,y:y};}/** * Returns true if the values are in a range of 10 */privateisNear(p1: number,p2:number){constp3=Math.abs(p1-p2);if(p3<this.snapRange){returntrue;}returnfalse;}}
reacted with thumbs up emoji reacted with thumbs down emoji reacted with laugh emoji reacted with hooray emoji reacted with confused emoji reacted with heart emoji reacted with rocket emoji reacted with eyes emoji
-
Hi,
I have implemented a new snapper tool with a magnetic snap behaviour. In different to the gridSnapper this snapper does not orientate on the diagram grid but on the alignment of other Elements in the modelling plane. Together with my HelperLine you can now much easier align elements in a fast and precise way:
The implementation looks like this:
The full feature can be found here
If you find this useful, use it!
Beta Was this translation helpful? Give feedback.
All reactions