From 6ed1c1a0b090fb709a1077b26d271190f46fa4d1 Mon Sep 17 00:00:00 2001 From: Paulo Veiga Date: Sat, 21 Jan 2012 15:30:39 -0300 Subject: [PATCH] Fix wrong connection line between lines and topics. --- mindplot/src/main/javascript/CentralTopic.js | 2 +- .../src/main/javascript/ConnectionLine.js | 4 +- mindplot/src/main/javascript/MainTopic.js | 30 ++++++++--- mindplot/src/main/javascript/Topic.js | 52 ++++++++++--------- 4 files changed, 52 insertions(+), 36 deletions(-) diff --git a/mindplot/src/main/javascript/CentralTopic.js b/mindplot/src/main/javascript/CentralTopic.js index a8714464..ed793c4e 100644 --- a/mindplot/src/main/javascript/CentralTopic.js +++ b/mindplot/src/main/javascript/CentralTopic.js @@ -32,7 +32,7 @@ mindplot.CentralTopic = new Class({ }); }, - workoutIncomingConnectionPoint : function(sourcePosition) { + workoutIncomingConnectionPoint : function() { return this.getPosition(); }, diff --git a/mindplot/src/main/javascript/ConnectionLine.js b/mindplot/src/main/javascript/ConnectionLine.js index 8da3c562..58121212 100644 --- a/mindplot/src/main/javascript/ConnectionLine.js +++ b/mindplot/src/main/javascript/ConnectionLine.js @@ -100,8 +100,8 @@ mindplot.ConnectionLine = new Class({ var targetPosition = targetTopic.getPosition(); var sPos,tPos; - sPos = sourceTopic.workoutOutgoingConnectionPoint(targetPosition, false); - tPos = targetTopic.workoutIncomingConnectionPoint(sourcePosition, false); + sPos = sourceTopic.workoutOutgoingConnectionPoint(targetPosition); + tPos = targetTopic.workoutIncomingConnectionPoint(sourcePosition); line2d.setFrom(tPos.x, tPos.y); line2d.setTo(sPos.x, sPos.y); diff --git a/mindplot/src/main/javascript/MainTopic.js b/mindplot/src/main/javascript/MainTopic.js index fc33bd73..033aadba 100644 --- a/mindplot/src/main/javascript/MainTopic.js +++ b/mindplot/src/main/javascript/MainTopic.js @@ -133,24 +133,38 @@ mindplot.MainTopic = new Class({ workoutOutgoingConnectionPoint : function(targetPosition) { $assert(targetPosition, 'targetPoint can not be null'); var pos = this.getPosition(); - var size = this.getSize(); - var isAtRight = mindplot.util.Shape.isAtRight(targetPosition, pos); var result; if (this.getShapeType() == mindplot.model.INodeModel.SHAPE_TYPE_LINE) { + result = new core.Point(); - if (!isAtRight) { - result.x = pos.x + (size.width / 2); + var groupPosition = this._elem2d.getPosition(); + var innerShareSize = this.getInnerShape().getSize(); + var isAtRight = mindplot.util.Shape.isAtRight(targetPosition, pos); + + if (innerShareSize) { + var magicCorrectionNumber = 0.3; + if (!isAtRight) { + result.x = groupPosition.x + innerShareSize.width - magicCorrectionNumber; + } else { + result.x = groupPosition.x + magicCorrectionNumber; + } + result.y = groupPosition.y + innerShareSize.height; } else { - result.x = pos.x - (size.width / 2); + // Hack: When the size has not being defined. This is because the node has not being added. + // Try to do our best ... + var size = this.getSize(); + if (!isAtRight) { + result.x = pos.x + (size.width / 2); + } else { + result.x = pos.x - (size.width / 2); + } + result.y = pos.y + (size.height / 2); } - result.y = pos.y + (size.height / 2); } else { result = mindplot.util.Shape.calculateRectConnectionPoint(pos, size, isAtRight, true); } - result.x = Math.ceil(result.x); - result.y = Math.ceil(result.y); return result; }, diff --git a/mindplot/src/main/javascript/Topic.js b/mindplot/src/main/javascript/Topic.js index 378f984e..ec553d14 100644 --- a/mindplot/src/main/javascript/Topic.js +++ b/mindplot/src/main/javascript/Topic.js @@ -175,11 +175,11 @@ mindplot.Topic = new Class({ result = new web2d.Rect(0.3, attributes); } else if (type == mindplot.model.INodeModel.SHAPE_TYPE_LINE) { - result = new web2d.Line({strokeColor:"#495879",strokeWidth:1, strokeOpacity:1}); + result = new web2d.Line({strokeColor:"#495879",strokeWidth:1}); result.setSize = function(width, height) { this.size = {width:width, height:height}; result.setFrom(0, height); - result.setTo(width + 1, height); + result.setTo(width, height); // Lines will have the same color of the default connection lines... var stokeColor = mindplot.ConnectionLine.getStrokeColor(); @@ -794,18 +794,19 @@ mindplot.Topic = new Class({ */ setPosition : function(point) { $assert(point, "position can not be null"); + point.x = Math.ceil(point.x); + point.y = Math.ceil(point.y); // Update model's position ... var model = this.getModel(); - var currentPos = model.getPosition(); - model.setPosition(point.x, point.y); + // Elements are positioned in the center. // All topic element must be positioned based on the innerShape. var size = this.getSize(); - var cx = Math.round(point.x - (size.width / 2)); - var cy = Math.round(point.y - (size.height / 2)); + var cx = point.x - (size.width / 2); + var cy = point.y - (size.height / 2); // Update visual position. this._elem2d.setPosition(cx, cy); @@ -974,30 +975,25 @@ mindplot.Topic = new Class({ }, - _setSize : function(size) { + setSize : function(size, force) { $assert(size, "size can not be null"); $assert($defined(size.width), "size seem not to be a valid element"); + size = {width:Math.ceil(size.width),height: Math.ceil(size.height)}; - mindplot.NodeGraph.prototype.setSize.call(this, size); - - var outerShape = this.getOuterShape(); - var innerShape = this.getInnerShape(); - - outerShape.setSize(size.width + 4, size.height + 6); - innerShape.setSize(parseInt(size.width), parseInt(size.height)); - - // Update the figure position(ej: central topic must be centered) and children position. var oldSize = this.getSize(); - this._updatePositionOnChangeSize(oldSize, size); + if (oldSize.width != size.width || oldSize.height != size.height || force) { + mindplot.NodeGraph.prototype.setSize.call(this, size); - mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.NodeResizeEvent, {node:this.getModel(),size:size}); + var outerShape = this.getOuterShape(); + var innerShape = this.getInnerShape(); - }, + outerShape.setSize(size.width + 4, size.height + 6); + innerShape.setSize(size.width, size.height); - setSize : function(size) { - var oldSize = this.getSize(); - if (parseInt(oldSize.width) != parseInt(size.width) || parseInt(oldSize.height) != parseInt(size.height)) { - this._setSize(size); + // Update the figure position(ej: central topic must be centered) and children position. + this._updatePositionOnChangeSize(oldSize, size); + + mindplot.EventBus.instance.fireEvent(mindplot.EventBus.events.NodeResizeEvent, {node:this.getModel(),size:size}); } }, @@ -1098,6 +1094,13 @@ mindplot.Topic = new Class({ var connector = targetTopic.getShrinkConnector(); connector.setVisibility(true); + // Create a connection line ... + var outgoingLine = new mindplot.ConnectionLine(this, targetTopic); + if ($defined(isVisible)) + outgoingLine.setVisibility(isVisible); + this._outgoingLine = outgoingLine; + workspace.appendChild(outgoingLine); + // Redraw line ... outgoingLine.redraw(); @@ -1198,8 +1201,7 @@ mindplot.Topic = new Class({ var height = textHeight + (topicPadding * 2); var width = textWidth + iconsWidth + (topicPadding * 2); - var size = {width:parseInt(width),height:parseInt(height)}; - this.setSize(size); + this.setSize({width:width,height:height}); // Position node ... textShape.setPosition(topicPadding + iconsWidth, topicPadding);