基于jtopo实现拖拽和连线

技术分享技术分享




</pre>上代码:<p></p><p></p><p>jtopoDemo.html</p><p></p><pre name="code" class="html"><!DOCTYPE html>
<html>
  <head>
    <title>拓扑</title>
	
    <meta name="keywords" content="keyword1,keyword2,keyword3">
    <meta name="description" content="this is my page">
    <meta name="content-type" content="text/html; charset=UTF-8">
    <!-- 配置自己的路径  -->
    <script type="text/javascript" src="../../view/common/js/jquery-2.2.3.min.js"></script>
    <script type="text/javascript" src="../../view/common/js/jtopo-0.4.8-min.js"></script>
  	
  	
  	<script type="text/javascript" src="js/conf.js"></script>
  	<script type="text/javascript" src="js/mytopo.js"></script>
  	<script type="text/javascript" src="js/toolbar.js"></script>
  	<script type="text/javascript" src="js/tooldrag.js"></script>
  	<link rel="stylesheet" type="text/css" href="css/base.css">
  </head>
  
  <body>
     拓扑测试<br>
	<div id="content" style="width:900px;position:relative;">
		<div style="width: 900px;height: 40px;border: 1px solid rgb(68, 68, 68);position:absolute; top:35px;">
			<!--原始节点  -->
			<canvas id='exchanger_icon' width='100' height='40' 
              draggable="true" ondragstart="drag(event)">
                                        当前浏览器无法使用canvas标签,请更换新版本浏览器
             </canvas>
             <canvas id='server_icon' width='100' height='40' 
              draggable="true" ondragstart="drag(event)">
                                        当前浏览器无法使用canvas标签,请更换新版本浏览器
             </canvas>
		</div>
		<div id="dst" ondrop="drop(event)" ondragover="allowDrop(event)">
             <canvas width="900px" height="550px" id="canvas" 
             style="border: 1px solid rgb(68, 68, 68);"  >
                                      当前浏览器无法使用canvas标签,请更换新版本浏览器</canvas>                    
        </div>	
		
		
	</div>
	<img alt="" src="" id="img" >
</body>
</html>



conf.js

var islink=false;  //是否默认连线

var nodelist=new Array(); 



mytopo.js

 $(document).ready(function(){
	
	 var canvas = document.getElementById('canvas'); 
	 stage = new JTopo.Stage(canvas); // 创建一个舞台对象
	 scene = new JTopo.Scene(stage); // 创建一个场景对象
	
	//显示工具栏
	showJTopoToobar(stage);

    stage.addEventListener("mouseover", function(event){
    	
    	 console.log("鼠标进入");
    	 
    	 
     });
     stage.addEventListener("mousedrag", function(event){
    	 
    	 console.log("拖拽");
    	 
     });
     
     stage.addEventListener("mouseup", function(event){
    	 
    	 if(event.button == 2){
    		 console.log ('松开右键');	
    		 
		 }else if(event.button == 1){
				console.log =('松开中键');					
		 }else if(event.button == 0){
			console.log ( '松开左键');	
		 }
    	 
     });
     
     stage.addEventListener("mousemove", function(event){
    	 
     });
     
 });
 
 
 //打印鼠标指针坐标
 function writeMessage (oGetMousePos,message) {
	 var oContext=oGetMousePos.getContext("2d");
     oContext.clearRect(0, 0, oGetMousePos.width, oGetMousePos.height);
     oContext.font = "20pt Microsoft JhengHei";
     oContext.fillStyle = "tomato";
     oContext.fillText(message, 10, 60);
 };
 
 
 
 
 //获取画布中鼠标的位置
 function getMousePos(canvas, evt, scene) { 
	   var rect = canvas.getBoundingClientRect(); 
	   
	   return { 
		   x: evt.clientX - rect.left * (canvas.width / rect.width)- (scene?scene.translateX:0),
		   y: evt.clientY - rect.top * (canvas.height / rect.height)- (scene?scene.translateY:0)
	   }
}
 

//绘制节点
 function draw(ev,data){
 	var mousePos = getMousePos(stage.canvas,ev,scene);
 	var message = "x:" + mousePos.x + ",y:" + mousePos.y;
 	console.log(message,data);
 	addNode(data,mousePos);
 	
 	//防止创建节点后连线
 	nodelist=[];
 }
 
 //添加节点
 function addNode(name,mousePos){
		var node = new JTopo.Node(name);
		node.setLocation(mousePos.x,mousePos.y);
	    node.setImage("img/"+name+".png"); 
	    node.shadow = "true";
	    //node.showSelected = "false";
	    scene.add(node);
	    node.dbclick(function(ev){
	    	console.log(node.text+"被点双击了");
	    });
	    node.mouseup(function(ev){
	    	console.log(node.text+"鼠标离开");
	    	
	    	//是否连线
	    	if(islink){
	    		nodelist.push(node);
	    		if(nodelist.length>=2&&nodelist[nodelist.length-1]!=nodelist[nodelist.length-2]){
	    			console.log("11");
	    			linkNode(nodelist[nodelist.length-1],nodelist[nodelist.length-2]);
	    			nodelist=[];
	    			
	    		}
	    	}
	    });
}
 

//增加连线
 function linkNode(nodeFrom,nodeTo){
	 var link = new JTopo.Link(nodeFrom, nodeTo); 
	 link.click(function(ev){
		 console.log("点击了连线");
	 });
	 link.click(function(ev){
		 console.log("点击了连线");
	 });
	 scene.add(link);
 }
 
 //删除节点或者连线
 function delNode(node){
	 scene.remove(node);
 }

toolbar.js  //jtopo的

// 页面工具栏
function showJTopoToobar(stage){
	var toobarDiv = $('<div class="jtopo_toolbar">').html(''
		+'<input type="radio" name="modeRadio" value="normal" checked id="r1"/>'
		+'<label for="r1"> 默认</label>'
		+' <input type="radio" name="modeRadio" value="select" id="r2"/><label for="r2"> 框选</label>'
		//+' <input type="radio" name="modeRadio" value="edit" id="r4"/><label for="r4"> 连线</label>'
		+'  <input type="button" id="centerButton" value="居中显示"/>'
		+'<input type="button" id="fullScreenButton" value="全屏显示"/>'
		+'<input type="button" id="zoomOutButton" value=" 放 大 " />'
		+'<input type="button" id="zoomInButton" value=" 缩 小 " />'
		+'  <input type="checkbox" id="linkCheckbox"/><label for="linkCheckbox">连接节点</label>'
		+'  <input type="checkbox" id="zoomCheckbox"/><label for="zoomCheckbox">鼠标缩放</label>'
		+'  <input type="checkbox" id="eyeCheckbox"/><label for="eyeCheckbox">鹰眼</label>'
		+'  <input type="text" id="findText" style="width: 100px;" value="" onkeydown="enterPressHandler(event)">'
		+ '<input type="button" id="findButton" value=" 查 询 ">' 
		+ '  <input type="button" id="cloneButton" value="选中克隆">'
		+'  <input type="button" id="exportButton" value="导出PNG">'
		+ '  <input type="button" id="printButton" value="导出PDF">');	
		
	$('#content').prepend(toobarDiv);

	// 工具栏按钮处理
	$("input[name='modeRadio']").click(function(){			
		stage.mode = $("input[name='modeRadio']:checked").val();
	});

	$('#centerButton').click(function(){
		stage.centerAndZoom(); //缩放并居中显示
	});
	$('#zoomOutButton').click(function(){
		stage.zoomOut();
	});
	$('#zoomInButton').click(function(){
		stage.zoomIn();
	});
	$('#cloneButton').click(function(){
		var img = document.getElementById('img'); 
		var c=stage.eagleEye.getImage();
		img.src =c;  
	});
	$('#exportButton').click(function() {
	    stage.saveImageInfo();
	});
	$('#printButton').click(function() {
	    stage.saveImageInfo();
	});
	$('#linkCheckbox').click(function(){
		islink=$('#linkCheckbox').is(':checked');
	});
	$('#zoomCheckbox').click(function(){
		if($('#zoomCheckbox').is(':checked')){
			stage.wheelZoom = 1.2; // 设置鼠标缩放比例
		}else{
			stage.wheelZoom = null; // 取消鼠标缩放比例
		}
	});
	$('#eyeCheckbox').click(function(){
		if($('#eyeCheckbox').is(':checked')){
			stage.eagleEye.visible = true;
		}else{
			stage.eagleEye.visible = false;
		}
	});
	$('#fullScreenButton').click(function(){
		runPrefixMethod(stage.canvas, "RequestFullScreen")
	});

	window.enterPressHandler = function (event){
		if(event.keyCode == 13 || event.which == 13){
			$('#findButton').click();
		}
	};
	
	// 查询
	$('#findButton').click(function(){
		var text = $('#findText').val().trim();
		//var nodes = stage.find('node[text="'+text+'"]');
		var scene = stage.childs[0];
		var nodes = scene.childs.filter(function(e){ 
			return e instanceof JTopo.Node; 
		});
		nodes = nodes.filter(function(e){
			if(e.text == null) return false;
			return e.text.indexOf(text) != -1;
		});
		
		if(nodes.length > 0){
			var node = nodes[0];
			node.selected = true;
			var location = node.getCenterLocation();
			// 查询到的节点居中显示
			stage.setCenter(location.x, location.y);
			
			function nodeFlash(node, n){
				if(n == 0) {
					node.selected = false;
					return;
				};
				node.selected = !node.selected;
				setTimeout(function(){
					nodeFlash(node, n-1);
				}, 300);
			}
			
			// 闪烁几下
			nodeFlash(node, 6);
		}
	});
}

var runPrefixMethod = function(element, method) {
	var usablePrefixMethod;
	["webkit", "moz", "ms", "o", ""].forEach(function(prefix) {
		if (usablePrefixMethod) return;
		if (prefix === "") {
			// 无前缀,方法首字母小写
			method = method.slice(0,1).toLowerCase() + method.slice(1);
		}
		var typePrefixMethod = typeof element[prefix + method];
		if (typePrefixMethod + "" !== "undefined") {
			if (typePrefixMethod === "function") {
				usablePrefixMethod = element[prefix + method]();
			} else {
				usablePrefixMethod = element[prefix + method];
			}
		}
	}
);

return usablePrefixMethod;
};
/*
runPrefixMethod(this, "RequestFullScreen");
if (typeof window.screenX === "number") {
var eleFull = canvas;
eleFull.addEventListener("click", function() {
	if (runPrefixMethod(document, "FullScreen") || runPrefixMethod(document, "IsFullScreen")) {
		runPrefixMethod(document, "CancelFullScreen");
		this.title = this.title.replace("退出", "");
	} else if (runPrefixMethod(this, "RequestFullScreen")) {
		this.title = this.title.replace("点击", "点击退出");
	}
});
} else {
alert("浏览器不支持");
}*/

tooldrag.js

//拖拽节点的初始化,以及拖拽拖拽操作

$(document).ready(function(){
	 init("server_icon");    //云主机
	 init("exchanger_icon"); //交换机
});

function init(id){
	var canvasSrc = document.getElementById(id);
	var contextSrc = canvasSrc.getContext('2d');
	var image = new Image();
	 image.src="img/"+id+".png";
	 image.onload=function(){
	         contextSrc.drawImage(image,0,0);
	 }
}



function allowDrop(ev){
        ev.preventDefault();
}

//拖拽开始
function drag(ev){
        ev.dataTransfer.setData("Text", ev.target.id);  
}

//拖拽结束
function drop(ev){
        //ev.preventDefault();
       var data = ev.dataTransfer.getData("Text");
        //ev.target.appendChild(document.getElementById(data));
        draw(ev,data);
}



文件格式:

技术分享
技术分享
技术分享




文章来自:http://blog.csdn.net/zw421152835/article/details/51280436
© 2021 jiaocheng.bubufx.com  联系我们
ICP备案:鲁ICP备09046678号-3