diff --git a/editor/svg-editor.js b/editor/svg-editor.js index 12f2a70d..a880e987 100644 --- a/editor/svg-editor.js +++ b/editor/svg-editor.js @@ -164,41 +164,54 @@ function svg_edit_setup() { // called when we've selected a different element var selectedChanged = function(window,elems) { + + if (selectedElement && selectedElement.id.indexOf('pathpointgrip') == 0) { + $('#path_node_panel').hide(); + $('#tools_bottom_2,#tools_bottom_3').show(); + var size = $('#tool_select > svg, #tool_select > img')[0].getAttribute('width'); + $('#tool_select').empty().append($.getSvgIcon('select')); + $.resizeSvgIcons({'#tool_select .svg_icon':size}); + } + // if elems[1] is present, then we have more than one element selectedElement = (elems.length == 1 || elems[1] == null ? elems[0] : null); multiselected = (elems.length >= 2 && elems[1] != null); - var is_node = false; if (selectedElement != null) { // unless we're already in always set the mode of the editor to select because // upon creation of a text element the editor is switched into // select mode and this event fires - we need our UI to be in sync - is_node = !!(selectedElement.id && selectedElement.id.indexOf('pathpointgrip') == 0); - - if (svgCanvas.getMode() != "multiselect" && !is_node) { + if (svgCanvas.getMode() != "multiselect") { setSelectMode(); updateToolbar(); } + } // if (elem != null) - - - // Deal with pathedit mode - $('#path_node_panel').toggle(is_node); - $('#tools_bottom_2,#tools_bottom_3').toggle(!is_node); - var size = $('#tool_select > svg, #tool_select > img')[0].getAttribute('width'); - if(is_node) { - // Change select icon - $('.tool_button').removeClass('tool_button_current'); - $('#tool_select').addClass('tool_button_current') - .empty().append($.getSvgIcon('select_node')); - } else { - $('#tool_select').empty().append($.getSvgIcon('select')); - } - $.resizeSvgIcons({'#tool_select .svg_icon':size}); + updateContextPanel(); }; + + // called when we've selected a different path node + var selectedPathNodeChanged = function(window, elems) { + $('#path_node_panel').show(); + $('#tools_bottom_2,#tools_bottom_3').hide(); + var size = $('#tool_select > svg, #tool_select > img')[0].getAttribute('width'); + + // Change select icon + $('.tool_button').removeClass('tool_button_current'); + $('#tool_select').addClass('tool_button_current') + .empty().append($.getSvgIcon('select_node')); + + $.resizeSvgIcons({'#tool_select .svg_icon':size}); + + updateContextPanel(); + if(elems.length) { + selectedElement = elems[0]; +// multiselected = (elems.length >= 2); + } + }; // called when any element has changed var elementChanged = function(window,elems) { @@ -508,6 +521,7 @@ function svg_edit_setup() { // bind the selected event to our function that handles updates to the UI svgCanvas.bind("selected", selectedChanged); + svgCanvas.bind("nodeselected", selectedPathNodeChanged); svgCanvas.bind("changed", elementChanged); svgCanvas.bind("saved", saveHandler); svgCanvas.bind("zoomed", zoomChanged); @@ -523,7 +537,7 @@ function svg_edit_setup() { var color_blocks = ['#FFF','#888','#000']; // ,'url(%2F%2F%2F9bW1iH5BAAAAAAALAAAAAAQABAAAAIfjG%2Bgq4jM3IFLJgpswNly%2FXkcBpIiVaInlLJr9FZWAQA7)']; var str = ''; $.each(color_blocks, function() { - str += '
'; + str += '
'; }); $('#bg_blocks').append(str); var blocks = $('#bg_blocks div'); diff --git a/editor/svgcanvas.js b/editor/svgcanvas.js index d5cc6d3e..8a1cef13 100644 --- a/editor/svgcanvas.js +++ b/editor/svgcanvas.js @@ -2911,7 +2911,17 @@ function BatchCommand(text) { case "path": // fall through case "pathedit": + if(rubberBox && rubberBox.getAttribute('display') != 'none') { + assignAttributes(rubberBox, { + 'x': Math.min(start_x,x), + 'y': Math.min(start_y,y), + 'width': Math.abs(x-start_x), + 'height': Math.abs(y-start_y) + },100); + } + pathActions.mouseMove(mouse_x, mouse_y); + break; case "rotate": var box = canvas.getBBox(selected), @@ -3299,35 +3309,80 @@ function BatchCommand(text) { $('#ctrlpointgrip_container *').attr('display','none'); }; - + // var addNodeToSelection = function(points) { - // Currently only one node can be selected at a time, should allow more later - // Should point be the index or the grip element? +// var point = points; + if(!$.isArray(points)) points = [points]; - var point = points; -// if(!$.isArray(points)) points = [points]; -// -// $.merge(selected_pts, points); -// $.unique(selected_pts); + for(var i=0; i< points.length; i++) { + var pt = points[i]; + if($.inArray(pt, selected_pts) == -1) { + selected_pts.push(pt); + } + } + selected_pts.sort(); var is_closed = pathIsClosed(); + var i = selected_pts.length; var last_pt = current_path_pts.length/2 - 1; - - current_path_pt = point; - + var grips = new Array(i); + $('#pathpointgrip_container circle').attr('stroke','#00F'); - $('#pathpointgrip_' + point).attr('stroke','#0FF'); - var grip = $('#pathpointgrip_' + point); - $('#ctrlpointgrip_container circle').attr('fill', '#EEE'); - - $('#ctrlpointgrip_' + current_path_pt + 'c1, #ctrlpointgrip_' + current_path_pt + 'c2').attr('fill','#0FF'); + // Loop through points to be selected and highlight each + while(i--) { + var point = selected_pts[i]; + + $('#pathpointgrip_' + point).attr('stroke','#0FF'); + grips[i] = $('#pathpointgrip_' + point)[0]; + $('#ctrlpointgrip_container circle').attr('fill', '#EEE'); + $('#ctrlpointgrip_' + point + 'c1, #ctrlpointgrip_' + point + 'c2').attr('fill','#0FF'); + } + if(current_path_pt == -1) { + current_path_pt = selected_pts[0]; + } updateSegLine(); updateSegLine(true); - call("selected", [grip[0]]); - } + call("nodeselected", grips); + }; + + var removeNodeFromSelection = function(point) { + + var pos = $.inArray(point, selected_pts); + if(pos == -1) { + return; + } else { + selected_pts.splice(pos, 1); + } + + $('#pathpointgrip_' + point).attr('stroke','#00F'); + // grips[i] = $('#pathpointgrip_' + point)[0]; + $('#ctrlpointgrip_container circle').attr('fill', '#EEE'); + $('#ctrlpointgrip_' + point + 'c1, #ctrlpointgrip_' + point + 'c2').attr('fill','#0FF'); + + current_path_pt = selected_pts[0]; + updateSegLine(); + updateSegLine(true); + +// call("nodeselected", grips); + }; + + var removeAllNodesFromSelection = function() { + var i = selected_pts.length; + var last_pt = current_path_pts.length/2 - 1; + + $('#pathpointgrip_container circle').attr('stroke','#EEE'); + $('#ctrlpointgrip_container circle').attr('fill', '#EEE'); + selected_pts = []; +// call("nodeselected", []); + }; + + var selectNode = function(point) { + removeAllNodesFromSelection(); + addNodeToSelection(point); + }; var addAllPointGripsToPath = function(pointToSelect) { // loop through and show all pointgrips @@ -3374,7 +3429,7 @@ function BatchCommand(text) { setPointContainerTransform(xform); } if(pointToSelect != null) { - addNodeToSelection(pointToSelect); + selectNode(pointToSelect); } }; @@ -3601,9 +3656,13 @@ function BatchCommand(text) { addControlPointGrip(x2,y2, mouse_x,mouse_y, id1, true); } } - updateSegLine(); - if(next_type != 4) { - updateSegLine(true); + if(selected_pts.length > 1) { + getElem("segline").setAttribute('display','none'); + } else { + updateSegLine(); + if(next_type != 4) { + updateSegLine(true); + } } } @@ -3868,54 +3927,82 @@ function BatchCommand(text) { var id = evt.target.id; if (id.substr(0,14) == "pathpointgrip_") { // Select this point - current_path_pt_drag = parseInt(id.substr(14)); - addNodeToSelection(current_path_pt_drag); - updateSegLine(); + current_path_pt = current_path_pt_drag = parseInt(id.substr(14)); -// if(evt.shiftKey) { -// if(current_path_pt) -// } + // only clear selection if shift is not pressed (otherwise, add + // node to selection) + if (!evt.shiftKey) { + if(selected_pts.length <= 1 || $.inArray(current_path_pt, selected_pts) == -1) { + removeAllNodesFromSelection(); + } + addNodeToSelection(current_path_pt); + } else if($.inArray(current_path_pt, selected_pts) != -1) { + removeNodeFromSelection(current_path_pt); + } else { + addNodeToSelection(current_path_pt); + } +// justSelected = current_path_pt; + + updateSegLine(); + } else if(id.indexOf("ctrlpointgrip_") == 0) { current_ctrl_pt_drag = id.split('_')[1]; var node_num = current_ctrl_pt_drag.split('c')[0]-0; - addNodeToSelection(node_num); + selectNode(node_num); } if(current_path_pt_drag == -1 && current_ctrl_pt_drag == -1) { - // if we haven't moused down on a shape, then go into multiselect mode - // otherwise, select it - canvas.clearSelection(); - if (mouse_target.id != "svgroot") { - current_path = null; - canvas.addToSelection([mouse_target], true); - canvas.setMode("select"); - - // Insert the dummy transform here in case element is moved - var tlist = canvas.getTransformList(mouse_target); - tlist.insertItemBefore(svgroot.createSVGTransform(), 0); + +// start_x = x; +// start_y = y; + if (rubberBox == null) { + rubberBox = selectorManager.getRubberBandBox(); } - else { - canvas.setMode("multiselect"); - if (rubberBox == null) { - rubberBox = selectorManager.getRubberBandBox(); - } - assignAttributes(rubberBox, { - 'x': start_x, - 'y': start_y, + assignAttributes(rubberBox, { + 'x': start_x * current_zoom, + 'y': start_y * current_zoom, 'width': 0, 'height': 0, 'display': 'inline' - }, 100); - } + }, 100); + + + // if we haven't moused down on a shape, then go into multiselect mode + // otherwise, select it +// console.log('clear!') +// canvas.clearSelection(); +// if (mouse_target.id != "svgroot") { +// current_path = null; +// canvas.addToSelection([mouse_target], true); +// canvas.setMode("select"); +// +// // Insert the dummy transform here in case element is moved +// var tlist = canvas.getTransformList(mouse_target); +// tlist.insertItemBefore(svgroot.createSVGTransform(), 0); +// } +// else { +// canvas.setMode("multiselect"); +// if (rubberBox == null) { +// rubberBox = selectorManager.getRubberBandBox(); +// } +// assignAttributes(rubberBox, { +// 'x': start_x, +// 'y': start_y, +// 'width': 0, +// 'height': 0, +// 'display': 'inline' +// }, 100); +// } } }, mouseMove: function(mouse_x, mouse_y) { + hasMoved = true; if(current_mode == "path") { var line = getElem("path_stretch_line"); if (line) { - line.setAttribute("x2", x *= current_zoom); - line.setAttribute("y2", y *= current_zoom); + line.setAttribute("x2", mouse_x); + line.setAttribute("y2", mouse_y); } return; } @@ -3923,7 +4010,17 @@ function BatchCommand(text) { // if we are dragging a point, let's move it if (current_path_pt_drag != -1 && current_path) { var old_path_pts = $.map(current_path_pts, function(n){return n/current_zoom;}); - updatePath(mouse_x, mouse_y, old_path_pts); + var diff_x = mouse_x - old_path_pts[current_path_pt*2]; + var diff_y = mouse_y - old_path_pts[current_path_pt*2+1]; +// console.log(diff_x, diff_y); + for(var i=0; i