Search in sources :

Example 1 with EConnectionCategory

use of org.talend.core.model.process.EConnectionCategory in project tdi-studio-se by Talend.

the class NodeAnchor method getDirectionPosition.

private Point getDirectionPosition(IConnection connection, Point figCenter, boolean isSource) {
    if (!DesignerPlugin.getDefault().getPreferenceStore().getBoolean(TalendDesignerPrefConstants.EDITOR_LINESTYLE)) {
        return null;
    }
    Dimension nodeSize = null;
    if (isSource) {
        nodeSize = this.source.getSize();
    } else {
        nodeSize = this.target.getSize();
    }
    EConnectionCategory category = null;
    EConnectionType lineStyle = null;
    if (connection != null) {
        lineStyle = connection.getLineStyle();
        category = lineStyle.getCategory();
    } else {
        lineStyle = ConnectionManager.getNewConnectionType();
        category = lineStyle.getCategory();
    }
    Point result = new Point(figCenter);
    if (category == EConnectionCategory.MAIN && lineStyle != EConnectionType.FLOW_REF) {
        if (isSource) {
            result.x = figCenter.x + nodeSize.width / 2;
        } else {
            result.x = figCenter.x - nodeSize.width / 2;
        }
        return result;
    } else if (category == EConnectionCategory.OTHER && (lineStyle == EConnectionType.FLOW_REF || lineStyle == EConnectionType.TABLE_REF)) {
        Rectangle sourceBounds = new Rectangle(this.source.getLocation(), this.source.getSize());
        Rectangle targetBounds = new Rectangle(this.target.getLocation(), this.target.getSize());
        if (isSource) {
            int sourceY = this.source.getPosY();
            int targetY = this.target.getPosY();
            if (sourceY <= targetY) {
                if ((targetBounds.getTopRight().y == sourceBounds.getBottomLeft().y)) {
                    result.y = figCenter.y - nodeSize.height / 2;
                } else {
                    result.y = figCenter.y + nodeSize.height / 2;
                }
            } else {
                if (targetBounds.getBottomLeft().y == sourceBounds.getTopRight().y) {
                    result.y = figCenter.y + nodeSize.height / 2;
                } else {
                    result.y = figCenter.y - nodeSize.height / 2;
                }
            }
            return result;
        }
        int sourceY = this.source.getPosY();
        int targetY = this.target.getPosY();
        if (sourceY < targetY) {
            result.y = figCenter.y - nodeSize.height / 2;
        } else {
            result.y = figCenter.y + nodeSize.height / 2;
        }
        return result;
    }
    return null;
}
Also used : Rectangle(org.eclipse.draw2d.geometry.Rectangle) EConnectionCategory(org.talend.core.model.process.EConnectionCategory) Dimension(org.eclipse.draw2d.geometry.Dimension) KeyPoint(org.talend.commons.ui.gmf.draw2d.LineSeg.KeyPoint) Point(org.eclipse.draw2d.geometry.Point) EConnectionType(org.talend.core.model.process.EConnectionType)

Example 2 with EConnectionCategory

use of org.talend.core.model.process.EConnectionCategory in project tdi-studio-se by Talend.

the class TalendBorderItemRectilinearRouter method manualHorizontalScrolBarCase.

private boolean manualHorizontalScrolBarCase(Connection conn) {
    PointList points = conn.getPoints();
    Point start = getStartPoint(conn);
    Point end = getEndPoint(conn);
    boolean handle = false;
    boolean processHandle = false;
    if ((request != null) && (request instanceof CreateConnectionRequest)) {
        start = conn.getSourceAnchor().getReferencePoint();
        CreateConnectionRequest createRequest = (CreateConnectionRequest) request;
        if (createRequest.getTargetEditPart() != null && createRequest.getTargetEditPart() != createRequest.getSourceEditPart() && createRequest.getTargetEditPart().getModel() instanceof Node) {
            PointList pointList = new PointList();
            conn.translateToRelative(start);
            pointList.addPoint(start);
            Point targetPoint = conn.getTargetAnchor().getReferencePoint();
            conn.translateToRelative(targetPoint);
            pointList.addPoint(targetPoint);
            conn.setPoints(pointList);
            handle = true;
        } else if (createRequest.getTargetEditPart() != null && createRequest.getTargetEditPart() != createRequest.getSourceEditPart() && createRequest.getTargetEditPart() instanceof ProcessPart) {
            processHandle = true;
        }
    }
    if (conn instanceof ConnectionFigure) {
        IConnection connection = ((ConnectionFigure) conn).getConnection();
        EConnectionType lineStyle = connection.getLineStyle();
        EConnectionCategory category = lineStyle.getCategory();
        if (category == EConnectionCategory.OTHER && (lineStyle == EConnectionType.ON_COMPONENT_ERROR || lineStyle == EConnectionType.ON_COMPONENT_OK || lineStyle == EConnectionType.ON_SUBJOB_ERROR || lineStyle == EConnectionType.ON_SUBJOB_OK || lineStyle == EConnectionType.RUN_IF)) {
            return handle || processHandle;
        }
    }
    if (!handle) {
        conn.translateToRelative(start);
        points.setPoint(start, 0);
        conn.translateToRelative(end);
        points.setPoint(end, points.size() - 1);
        conn.setPoints(points);
    }
    return handle || processHandle;
}
Also used : PointList(org.eclipse.draw2d.geometry.PointList) Node(org.talend.designer.core.ui.editor.nodes.Node) IConnection(org.talend.core.model.process.IConnection) EConnectionCategory(org.talend.core.model.process.EConnectionCategory) Point(org.eclipse.draw2d.geometry.Point) ProcessPart(org.talend.designer.core.ui.editor.process.ProcessPart) CreateConnectionRequest(org.eclipse.gef.requests.CreateConnectionRequest) EConnectionType(org.talend.core.model.process.EConnectionType)

Example 3 with EConnectionCategory

use of org.talend.core.model.process.EConnectionCategory in project tdi-studio-se by Talend.

the class TalendBorderItemRectilinearRouter method manualPosition.

private boolean manualPosition(Connection conn, boolean horizontalHandle) {
    boolean isCreation = false;
    boolean isReconnect = false;
    boolean alreadyHandle = false;
    if (!(conn instanceof PolylineConnectionEx)) {
        return false;
    }
    if (this.request != null) {
        if (request instanceof CreateConnectionRequest) {
            isCreation = true;
        } else if (request instanceof ReconnectRequest) {
            isReconnect = true;
        }
    }
    IConnection connection = null;
    EConnectionCategory category = null;
    EConnectionType lineStyle = null;
    Rectangle sourceBounds = null;
    Rectangle targetBounds = null;
    if (conn instanceof ConnectionFigure) {
        connection = ((ConnectionFigure) conn).getConnection();
        if (!(connection.getSource() instanceof Node)) {
            return false;
        }
        lineStyle = connection.getLineStyle();
        category = lineStyle.getCategory();
        sourceBounds = new Rectangle(((Node) connection.getSource()).getLocation(), ((Node) connection.getSource()).getSize());
        targetBounds = new Rectangle(((Node) connection.getTarget()).getLocation(), ((Node) connection.getTarget()).getSize());
    }
    if (lineStyle == null) {
        lineStyle = ConnectionManager.getNewConnectionType();
        category = lineStyle.getCategory();
    }
    if (isCreation) {
        if (((CreateConnectionRequest) request).getSourceEditPart() == null) {
            return false;
        }
        if ((((CreateConnectionRequest) request).getTargetEditPart() == null) || horizontalHandle) {
            if (conn.getPoints().size() <= 2) {
                makeUpConnection(conn);
            }
            return false;
        }
    }
    if ((sourceBounds == null) && isCreation) {
        Node source = (Node) ((CreateConnectionRequest) request).getSourceEditPart().getModel();
        if (source != null) {
            sourceBounds = new Rectangle(source.getLocation(), source.getSize());
        }
    }
    if ((targetBounds == null) && isCreation) {
        Object obj = ((CreateConnectionRequest) request).getTargetEditPart().getModel();
        if (obj instanceof Node) {
            Node target = (Node) obj;
            if (target != null) {
                targetBounds = new Rectangle(target.getLocation(), target.getSize());
            }
        } else {
            Point lastPoint = conn.getPoints().getLastPoint();
            targetBounds = new Rectangle(lastPoint, new Dimension(2 * OFFSET, 2 * OFFSET));
        }
    }
    if (isReconnect) {
        if (((ReconnectRequest) request).getTarget() != null) {
            Object obj = ((ReconnectRequest) request).getTarget().getModel();
            if (obj instanceof Node) {
                Node target = (Node) obj;
                if (target != null) {
                    targetBounds = new Rectangle(target.getLocation(), target.getSize());
                }
            }
        } else {
            Point lastPoint = conn.getPoints().getLastPoint();
            targetBounds = new Rectangle(lastPoint, new Dimension(2 * OFFSET, 2 * OFFSET));
        }
    }
    if (targetBounds == null) {
        return false;
    }
    ((PolylineConnectionEx) conn).setRoundedBendpointsRadius(32);
    PointList points = conn.getPoints();
    PointList pointList = new PointList();
    Point firstpoint = points.getFirstPoint();
    Point lastpoint = points.getLastPoint();
    if (category == EConnectionCategory.MAIN && lineStyle != EConnectionType.FLOW_REF) {
        if ((sourceBounds.x > targetBounds.x) && (sourceBounds.y == targetBounds.y)) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x + OFFSET, firstpoint.y);
            pointList.addPoint(firstpoint.x + OFFSET, firstpoint.y + 2 * OFFSET);
            pointList.addPoint(lastpoint.x - OFFSET, lastpoint.y + 2 * OFFSET);
            pointList.addPoint(lastpoint.x - OFFSET, lastpoint.y);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if ((sourceBounds.x > targetBounds.x) || (sourceBounds.getTopRight().x == targetBounds.getTopLeft().x) || ((sourceBounds.getTopLeft().x == targetBounds.getTopRight().x) && (sourceBounds.getTopLeft().y != targetBounds.getTopRight().y))) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x + OFFSET, firstpoint.y);
            pointList.addPoint(firstpoint.x + OFFSET, (sourceBounds.getCenter().y + targetBounds.getCenter().y) / 2);
            pointList.addPoint(lastpoint.x - OFFSET, (sourceBounds.getCenter().y + targetBounds.getCenter().y) / 2);
            pointList.addPoint(lastpoint.x - OFFSET, lastpoint.y);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if (sourceBounds.x == targetBounds.x) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x + 2 * OFFSET, firstpoint.y);
            pointList.addPoint(firstpoint.x + 2 * OFFSET, (sourceBounds.getCenter().y + targetBounds.getCenter().y) / 2);
            pointList.addPoint(lastpoint.x - 2 * OFFSET, (sourceBounds.getCenter().y + targetBounds.getCenter().y) / 2);
            pointList.addPoint(lastpoint.x - 2 * OFFSET, lastpoint.y);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if (Math.abs(sourceBounds.getCenter().y - targetBounds.getCenter().y) == 4 * OFFSET) {
            if ((firstpoint.x + lastpoint.x) / 2 - OFFSET <= firstpoint.x) {
                return false;
            }
            ((PolylineConnectionEx) conn).setRoundedBendpointsRadius(16);
        }
    } else if (category == EConnectionCategory.OTHER && (lineStyle == EConnectionType.FLOW_REF || lineStyle == EConnectionType.TABLE_REF)) {
        if (targetBounds.y == sourceBounds.y) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x, firstpoint.y + OFFSET);
            pointList.addPoint(lastpoint.x, firstpoint.y + OFFSET);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if ((targetBounds.getTopRight().y == sourceBounds.getBottomLeft().y)) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x, firstpoint.y - OFFSET);
            pointList.addPoint(lastpoint.x, firstpoint.y - OFFSET);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if (targetBounds.getBottomLeft().y == sourceBounds.getTopRight().y) {
            pointList.addPoint(firstpoint);
            pointList.addPoint(firstpoint.x, firstpoint.y + OFFSET);
            pointList.addPoint(lastpoint.x, firstpoint.y + OFFSET);
            pointList.addPoint(lastpoint);
            alreadyHandle = true;
        } else if (Math.abs(sourceBounds.x - targetBounds.x) == 4 * OFFSET) {
            ((PolylineConnectionEx) conn).setRoundedBendpointsRadius(16);
        }
    }
    if (alreadyHandle && pointList.size() > 0) {
        conn.setPoints(pointList);
    }
    return alreadyHandle;
}
Also used : ReconnectRequest(org.eclipse.gef.requests.ReconnectRequest) PointList(org.eclipse.draw2d.geometry.PointList) Node(org.talend.designer.core.ui.editor.nodes.Node) Rectangle(org.eclipse.draw2d.geometry.Rectangle) IConnection(org.talend.core.model.process.IConnection) EConnectionCategory(org.talend.core.model.process.EConnectionCategory) PolylineConnectionEx(org.eclipse.gmf.runtime.draw2d.ui.figures.PolylineConnectionEx) Point(org.eclipse.draw2d.geometry.Point) Dimension(org.eclipse.draw2d.geometry.Dimension) CreateConnectionRequest(org.eclipse.gef.requests.CreateConnectionRequest) EConnectionType(org.talend.core.model.process.EConnectionType)

Example 4 with EConnectionCategory

use of org.talend.core.model.process.EConnectionCategory in project tdi-studio-se by Talend.

the class DummyNodeAnchor method getDirectionPosition.

private Point getDirectionPosition(Point figCenter, Point reference) {
    Dimension nodeSize = this.source.getSize();
    EConnectionCategory category = null;
    EConnectionType lineStyle = null;
    if (connection != null) {
        lineStyle = connection.getLineStyle();
        category = lineStyle.getCategory();
    } else {
        lineStyle = ConnectionManager.getNewConnectionType();
        category = lineStyle.getCategory();
    }
    Point result = new Point(figCenter);
    if (category == EConnectionCategory.MAIN && lineStyle != EConnectionType.FLOW_REF) {
        if (!isTargetAnchor) {
            result.x = figCenter.x + nodeSize.width / 2;
        } else {
            result.x = figCenter.x - nodeSize.width / 2;
        }
        return result;
    } else if (category == EConnectionCategory.OTHER && (lineStyle == EConnectionType.FLOW_REF || lineStyle == EConnectionType.TABLE_REF)) {
        if (target != null) {
            int sourceY = this.source.getPosY();
            int targetY = this.target.getPosY();
            Rectangle sourceBounds = new Rectangle(this.source.getLocation(), this.source.getSize());
            Rectangle targetBounds = new Rectangle(this.target.getLocation(), this.target.getSize());
            if (!isTargetAnchor) {
                if (target.equals(source)) {
                    Point tempPoint = new Point(reference.x - nodeSize.width / 2, reference.y - nodeSize.height / 2);
                    targetBounds = new Rectangle(tempPoint, this.target.getSize());
                    targetY = reference.y - nodeSize.height / 2;
                }
                if (sourceY <= targetY) {
                    if ((targetBounds.getTopRight().y == sourceBounds.getBottomLeft().y)) {
                        result.y = figCenter.y - nodeSize.height / 2;
                    } else {
                        result.y = figCenter.y + nodeSize.height / 2;
                    }
                } else {
                    if (targetBounds.getBottomLeft().y == sourceBounds.getTopRight().y) {
                        result.y = figCenter.y + nodeSize.height / 2;
                    } else {
                        result.y = figCenter.y - nodeSize.height / 2;
                    }
                }
                return result;
            }
            //
            if (sourceY < targetY) {
                result.y = figCenter.y - nodeSize.height / 2;
            } else {
                result.y = figCenter.y + nodeSize.height / 2;
            }
            return result;
        }
    }
    return null;
}
Also used : Rectangle(org.eclipse.draw2d.geometry.Rectangle) EConnectionCategory(org.talend.core.model.process.EConnectionCategory) Dimension(org.eclipse.draw2d.geometry.Dimension) Point(org.eclipse.draw2d.geometry.Point) EConnectionType(org.talend.core.model.process.EConnectionType)

Aggregations

Point (org.eclipse.draw2d.geometry.Point)4 EConnectionCategory (org.talend.core.model.process.EConnectionCategory)4 EConnectionType (org.talend.core.model.process.EConnectionType)4 Dimension (org.eclipse.draw2d.geometry.Dimension)3 Rectangle (org.eclipse.draw2d.geometry.Rectangle)3 PointList (org.eclipse.draw2d.geometry.PointList)2 CreateConnectionRequest (org.eclipse.gef.requests.CreateConnectionRequest)2 IConnection (org.talend.core.model.process.IConnection)2 Node (org.talend.designer.core.ui.editor.nodes.Node)2 ReconnectRequest (org.eclipse.gef.requests.ReconnectRequest)1 PolylineConnectionEx (org.eclipse.gmf.runtime.draw2d.ui.figures.PolylineConnectionEx)1 KeyPoint (org.talend.commons.ui.gmf.draw2d.LineSeg.KeyPoint)1 ProcessPart (org.talend.designer.core.ui.editor.process.ProcessPart)1