185 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
		
		
			
		
	
	
			185 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
|   | <!--
 | ||
|  |   Copyright (c) 2006-2013, JGraph Ltd | ||
|  |    | ||
|  |   Toolbar example for mxGraph. This example demonstrates using | ||
|  |   existing cells as templates for creating new cells. | ||
|  | --> | ||
|  | <html> | ||
|  | <head> | ||
|  | 	<title>Toolbar example for mxGraph</title> | ||
|  | 
 | ||
|  | 	<!-- Sets the basepath for the library if not in same directory --> | ||
|  | 	<script type="text/javascript"> | ||
|  | 		mxBasePath = '../src'; | ||
|  | 	</script> | ||
|  | 
 | ||
|  | 	<!-- Loads and initializes the library --> | ||
|  | 	<script type="text/javascript" src="../src/js/mxClient.js"></script> | ||
|  | 
 | ||
|  | 	<!-- Example code --> | ||
|  | 	<script type="text/javascript"> | ||
|  | 		// Program starts here. Creates a sample graph in the | ||
|  | 		// DOM node with the specified ID. This function is invoked | ||
|  | 		// from the onLoad event handler of the document (see below). | ||
|  | 		function main() | ||
|  | 		{ | ||
|  | 			// Defines an icon for creating new connections in the connection handler. | ||
|  | 			// This will automatically disable the highlighting of the source vertex. | ||
|  | 			mxConnectionHandler.prototype.connectImage = new mxImage('images/connector.gif', 16, 16); | ||
|  | 		 | ||
|  | 			// Checks if browser is supported | ||
|  | 			if (!mxClient.isBrowserSupported()) | ||
|  | 			{ | ||
|  | 				// Displays an error message if the browser is | ||
|  | 				// not supported. | ||
|  | 				mxUtils.error('Browser is not supported!', 200, false); | ||
|  | 			} | ||
|  | 			else | ||
|  | 			{ | ||
|  | 				// Creates the div for the toolbar | ||
|  | 				var tbContainer = document.createElement('div'); | ||
|  | 				tbContainer.style.position = 'absolute'; | ||
|  | 				tbContainer.style.overflow = 'hidden'; | ||
|  | 				tbContainer.style.padding = '2px'; | ||
|  | 				tbContainer.style.left = '0px'; | ||
|  | 				tbContainer.style.top = '26px'; | ||
|  | 				tbContainer.style.width = '24px'; | ||
|  | 				tbContainer.style.bottom = '0px'; | ||
|  | 				 | ||
|  | 				document.body.appendChild(tbContainer); | ||
|  | 			 | ||
|  | 				// Creates new toolbar without event processing | ||
|  | 				var toolbar = new mxToolbar(tbContainer); | ||
|  | 				toolbar.enabled = false | ||
|  | 				 | ||
|  | 				// Creates the div for the graph | ||
|  | 				container = document.createElement('div'); | ||
|  | 				container.style.position = 'absolute'; | ||
|  | 				container.style.overflow = 'hidden'; | ||
|  | 				container.style.left = '24px'; | ||
|  | 				container.style.top = '26px'; | ||
|  | 				container.style.right = '0px'; | ||
|  | 				container.style.bottom = '0px'; | ||
|  | 				container.style.background = 'url("editors/images/grid.gif")'; | ||
|  | 
 | ||
|  | 				document.body.appendChild(container); | ||
|  | 				 | ||
|  | 				// Workaround for Internet Explorer ignoring certain styles | ||
|  | 				if (mxClient.IS_QUIRKS) | ||
|  | 				{ | ||
|  | 					document.body.style.overflow = 'hidden'; | ||
|  | 					new mxDivResizer(tbContainer); | ||
|  | 					new mxDivResizer(container); | ||
|  | 				} | ||
|  | 	 | ||
|  | 				// Creates the model and the graph inside the container | ||
|  | 				// using the fastest rendering available on the browser | ||
|  | 				var model = new mxGraphModel(); | ||
|  | 				var graph = new mxGraph(container, model); | ||
|  | 				graph.dropEnabled = true; | ||
|  | 				 | ||
|  | 				// Matches DnD inside the graph | ||
|  | 				mxDragSource.prototype.getDropTarget = function(graph, x, y) | ||
|  | 				{ | ||
|  | 					var cell = graph.getCellAt(x, y); | ||
|  | 					 | ||
|  | 					if (!graph.isValidDropTarget(cell)) | ||
|  | 					{ | ||
|  | 						cell = null; | ||
|  | 					} | ||
|  | 					 | ||
|  | 					return cell; | ||
|  | 				}; | ||
|  | 
 | ||
|  | 				// Enables new connections in the graph | ||
|  | 				graph.setConnectable(true); | ||
|  | 				graph.setMultigraph(false); | ||
|  | 
 | ||
|  | 				// Stops editing on enter or escape keypress | ||
|  | 				var keyHandler = new mxKeyHandler(graph); | ||
|  | 				var rubberband = new mxRubberband(graph); | ||
|  | 				 | ||
|  | 				var addVertex = function(icon, w, h, style) | ||
|  | 				{ | ||
|  | 					var vertex = new mxCell(null, new mxGeometry(0, 0, w, h), style); | ||
|  | 					vertex.setVertex(true); | ||
|  | 				 | ||
|  | 					addToolbarItem(graph, toolbar, vertex, icon); | ||
|  | 				}; | ||
|  | 				 | ||
|  | 				addVertex('editors/images/swimlane.gif', 120, 160, 'shape=swimlane;startSize=20;'); | ||
|  | 				addVertex('editors/images/rectangle.gif', 100, 40, ''); | ||
|  | 				addVertex('editors/images/rounded.gif', 100, 40, 'shape=rounded'); | ||
|  | 				addVertex('editors/images/ellipse.gif', 40, 40, 'shape=ellipse'); | ||
|  | 				addVertex('editors/images/rhombus.gif', 40, 40, 'shape=rhombus'); | ||
|  | 				addVertex('editors/images/triangle.gif', 40, 40, 'shape=triangle'); | ||
|  | 				addVertex('editors/images/cylinder.gif', 40, 40, 'shape=cylinder'); | ||
|  | 				addVertex('editors/images/actor.gif', 30, 40, 'shape=actor'); | ||
|  | 				toolbar.addLine(); | ||
|  | 				 | ||
|  | 				var button = mxUtils.button('Create toolbar entry from selection', function(evt) | ||
|  | 				{ | ||
|  | 					if (!graph.isSelectionEmpty()) | ||
|  | 					{ | ||
|  | 						// Creates a copy of the selection array to preserve its state | ||
|  | 						var cells = graph.getSelectionCells(); | ||
|  | 						var bounds = graph.getView().getBounds(cells); | ||
|  | 						 | ||
|  | 						// Function that is executed when the image is dropped on | ||
|  | 						// the graph. The cell argument points to the cell under | ||
|  | 						// the mousepointer if there is one. | ||
|  | 						var funct = function(graph, evt, cell) | ||
|  | 						{ | ||
|  | 							graph.stopEditing(false); | ||
|  | 			 | ||
|  | 							var pt = graph.getPointForEvent(evt); | ||
|  | 							var dx = pt.x - bounds.x; | ||
|  | 							var dy = pt.y - bounds.y; | ||
|  | 							 | ||
|  | 							graph.setSelectionCells(graph.importCells(cells, dx, dy, cell)); | ||
|  | 						} | ||
|  | 			 | ||
|  | 						// Creates the image which is used as the drag icon (preview) | ||
|  | 						var img = toolbar.addMode(null, 'editors/images/outline.gif', funct); | ||
|  | 						mxUtils.makeDraggable(img, graph, funct); | ||
|  | 					} | ||
|  | 				}); | ||
|  | 
 | ||
|  | 				button.style.position = 'absolute'; | ||
|  | 				button.style.left = '2px'; | ||
|  | 				button.style.top = '2px'; | ||
|  | 				 | ||
|  | 				document.body.appendChild(button); | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		function addToolbarItem(graph, toolbar, prototype, image) | ||
|  | 		{ | ||
|  | 			// Function that is executed when the image is dropped on | ||
|  | 			// the graph. The cell argument points to the cell under | ||
|  | 			// the mousepointer if there is one. | ||
|  | 			var funct = function(graph, evt, cell) | ||
|  | 			{ | ||
|  | 				graph.stopEditing(false); | ||
|  | 
 | ||
|  | 				var pt = graph.getPointForEvent(evt); | ||
|  | 				var vertex = graph.getModel().cloneCell(prototype); | ||
|  | 				vertex.geometry.x = pt.x; | ||
|  | 				vertex.geometry.y = pt.y; | ||
|  | 				 | ||
|  | 				graph.setSelectionCells(graph.importCells([vertex], 0, 0, cell)); | ||
|  | 			} | ||
|  | 
 | ||
|  | 			// Creates the image which is used as the drag icon (preview) | ||
|  | 			var img = toolbar.addMode(null, image, funct); | ||
|  | 			mxUtils.makeDraggable(img, graph, funct); | ||
|  | 		} | ||
|  | 
 | ||
|  | 	</script> | ||
|  | </head> | ||
|  | 
 | ||
|  | <!-- Calls the main function after the page has loaded. Container is dynamically created. --> | ||
|  | <body onload="main();"> | ||
|  | </body> | ||
|  | </html> |