Coverage Report - org.argouml.uml.diagram.ui.PathConvPercent2
 
Classes in this File Line Coverage Branch Coverage Complexity
PathConvPercent2
0%
0/34
0%
0/8
2
 
 1  
 /* $Id: PathConvPercent2.java 17865 2010-01-12 20:45:26Z linus $
 2  
  *****************************************************************************
 3  
  * Copyright (c) 2009 Contributors - see below
 4  
  * All rights reserved. This program and the accompanying materials
 5  
  * are made available under the terms of the Eclipse Public License v1.0
 6  
  * which accompanies this distribution, and is available at
 7  
  * http://www.eclipse.org/legal/epl-v10.html
 8  
  *
 9  
  * Contributors:
 10  
  *    tfmorris
 11  
  *****************************************************************************
 12  
  *
 13  
  * Some portions of this file was previously release using the BSD License:
 14  
  */
 15  
 
 16  
 // Copyright (c) 1996-2006 The Regents of the University of California. All
 17  
 // Rights Reserved. Permission to use, copy, modify, and distribute this
 18  
 // software and its documentation without fee, and without a written
 19  
 // agreement is hereby granted, provided that the above copyright notice
 20  
 // and this paragraph appear in all copies.  This software program and
 21  
 // documentation are copyrighted by The Regents of the University of
 22  
 // California. The software program and documentation are supplied "AS
 23  
 // IS", without any accompanying services from The Regents. The Regents
 24  
 // does not warrant that the operation of the program will be
 25  
 // uninterrupted or error-free. The end-user understands that the program
 26  
 // was developed for research purposes and is advised not to rely
 27  
 // exclusively on the program for any reason.  IN NO EVENT SHALL THE
 28  
 // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
 29  
 // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS,
 30  
 // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
 31  
 // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF
 32  
 // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY
 33  
 // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 34  
 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
 35  
 // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
 36  
 // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
 37  
 // UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
 38  
 
 39  
 package org.argouml.uml.diagram.ui;
 40  
 
 41  
 import java.awt.Point;
 42  
 
 43  
 import org.tigris.gef.base.PathConv;
 44  
 import org.tigris.gef.presentation.Fig;
 45  
 
 46  
 /**
 47  
  * Used to place labels as specific positions along a FigEdge. For example, a
 48  
  * label can be placed in the middle of a FigEdge by using 50%. This version
 49  
  * changes the behavior as it tries to avoid that the itemFig cuts through the
 50  
  * pathFig.
 51  
  *
 52  
  * @author abonner@ics.uci.edu
 53  
  */
 54  
 public class PathConvPercent2 extends PathConv {
 55  
 
 56  
     /**
 57  
      * The item Fig.
 58  
      */
 59  
     private Fig itemFig;
 60  
 
 61  
     /**
 62  
      * The percent.
 63  
      */
 64  
     private int percent;
 65  
 
 66  
     /**
 67  
      * The offset.
 68  
      */
 69  
     private int offset;
 70  
 
 71  
     /**
 72  
      * Constructor.
 73  
      *
 74  
      * @param theFig The Fig.
 75  
      * @param theItemFig The item Fig.
 76  
      * @param newPercent The percent.
 77  
      * @param newOffset The offset.
 78  
      */
 79  
     public PathConvPercent2(Fig theFig, Fig theItemFig, int newPercent,
 80  
             int newOffset) {
 81  0
         super(theFig);
 82  0
         itemFig = theItemFig;
 83  0
         setPercentOffset(newPercent, newOffset);
 84  0
     }
 85  
 
 86  
     /*
 87  
      * @see org.tigris.gef.base.PathConv#stuffPoint(java.awt.Point)
 88  
      */
 89  
     public void stuffPoint(Point res) {
 90  0
         int figLength = _pathFigure.getPerimeterLength();
 91  0
         if (figLength < 10) {
 92  0
             res.setLocation(_pathFigure.getCenter());
 93  0
             return;
 94  
         }
 95  0
         int pointToGet = (figLength * percent) / 100;
 96  
 
 97  0
         _pathFigure.stuffPointAlongPerimeter(pointToGet, res);
 98  
 
 99  0
         applyOffsetAmount(_pathFigure.pointAlongPerimeter(pointToGet + 5),
 100  
                 _pathFigure.pointAlongPerimeter(pointToGet - 5), offset, res);
 101  0
     }
 102  
 
 103  
     /**
 104  
      * Set the percent and offset again.
 105  
      *
 106  
      * @param newPercent The new percent.
 107  
      * @param newOffset The new offset.
 108  
      */
 109  
     public void setPercentOffset(int newPercent, int newOffset) {
 110  0
         percent = newPercent;
 111  0
         offset = newOffset;
 112  0
     }
 113  
 
 114  
     /*
 115  
      * @see org.tigris.gef.base.PathConv#setClosestPoint(java.awt.Point)
 116  
      */
 117  
     public void setClosestPoint(Point newPoint) {
 118  0
     }
 119  
 
 120  
     /*
 121  
      * @see org.tigris.gef.base.PathConv#applyOffsetAmount(java.awt.Point, java.awt.Point, int, java.awt.Point)
 122  
      */
 123  
     protected void applyOffsetAmount(
 124  
             Point p1, Point p2,
 125  
             int theOffset, Point res) {
 126  
         // slope of the line we're finding the normal to
 127  
         // is slope, and the normal is the negative reciprocal
 128  
         // slope is (p1.y - p2.y) / (p1.x - p2.x)
 129  
         // so recip is - (p1.x - p2.x) / (p1.y - p2.y)
 130  0
         int recipnumerator = (p1.x - p2.x) * -1;
 131  0
         int recipdenominator = (p1.y - p2.y);
 132  
 
 133  0
         if (recipdenominator == 0 && recipnumerator == 0) {
 134  0
             return;
 135  
         }
 136  
 
 137  
 
 138  
         // find the point offset on the line that gives a
 139  
         // correct offset
 140  
 
 141  0
         double len =
 142  
             Math.sqrt(recipnumerator * recipnumerator
 143  
                 + recipdenominator * recipdenominator);
 144  0
         int dx = (int) ((recipdenominator * theOffset) / len);
 145  0
         int dy = (int) ((recipnumerator * theOffset) / len);
 146  
 
 147  0
         res.x += Math.abs(dx);
 148  0
         res.y -= Math.abs(dy);
 149  
 
 150  0
         int width = itemFig.getWidth() / 2;
 151  
 
 152  0
         if (recipnumerator != 0) {
 153  0
             double slope = (double) recipdenominator / (double) recipnumerator;
 154  
 
 155  0
             double factor = tanh(slope);
 156  0
             res.x += (Math.abs(factor) * width);
 157  0
         } else {
 158  0
             res.x += width;
 159  
         }
 160  0
     }
 161  
 
 162  
     /**
 163  
      * Calculate the tangens hyperbolicus.
 164  
      *
 165  
      * @param x The argument.
 166  
      * @return tangens hyberbolicus
 167  
      */
 168  
     private double tanh(double x) {
 169  0
         return ((Math.exp(x) - Math.exp(-x)) / 2)
 170  
             / ((Math.exp(x) + Math.exp(-x)) / 2);
 171  
     }
 172  
 
 173  
     /**
 174  
      * The UID.
 175  
      */
 176  
     private static final long serialVersionUID = -8079350336685789199L;
 177  
 }