/* ****************************************************************************** * Copyright (c) 2006-2012 XMind Ltd. and others. * * This file is a part of XMind 3. XMind releases 3 and * above are dual-licensed under the Eclipse Public License (EPL), * which is available at http://www.eclipse.org/legal/epl-v10.html * and the GNU Lesser General Public License (LGPL), * which is available at http://www.gnu.org/licenses/lgpl.html * See http://www.xmind.net/license.html for details. * * Contributors: * XMind Ltd. - initial API and implementation *******************************************************************************/ package org.xmind.ui.internal.decorations; import org.eclipse.draw2d.IFigure; import org.xmind.gef.draw2d.geometry.PrecisionPoint; import org.xmind.gef.draw2d.graphics.Path; import org.xmind.ui.decorations.AbstractSummaryDecoration; public class SquareSummaryDecoration extends AbstractSummaryDecoration { private static PrecisionPoint se = new PrecisionPoint(); private static PrecisionPoint te = new PrecisionPoint(); private static PrecisionPoint ce = new PrecisionPoint(); public SquareSummaryDecoration() { } public SquareSummaryDecoration(String id) { super(id); } protected void route(IFigure figure, Path shape) { PrecisionPoint sp = getSourcePosition(figure); PrecisionPoint tp = getTargetPosition(figure); PrecisionPoint cp = getConclusionPoint(figure); boolean horizontal = isHorizontal(); if (horizontal) { double x = calculateCenterX(sp, tp, cp); se.setLocation(x, sp.y); te.setLocation(x, tp.y); ce.setLocation(x, cp.y); } else { double y = calculateCenterY(sp, tp, cp); se.setLocation(sp.x, y); te.setLocation(tp.x, y); ce.setLocation(cp.x, y); } shape.moveTo(sp); shape.lineTo(se); shape.lineTo(te); shape.lineTo(tp); shape.moveTo(ce); shape.lineTo(cp); } private double calculateCenterX(PrecisionPoint sp, PrecisionPoint tp, PrecisionPoint cp) { double x1 = (sp.x + cp.x) / 2; double x2 = (tp.x + cp.x) / 2; return (Math.abs(x1 - cp.x) < Math.abs(x2 - cp.x)) ? x1 : x2; } private double calculateCenterY(PrecisionPoint sp, PrecisionPoint tp, PrecisionPoint cp) { double y1 = (sp.y + cp.y) / 2; double y2 = (tp.y + cp.y) / 2; return (Math.abs(y1 - cp.y) < Math.abs(y2 - cp.y)) ? y1 : y2; } }