144 |
Defines the colors, to display overlapping links
|
143 |
The exPreventOverlapMixt flag must always be used alongside either the exPreventOverlap or exChangeColorOnOverlap flag. When used with the exPreventOverlap flag, it ensures that links avoid overlapping with elements or obstacles, enabling their paths to include both rectangular and diagonal lines. When combined with the exChangeColorOnOverlap flag, overlapping links alternately adjust their width in addition to changing colors (sample 2)
|
142 |
The exChangeColorOnOverlap flag changes the color for links in areas where they overlap with other links, enhancing clarity and distinction between them
|
141 |
The exPreventOverlapMixt flag must always be used alongside either the exPreventOverlap or exChangeColorOnOverlap flag. When used with the exPreventOverlap flag, it ensures that links avoid overlapping with elements or obstacles, enabling their paths to include both rectangular and diagonal lines. When combined with the exChangeColorOnOverlap flag, overlapping links alternately adjust their width in addition to changing colors (sample 1)
|
140 |
The exPreventOverlap flag adjusts the links to prevent them from overlapping the connected objects. The exPreventOverlap option calculates the path between A and B using the A* (A-star) pathfinding algorithm, which can be a time-consuming operation
|
139 |
How can I replace or add an icon at runtime
|
138 |
exActionContextMenuObject, An item from object's context menu is executing. Use the AllowContextMenu property to specify the combination of keys that allows the user to open the object's context menu. Use the ContextMenu property to provide a custom context menu for the objects on the surface. The ActionContextMenu event notifies your application once an action occurs within the object's context menu.
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 18 ? `exActionContextMenuObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 18 ? `exActionContextMenuObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowDesignHeader = EXSWIMLANELib.AllowDesignHeaderEnum.exDesignHeaderLock; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); EXSWIMLANELib.Pool var_Pool = axSwimLane1.Pools.Add(-100,-100,250,160); var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneHorizontal).Children.Count = 2; var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneVertical).Children.Count = 2; axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Right-Click the pool, element or the link to open its context menu, and change a property of it" ); |
137 |
exContextMenuObject, The object's context menu is running. The user right-clicks an object on the surface, and it's context menu is shown. Use the AllowContextMenu property to specify the combination of keys that allows the user to open the object's context menu. Use the ContextMenu property to provide a custom context menu for the objects on the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 17 ? `exContextMenuObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 17 ? `exContextMenuObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowDesignHeader = EXSWIMLANELib.AllowDesignHeaderEnum.exDesignHeaderLock; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); EXSWIMLANELib.Pool var_Pool = axSwimLane1.Pools.Add(-100,-100,250,160); var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneHorizontal).Children.Count = 2; var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneVertical).Children.Count = 2; axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Right-Click the pool, element or the link to open its context menu" ); |
136 |
exMoveLane, The user moves/changes the position of the lane of the pool. The AllowMoveLane property specifies the keys combination to allow user to moves/changes the position the lane
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 16 ? `exMoveLane` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 16 ? `exMoveLane` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowDesignHeader = EXSWIMLANELib.AllowDesignHeaderEnum.exDesignHeaderLock; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); EXSWIMLANELib.Pool var_Pool = axSwimLane1.Pools.Add(-100,-100,250,160); var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneHorizontal).Children.Count = 2; var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneVertical).Children.Count = 2; axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click the lane's header to drag to a new position" ); |
135 |
exResizeLane, The user resizes the lane of the pool. The AllowResizePoolHeader property specifies the keys combination to allow user to resize the header of the pool
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 15 ? `exResizeLane` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 15 ? `exResizeLane` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowDesignHeader = EXSWIMLANELib.AllowDesignHeaderEnum.exDesignHeaderLock; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); EXSWIMLANELib.Pool var_Pool = axSwimLane1.Pools.Add(-100,-100,250,160); var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneHorizontal).Children.Count = 2; var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneVertical).Children.Count = 2; axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click the pool's header to resize it" ); |
134 |
exResizePoolHeader, the user resizes the header's pool from the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 14 ? `exResizePoolHeader` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 14 ? `exResizePoolHeader` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click the pool's header to resize it" ); |
133 |
exMovePool, The user moves the pool from the surface. The AllowMovePool property specifies the keys combination to allow user to move the pool
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 13 ? `exMovePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 13 ? `exMovePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click a pool and drag to reposition it" ); |
132 |
exResizePool, The user resizes the pool from the surface. The AllowResizePool property specifies the keys combination to allow user to resize the pool
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 12 ? `exResizePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 12 ? `exResizePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Resize a pool" ); |
131 |
exCreatePool, The user creates pools on the surface. The AllowCreatePool property specifies the keys combination to allow user to create pools on the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 11 ? `exCreatePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 11 ? `exCreatePool` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Hold SHIFT, double-click on the surface, and immediately drag to a new position to create a new pool" ); |
130 |
exDesignMode, The user changes the surface's design mode. The exDesignMode operation occurs, when the user selects a new design-mode, from the control's toolbar.
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 10 ? `exDesignMode` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 10 ? `exDesignMode` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click the Design Menu and select one of the options" ); |
129 |
exUndo, An Undo operation is performed (CTR + Z), exRedo, A Redo operation is performed (CTR + Y). exUndoRedoUpdate, The Undo/Redo queue is updated
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value case (default:value;32:`exUndoRedoUpdate`;33:`exUndo`;34:`exRedo`)",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value case (default:value;32:`exUndoRedoUpdate`;33:`exUndo`;34:`exRedo`)",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowUndoRedo = true; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Press CTRL+Z to Undo, CTRL+Y to Redo" ); |
128 |
exLinkObjects, the user creates an element on the surface. The AllowLinkObjects property specifies the keys combination to allow user to link elements on the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 9 ? `exLinkObjects` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 9 ? `exLinkObjects` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Hold SHIFT, click an element, and drag to another element to create a link between them" ); |
127 |
exEditObject, the user edits the element's caption
// Click event - Occurs when the user presses and then releases the left mouse button over the control. private void axSwimLane1_ClickEvent(object sender, EventArgs e) { // ElementFromPoint(-1,-1).Edit(0) } //this.axSwimLane1.ClickEvent += new EventHandler(this.axSwimLane1_ClickEvent); // LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 8 ? `exEditObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 8 ? `exEditObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click an element to edit its caption" ); |
126 |
exCreateObject, the user creates an element on the surface. The AllowCreateObject property specifies the keys combination to allow user to create elements on the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 7 ? `exCreateObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 7 ? `exCreateObject` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Double-click on the surface and immediately drag to a new position to create an element" ); |
125 |
exSelectNothing, the user clicks an empty zone of the surface. The AllowSelectNothing property specifies the keys combination to allow user to select nothing on the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 6 ? `exSelectNothing` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 6 ? `exSelectNothing` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowSelectNothing = true; axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null).Selected = true; var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Select an element, and then click outside to select nothing" ); |
124 |
exSelectElement, the user clicks the object to get it selected. The AllowSelectObject property specifies the keys combination to allow user to select the object
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 5 ? `exSelectElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 5 ? `exSelectElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Hold ALT and click, then drag to select elements within the drawn rectangle. Click an element to select it. CTRL + CLick to uns" + "elect it" ); |
123 |
exMoveElement, the user moves the object. The AllowMoveObject property specifies the keys combination to allow user to move the object
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 4 ? `exMoveElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 4 ? `exMoveElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Move an element" ); |
122 |
exResizeElement, the user resizes the object. The AllowResizeObject property specifies the keys combination to allow user to resize the object
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 3 ? `exResizeElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 3 ? `exResizeElement` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64).AutoSize = false; var_Elements.Add("Node <b>2",null,null).AutoSize = false; var_Elements.Add("Node <b>3",64,-64).AutoSize = false; axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Resize an element" ); |
121 |
exSurfaceHome, the user clicks the Home button on the control's toolbar, so the surface is restored to original position. The Home method has the same effect
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 2 ? `exSurfaceHome` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 2 ? `exSurfaceHome` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click the Home button" ); |
120 |
exSurfaceZoom, the user magnifies or shrinks the surface. The AllowZoomSurface property specifies the keys combination to allow user to zoom the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 1 ? `exSurfaceZoom` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 1 ? `exSurfaceZoom` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click and drag the surface to reposition it" ); |
119 |
exSurfaceMove, the user scrolls or moves the surface. The AllowMoveSurface property specifies the keys combination to allow user to move / scroll the surface
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 0 ? `exSurfaceMove` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value = 0 ? `exSurfaceMove` : value",e.operation,null,null).ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); System.Diagnostics.Debug.Print( "Click and drag the surface to reposition it" ); |
118 |
FormatABC method formats the A,B,C values based on the giving expression and returns the result
System.Diagnostics.Debug.Print( axSwimLane1.FormatABC("value format ``",1000,null,null).ToString() ); |
117 |
FreezeEvents(Freeze) method prevents firing any event. For instance, FreezeEvents(True) freezes the control's events, no no event is fired, until the FreezeEvents(False) is called
// Event event - Notifies the application once the control fires an event. private void axSwimLane1_Event(object sender, AxEXSWIMLANELib._ISwimLaneEvents_EventEvent e) { System.Diagnostics.Debug.Print( axSwimLane1.get_EventParam(-2).ToString() ); } //this.axSwimLane1.Event += new AxEXSWIMLANELib._ISwimLaneEvents_EventEventHandler(this.axSwimLane1_Event); axSwimLane1.FreezeEvents(true); System.Diagnostics.Debug.Print( "No event is fired after FreezeEvents(True) call" ); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); |
116 |
The exAllowChangeFrom(0x20)/exAllowChangeTo(0x40) flag of LinkControlPointEnum type allows the user to adjust the link's from/to element by dragging and dropping the start control point (requires the exStartControlPoint/exEndControlPoint flag)
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); System.Diagnostics.Debug.Print( axSwimLane1.FocusLink.ID.ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); System.Diagnostics.Debug.Print( axSwimLane1.FocusLink.ID.ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exAllowChangeTo | EXSWIMLANELib.LinkControlPointEnum.exAllowChangeFrom | EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); var_Elements.Add("Node <b>3",64,-64); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.FocusLink = "L1"; axSwimLane1.EndUpdate(); |
115 |
The LayoutStartChanging(exFocusLink)/LayoutEndChanging(exFocusLink) event notifies your application when the user focuses on a new link
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); System.Diagnostics.Debug.Print( axSwimLane1.FocusLink.ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); System.Diagnostics.Debug.Print( axSwimLane1.FocusLink.ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.EndUpdate(); |
114 |
Focus a link
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); // LayoutStartChanging event - Occurs when the control's layout is about to be changed. private void axSwimLane1_LayoutStartChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutStartChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); } //this.axSwimLane1.LayoutStartChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutStartChangingEventHandler(this.axSwimLane1_LayoutStartChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowLinkControlPoint = EXSWIMLANELib.LinkControlPointEnum.exEndControlPoint | EXSWIMLANELib.LinkControlPointEnum.exStartControlPoint; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Node <b>1",-64,-64); var_Elements.Add("Node <b>2",null,null); axSwimLane1.Pools.Add(-100,-100,250,160); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],"L1"); axSwimLane1.FocusLink = "L1"; axSwimLane1.EndUpdate(); |
113 |
The caption is displayed on the back, so the picture overrides it. How can I place the caption on the foreground
|
112 |
Expandable-caption
|
111 |
Expandable-caption
|
110 |
Draws a frame arround the link's arrow
|
109 |
Draws a frame arround the arrow for all links
|
108 |
Change the size to display the arrow of the link
|
107 |
Change the size to display the arrows for all links
|
106 |
Extends the caption on the element's width
|
105 |
Gets the width/height of the element to fit its content ( as if the AutoSize property is True )
|
104 |
Fullfit the caption on the element's width
|
103 |
Wrap the caption by <br> or "\r\n" sequence only
|
102 |
Display a custom tooltip
|
101 |
Shows the tooltip of the object moved relative to its default position
|
100 |
Add a pool to cover all visible-elements
|
99 |
How can I ensure that a specified pool fits the surface's visible area
|
98 |
No property for the pool can be saved/restored through Undo/Redo feature
|
97 |
Rename Undo/Redo commands into the control's toolbar
|
96 |
Add Undo/Redo commands to control's toolbar
|
95 |
Clear Undo/Redo queue (method 2)
|
94 |
Clear Undo/Redo queue (method 1)
|
93 |
Removes Redo operations
|
92 |
Removes Undo operations
|
91 |
Record the UI operations as a block of undo/redo operations
|
90 |
Groups the next to current Undo/Redo Actions in a single block
|
89 |
Limits the number of entries within the Undo/Redo queue
|
88 |
Lists the Redo actions that can be performed on the surface
|
87 |
Lists the Undo actions that can be performed on the surface
|
86 |
Checks whether the Undo operation is possible
|
85 |
Call Redo by code
|
84 |
Checks whether the Undo operation is possible
|
83 |
Call Undo by code
|
82 |
Save the element's properties for Undo/Redo operations, by code
|
81 |
No color is restored for the link when Undo/Redo operation is executed
|
80 |
Save the element's properties for Undo/Redo operations, by code
|
79 |
No color is restored for the element when Undo/Redo operation is executed
|
78 |
How can I ensure that a specified element fits the surface's visible area
|
77 |
LayoutEndChanging(exUndo), LayoutEndChanging(exRedo) or LayoutEndChanging(exUndoRedoUpdate) notifiy your application once a Undo/Redo operation is executed (CTRL+Z, CTRL+Y) or updated
// LayoutEndChanging event - Notifies your application once the control's layout has been changed. private void axSwimLane1_LayoutEndChanging(object sender, AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEvent e) { System.Diagnostics.Debug.Print( "LayoutEndChanging" ); System.Diagnostics.Debug.Print( e.operation.ToString() ); } //this.axSwimLane1.LayoutEndChanging += new AxEXSWIMLANELib._ISwimLaneEvents_LayoutEndChangingEventHandler(this.axSwimLane1_LayoutEndChanging); axSwimLane1.BeginUpdate(); axSwimLane1.AllowUndoRedo = true; axSwimLane1.Pools.Add(-154,-82,244,122); EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Item <b>1",-64,-64); var_Elements.Add("Item <b>2",null,null); axSwimLane1.Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],null); axSwimLane1.EndUpdate(); |
76 |
Turn on the Undo/Redo feature
|
75 |
ImageSize property on 32 (specifies the size of control' icons/images/check-boxes/radio-buttons)
|
74 |
ImageSize property on 16 (default) (specifies the size of control' icons)
|
73 |
We want to have option to start/end connectors at the middle of each side of the elements
|
72 |
How can I determine the position the user clicks within the element's boundaries (Click event)
|
71 |
How can I determine the position the user clicks within the element's boundaries (MouseMove event)
|
70 |
How can I convert the screen position (mouse) to surface position
|
69 |
Is is possible to show just the positive coordinates
|
68 |
Cartesian coordinates (positive coordinates are shown top-right to the origin)
|
67 |
Default coordinates (positive coordinates are shown bottom-right to the origin)
|
66 |
Is it possible to customize the path of the links orthogonally similar with Microsoft Visio tool
|
65 |
Does your control supports OLE Drag and Drop
// OLEDragDrop event - Occurs when a source component is dropped onto a target component when the source component determines that a drop can occur. private void axSwimLane1_OLEDragDrop(object sender, AxEXSWIMLANELib._ISwimLaneEvents_OLEDragDropEvent e) { System.Diagnostics.Debug.Print( e.data.ToString() ); } //this.axSwimLane1.OLEDragDrop += new AxEXSWIMLANELib._ISwimLaneEvents_OLEDragDropEventHandler(this.axSwimLane1_OLEDragDrop); // OLEStartDrag event - Occurs when the OLEDrag method is called. private void axSwimLane1_OLEStartDrag(object sender, AxEXSWIMLANELib._ISwimLaneEvents_OLEStartDragEvent e) { // Data.SetData("some data to drag") } //this.axSwimLane1.OLEStartDrag += new AxEXSWIMLANELib._ISwimLaneEvents_OLEStartDragEventHandler(this.axSwimLane1_OLEStartDrag); axSwimLane1.BeginUpdate(); axSwimLane1.OLEDropMode = EXSWIMLANELib.exOLEDropModeEnum.exOLEDropManual; EXSWIMLANELib.Pool var_Pool = axSwimLane1.Pools.Add(-250,-150,500,250); var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneHorizontal).Children.Count = 2; var_Pool.get_Lane(EXSWIMLANELib.LaneTypeEnum.exLaneVertical).Children.Count = 1; EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; EXSWIMLANELib.Element var_Element = var_Elements.Add("Click the Element wait for .5 second until + cursor is shown, to start <b>OLE Drag and Drop</b>",null,null); var_Element.CaptionSingleLine = EXSWIMLANELib.CaptionSingleLineEnum.exCaptionWordWrap; var_Element.AutoSize = false; var_Element.X = -125; var_Element.Y = -105; var_Element.Width = 256; var_Element.Height = 56; EXSWIMLANELib.Element var_Element1 = var_Elements.Add("Click the Element wait for .5 second until + cursor is shown, to start <b>OLE Drag and Drop</b>",null,null); var_Element1.CaptionSingleLine = EXSWIMLANELib.CaptionSingleLineEnum.exCaptionWordWrap; var_Element1.AutoSize = false; var_Element1.X = -125; var_Element1.Width = 256; var_Element1.Height = 56; axSwimLane1.EndUpdate(); |
64 |
Is it possible to disable customizing the path of a specified link
|
63 |
How do I let user customizes the link's path
|
62 |
How can I generate a picture/image/graph from my diagram
EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Element A",null,null).ID = "A"; var_Elements.Add("Element B",null,null).ID = "B"; var_Elements.Add("Element C",null,null).ID = "C"; var_Elements.Add("Element D",null,null).ID = "D"; var_Elements.Add("Element E",null,null).ID = "E"; var_Elements.Add("Element E",null,null).ID = "F"; EXSWIMLANELib.Links var_Links = axSwimLane1.Links; var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["B"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["C"],null); var_Links.Add(axSwimLane1.Elements["B"],axSwimLane1.Elements["D"],null); var_Links.Add(axSwimLane1.Elements["B"],axSwimLane1.Elements["C"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["E"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["F"],null); axSwimLane1.set_DefArrange(EXSWIMLANELib.DefArrangeEnum.exDefArrangeCompact,false); axSwimLane1.Arrange(null); object var_CopyTo = axSwimLane1.get_CopyTo("c:/temp/xtest.jpg"); System.Diagnostics.Debug.Print( "!!!check the file c:/temp/xtest.jpg!!!" ); |
61 |
How can I generate a picture/image/graph from my diagram
EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Element A",null,null).ID = "A"; var_Elements.Add("Element B",null,null).ID = "B"; var_Elements.Add("Element C",null,null).ID = "C"; var_Elements.Add("Element D",null,null).ID = "D"; var_Elements.Add("Element E",null,null).ID = "E"; var_Elements.Add("Element E",null,null).ID = "F"; EXSWIMLANELib.Links var_Links = axSwimLane1.Links; var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["B"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["C"],null); var_Links.Add(axSwimLane1.Elements["B"],axSwimLane1.Elements["D"],null); var_Links.Add(axSwimLane1.Elements["B"],axSwimLane1.Elements["C"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["E"],null); var_Links.Add(axSwimLane1.Elements["A"],axSwimLane1.Elements["F"],null); axSwimLane1.set_DefArrange(EXSWIMLANELib.DefArrangeEnum.exDefArrangeCompact,false); axSwimLane1.Arrange(null); // Add 'ExPrint 1.0 Control Library(ExPrint.dll)' reference to your project. EXPRINTLib.Print var_Print = new EXPRINTLib.Print(); var_Print.PrintExt = (axSwimLane1.GetOcx() as EXSWIMLANELib.SwimLane); var_Print.CopyTo("c:/temp/xtest.jpg"); System.Diagnostics.Debug.Print( "!!!check the file c:/temp/xtest.jpg!!!" ); |
60 |
How can I print the component
EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Element <sha ;;0>A",null,null); var_Elements.Add("Element <sha ;;0>B",0,76); EXSWIMLANELib.Element var_Element = var_Elements.Add("Element <sha ;;0>C",-76,32); var_Element.AutoSize = false; var_Element.Height = 32; EXSWIMLANELib.Element var_Element1 = var_Elements.Add("Element <sha ;;0>D",76,32); var_Element1.AutoSize = false; var_Element1.Height = 32; EXSWIMLANELib.Links var_Links = axSwimLane1.Links; EXSWIMLANELib.Link var_Link = var_Links.Add(axSwimLane1.Elements[1],axSwimLane1.Elements[2],null); var_Link.StartPos = EXSWIMLANELib.AlignmentEnum.CenterAlignment; var_Link.EndPos = EXSWIMLANELib.AlignmentEnum.CenterAlignment; EXSWIMLANELib.Link var_Link1 = var_Links.Add(axSwimLane1.Elements[2],axSwimLane1.Elements[1],null); var_Link1.StartPos = EXSWIMLANELib.AlignmentEnum.CenterAlignment; var_Link1.EndPos = EXSWIMLANELib.AlignmentEnum.CenterAlignment; var_Links.Add(axSwimLane1.Elements[3],axSwimLane1.Elements[4],null); EXSWIMLANELib.Link var_Link2 = var_Links.Add(axSwimLane1.Elements[4],axSwimLane1.Elements[3],null); var_Link2.StartPos = EXSWIMLANELib.AlignmentEnum.LeftAlignment; var_Link2.EndPos = EXSWIMLANELib.AlignmentEnum.RightAlignment; // Add 'ExPrint 1.0 Control Library(ExPrint.dll)' reference to your project. EXPRINTLib.Print var_Print = new EXPRINTLib.Print(); var_Print.PrintExt = (axSwimLane1.GetOcx() as EXSWIMLANELib.SwimLane); var_Print.Preview(); |
59 |
How can I show direct-links
|
58 |
How can I show straight-links
|
57 |
How can I show round-links
|
56 |
I've tried to insert a "<br>" in the Caption property text and it just ignores it
|
55 |
How do I align the extra-caption
|
54 |
How can I add an extra caption
|
53 |
I am using the reserve-neighbors feature, the question is how to shift left/right the neighbors instead of up/down
axSwimLane1.BeginUpdate(); axSwimLane1.AllowMoveNeighbors = EXSWIMLANELib.MoveNeighborsEnum.exMoveNeighborsHorizontally; axSwimLane1.set_DefArrange(EXSWIMLANELib.DefArrangeEnum.exDefArrangeDir,1); EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Element <sha ;;0>A",null,null); var_Elements.Add("Element <sha ;;0>B ( move it )",16,32); var_Elements.Add("Element <sha ;;0>C",128,0); axSwimLane1.EndUpdate(); |
52 |
I am using the reserve-neighbors feature, the question is if possible to specify the distance between neighbors
axSwimLane1.BeginUpdate(); axSwimLane1.AllowMoveNeighbors = EXSWIMLANELib.MoveNeighborsEnum.exMoveNeighborsVertically; axSwimLane1.set_DefArrange(EXSWIMLANELib.DefArrangeEnum.exDefArrangeDX,0); axSwimLane1.set_DefArrange(EXSWIMLANELib.DefArrangeEnum.exDefArrangeDY,0); EXSWIMLANELib.Elements var_Elements = axSwimLane1.Elements; var_Elements.Add("Element <sha ;;0>A",null,null); var_Elements.Add("Element <sha ;;0>B ( move it )",0,32); var_Elements.Add("Element <sha ;;0>C",0,64); axSwimLane1.EndUpdate(); |
51 |
How do I enable the reserve-neighbors feature
|
50 |
I've noticed that recently, the elements get compacted once the Arrange method is performed. How can I prevent that
|
49 |
How can I move an element to a specified lane/phase/pool
|
48 |
Is it possible to add a link to show from bottom/down to top/up, rather that right to left (method-2)
|
47 |
Is it possible to add a link to show from bottom/down to top/up, rather that right to left (method-1)
|
46 |
How do I enable the cross link support ( mixed )
|
45 |
How do I enable the cross link support ( triangular )
|