📄 move.js
字号:
/* vim: set expandtab sw=4 ts=4 sts=4: *//** * @version $Id: move.js 11274 2008-05-14 17:30:33Z lem9 $ * @author Ivan A Kirillov (Ivan.A.Kirillov@gmail.com) * @package phpMyAdmin-Designer *//** * init */var dx, dy, dy2;var cur_click;// update in Main()var sm_x = 2, sm_y = 2;var sm_s = 0;var sm_add = 10;var s_left = 0;var s_right = 0;var ON_relation = 0;var ON_grid = 0;var ON_display_field = 0;// relation_style: 0 - angular 1 - directvar ON_angular_direct = 1;var click_field = 0;var link_relation = "";var id_hint;var canvas_width = 0;var canvas_height = 0;var osn_tab_width = 0;var osn_tab_height = 0;var height_field = 7;var Glob_X, Glob_Y;var timeoutID;var layer_menu_cur_click = 0;var step = 10;var old_class;//------------------------------------------------------------------------------//------------------------------------------------------------------------------//------------------------------------------------------------------------------//window.captureEvents(Event.MOUSEDOWN | Event.MOUSEUP);//---CROSSdocument.onmousedown = MouseDown;document.onmouseup = MouseUp;document.onmousemove = MouseMove;var isIE = document.all && !window.opera;var isNN = !document.all && document.getElementById;var isN4 = document.layers;if (isIE) { window.onscroll = General_scroll; document.onselectstart = function () {return false;};}//document.onmouseup = function(){General_scroll_end();}function MouseDown(e){ var offsetx, offsety; if (cur_click != null) { offsetx = isIE ? event.clientX + document.body.scrollLeft : e.pageX; offsety = isIE ? event.clientY + document.body.scrollTop : e.pageY; dx = offsetx - parseInt(cur_click.style.left); dy = offsety - parseInt(cur_click.style.top); //alert(" dx = " + dx + " dy = " +dy); document.getElementById("canvas").style.visibility = 'hidden'; /* var left = parseInt(cur_click.style.left); var top = parseInt(cur_click.style.top); dx = e.pageX - left; dy = e.pageY - top; alert(" dx = " + dx + " dy = " +dy); */ cur_click.style.zIndex = 2; } if (layer_menu_cur_click) { offsetx = isIE ? event.clientX + document.body.scrollLeft : e.pageX; dx = offsetx - parseInt(document.getElementById("layer_menu").style.width); }}function MouseMove(e){ //Glob_X = e.pageX; //Glob_Y = e.pageY; Glob_X = isIE ? event.clientX + document.body.scrollLeft : e.pageX; Glob_Y = isIE ? event.clientY + document.body.scrollTop : e.pageY; //mouseX = (bw.ns4||bw.ns6)? e.pageX: bw.ie&&bw.win&&!bw.ie4? (event.clientX-2)+document.body.scrollLeft : event.clientX+document.body.scrollLeft; //mouseY = (bw.ns4||bw.ns6)? e.pageY: bw.ie&&bw.win&&!bw.ie4? (event.clientY-2)+document.body.scrollTop : event.clientY+document.body.scrollTop; //window.status = "X = "+ Glob_X + " Y = "+ Glob_Y; if (cur_click != null) { var mGx = Glob_X - dx; var mGy = Glob_Y - dy; mGx = mGx > 0 ? mGx : 0; mGy = mGy > 0 ? mGy : 0; if (ON_grid) { mGx = mGx % step < step / 2 ? mGx - mGx % step : mGx - mGx % step + step; mGy = mGy % step < step / 2 ? mGy - mGy % step : mGy - mGy % step + step; } cur_click.style.left = mGx + 'px'; cur_click.style.top = mGy + 'px'; } if (ON_relation || ON_display_field) { document.getElementById('hint').style.left = (Glob_X + 20) + 'px'; document.getElementById('hint').style.top = (Glob_Y + 20) + 'px'; } if (layer_menu_cur_click) { document.getElementById("layer_menu").style.width = ((Glob_X - dx) >= 150 ? Glob_X - dx : 150) + 'px'; //document.getElementById("layer_menu").style.height = Glob_Y - dy>=200?Glob_Y - dy:200; //document.getElementById("id_scroll_tab").style.height = Glob_Y - dy2; }}function MouseUp(e){ if (cur_click != null) { document.getElementById("canvas").style.visibility = 'visible'; Re_load(); cur_click.style.zIndex = 1; cur_click = null; } layer_menu_cur_click = 0; //window.releaseEvents(Event.MOUSEMOVE);}//------------------------------------------------------------------------------//------------------------------------------------------------------------------//------------------------------------------------------------------------------//function ToInt(s)//{// return s.substring(0,s.length-2)*1; //re = /(\d+)\w*/; newstr = str.replace(re, "$1");//}function Canvas_pos(){ canvas_width = document.getElementById('canvas').width = osn_tab_width - 3; canvas_height = document.getElementById('canvas').height = osn_tab_height - 3; if (isIE) { document.getElementById('canvas').style.width = ((osn_tab_width - 3)?(osn_tab_width - 3):0) + 'px'; document.getElementById('canvas').style.height = ((osn_tab_height - 3)?(osn_tab_height - 3):0) + 'px'; }}function Osn_tab_pos(){ osn_tab_width = parseInt(document.getElementById('osn_tab').style.width); osn_tab_height = parseInt(document.getElementById('osn_tab').style.height);}function Main(){ //alert( document.getElementById('osn_tab').offsetTop); //---CROSS if (isIE) { document.getElementById('top_menu').style.position = 'absolute'; document.getElementById('layer_menu').style.position = 'absolute'; } document.getElementById("layer_menu").style.top = -1000 + 'px'; //fast scroll sm_x += document.getElementById('osn_tab').offsetLeft; sm_y += document.getElementById('osn_tab').offsetTop; Osn_tab_pos(); Canvas_pos(); Small_tab_refresh(); Re_load(); id_hint = document.getElementById('hint'); if (isIE) { General_scroll(); }}//-------------------------------- new -----------------------------------------function Rezize_osn_tab(){ var max_X = 0; var max_Y = 0; for (key in j_tabs) { var k_x = parseInt(document.getElementById(key).style.left) + document.getElementById(key).offsetWidth; var k_y = parseInt(document.getElementById(key).style.top) + document.getElementById(key).offsetHeight; max_X = max_X < k_x ? k_x : max_X; max_Y = max_Y < k_y ? k_y : max_Y; } osn_tab_width = max_X + 50; osn_tab_height = max_Y + 50; Canvas_pos(); document.getElementById('osn_tab').style.width = osn_tab_width + 'px'; document.getElementById('osn_tab').style.height = osn_tab_height + 'px';}//------------------------------------------------------------------------------/** * refreshes display, must be called after state changes */function Re_load(){ Rezize_osn_tab(); var n; var x1; var x2; var a = new Array(); Clear(); for (K in contr) for (key in contr[K]) // contr name for (key2 in contr[K][key]) // table name for (key3 in contr[K][key][key2]) // field name { if (!document.getElementById("check_vis_" + key2).checked || !document.getElementById("check_vis_" + contr[K][key][key2][key3][0]).checked) { // if hide continue; } var x1_left = document.getElementById(key2).offsetLeft+1; var x1_right = x1_left + document.getElementById(key2).offsetWidth; var x2_left = document.getElementById(contr[K][key][key2][key3][0]).offsetLeft; var x2_right = x2_left + document.getElementById(contr[K][key][key2][key3][0]).offsetWidth; a[0] = Math.abs(x1_left - x2_left); a[1] = Math.abs(x1_left - x2_right); a[2] = Math.abs(x1_right - x2_left); a[3] = Math.abs(x1_right - x2_right); n = s_left = s_right = 0; for (var i = 1; i < 4; i++) { if (a[n] > a[i]) { n = i; } } if (n == 1) { x1 = x1_left - sm_s; x2 = x2_right + sm_s; if (x1 < x2) { n = 0; } } if (n == 2) { x1 = x1_right + sm_s; x2 = x2_left - sm_s; if (x1 > x2) { n = 0; } } if (n == 3) { x1 = x1_right + sm_s; x2 = x2_right + sm_s; s_right = 1; } if (n == 0) { x1 = x1_left - sm_s; x2 = x2_left - sm_s; s_left = 1; } //alert(key2 + "." + key3); var row_offset_top = 0; //alert('id_tbody_' + key2); //alert(document.getElementById('id_hide_tbody_' + key2)); var tab_hide_button = document.getElementById('id_hide_tbody_' + key2); //alert(tab_hide_button.innerHTML); if (tab_hide_button.innerHTML == 'v') { row_offset_top = document.getElementById(key2 + "." + key3).offsetTop; } var y1 = document.getElementById(key2).offsetTop + row_offset_top + height_field; //alert(1); row_offset_top = 0; var tab_hide_button = document.getElementById('id_hide_tbody_' + contr[K][key][key2][key3][0]); if (tab_hide_button.innerHTML == 'v') { row_offset_top = document.getElementById(contr[K][key][key2][key3][0] + '.' + contr[K][key][key2][key3][1]).offsetTop; } var y2 = document.getElementById(contr[K][key][key2][key3][0]).offsetTop + row_offset_top + height_field; //alert(y1 + ' - ' + key2 + "." + key3); Line0(x1 - sm_x, y1 - sm_y, x2 - sm_x, y2 - sm_y, "rgba(0,100,150,1)"); }}/** * draws a line from x1:y1 to x2:y2 with color */function Line(x1, y1, x2, y2, color_line){ var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d"); ctx.strokeStyle = color_line; ctx.lineWidth = 1; ctx.beginPath();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -