Module implementing a graphics item for an association between two items.
| Center | 
| East | 
| Generalisation | 
| Imports | 
| NoRegion | 
| Normal | 
| North | 
| NorthEast | 
| NorthWest | 
| South | 
| SouthEast | 
| SouthWest | 
| West | 
| AssociationItem | Class implementing a graphics item for an association between two items. | 
| None | 
Class implementing a graphics item for an association between two items.
The association is drawn as an arrow starting at the first items and ending at the second.
| None | 
| None | 
| AssociationItem | Constructor | 
| __calculateEndingPoints_center | Private method to calculate the ending points of the association item. | 
| __calculateEndingPoints_rectangle | Private method to calculate the ending points of the association item. | 
| __findIntersection | Method to calculate the intersection point of two lines. | 
| __findPointRegion | Private method to find out, which region of rectangle rect contains the point (PosX, PosY) and returns the region number. | 
| __findRectIntersectionPoint | Private method to find the intersetion point of a line with a rectangle. | 
| __mapRectFromItem | Private method to map item's rectangle to this item's coordinate system. | 
| __updateEndPoint | Private method to update an endpoint. | 
| unassociate | Public method to unassociate from the widgets. | 
| widgetMoved | Public method to recalculate the association after a widget was moved. | 
| None | 
Constructor
Private method to calculate the ending points of the association item.
The ending points are calculated from the centers of the two associated items.
Private method to calculate the ending points of the association item.
The ending points are calculated by the following method.
For each item the diagram is divided in four Regions by its diagonals as indicated below
                   \  Region 2  /
                    \          /
                     |--------|
                     | \    / |
                     |  \  /  |
                     |   \/   |
            Region 1 |   /\   | Region 3
                     |  /  \  |
                     | /    \ |
                     |--------|
                    /          \
                   /  Region 4  \
        
Each diagonal is defined by two corners of the bounding rectangle
To calculate the start point we have to find out in which region (defined by itemA's diagonals) is itemB's TopLeft corner (lets call it region M). After that the start point will be the middle point of rectangle's side contained in region M.
To calculate the end point we repeat the above but in the opposite direction (from itemB to itemA)
Method to calculate the intersection point of two lines.
The first line is determined by the points p1 and p2, the second line by p3 and p4. If the intersection point is not contained in the segment p1p2, then it returns (-1.0, -1.0).
        For the function's internal calculations remember:
        QT coordinates start with the point (0,0) as the topleft corner
        and x-values increase from left to right and y-values increase
        from top to bottom; it means the visible area is quadrant I in
        the regular XY coordinate system
            Quadrant II     |   Quadrant I
           -----------------|-----------------
            Quadrant III    |   Quadrant IV
        
In order for the linear function calculations to work in this method we must switch x and y values (x values become y values and viceversa)
Private method to find out, which region of rectangle rect contains the point (PosX, PosY) and returns the region number.
Private method to find the intersetion point of a line with a rectangle.
Private method to map item's rectangle to this item's coordinate system.
Private method to update an endpoint.
Public method to unassociate from the widgets.
Public method to recalculate the association after a widget was moved.