/*
* (c) Copyright 2010-2011 AgileBirds
*
* This file is part of OpenFlexo.
*
* OpenFlexo is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* OpenFlexo is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with OpenFlexo. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openflexo.fge.connectors.rpc;
import java.awt.event.MouseEvent;
import java.awt.geom.AffineTransform;
import java.util.logging.Logger;
import org.openflexo.fge.GraphicalRepresentation;
import org.openflexo.fge.controller.DrawingController;
import org.openflexo.fge.geom.FGEGeometricObject.SimplifiedCardinalDirection;
import org.openflexo.fge.geom.FGEPoint;
import org.openflexo.fge.geom.FGESegment;
import org.openflexo.fge.geom.area.FGEArea;
import org.openflexo.fge.geom.area.FGEEmptyArea;
import org.openflexo.fge.geom.area.FGEHalfPlane;
public class AdjustableFirstSegment extends RectPolylinAdjustableSegment {
static final Logger logger = Logger.getLogger(AdjustableFirstSegment.class.getPackage().getName());
private boolean consistentData = false;
private FGESegment currentSegment;
private FGESegment nextSegment;
private FGESegment afterNextSegment;
private SimplifiedCardinalDirection currentOrientation;
private SimplifiedCardinalDirection nextOrientation;
private FGEArea startArea;
private FGEArea draggingAuthorizedArea;
private void retrieveInfos() {
currentSegment = getArea();
nextSegment = getPolylin().getSegmentAt(1);
if (currentSegment.getApproximatedOrientation() == null || nextSegment.getApproximatedOrientation() == null) {
RectPolylinConnector.logger.warning("Inconsistent data while managing adjustable segment in RectPolylinConnector");
return;
}
if (getPolylin().getSegmentNb() > 2) {
afterNextSegment = getPolylin().getSegmentAt(2);
}
currentOrientation = currentSegment.getApproximatedOrientation();
nextOrientation = nextSegment.getApproximatedOrientation();
AffineTransform at1 = GraphicalRepresentation.convertNormalizedCoordinatesAT(getConnector().getStartObject(),
getGraphicalRepresentation());
startArea = getConnector().getStartObject().getShape().getOutline().transform(at1);
FGEArea orthogonalPerspectiveArea = startArea.getOrthogonalPerspectiveArea(currentOrientation);
if (!nextSegment.containsPoint(currentSegment.getP1())) {
FGEHalfPlane hp = new FGEHalfPlane(nextSegment, currentSegment.getP1());
draggingAuthorizedArea = orthogonalPerspectiveArea.intersect(hp);
} else {
draggingAuthorizedArea = orthogonalPerspectiveArea;
}
consistentData = true;
}
public AdjustableFirstSegment(FGESegment segment, RectPolylinConnector connector) {
super(segment, connector);
retrieveInfos();
}
@Override
public void startDragging(DrawingController controller, FGEPoint startPoint) {
super.startDragging(controller, startPoint);
retrieveInfos();
logger.info("Start dragging: " + draggingAuthorizedArea);
}
@Override
public FGEArea getDraggingAuthorizedArea() {
if (!consistentData) {
return new FGEEmptyArea();
}
return draggingAuthorizedArea;
}
@Override
public boolean dragToPoint(FGEPoint newRelativePoint, FGEPoint pointRelativeToInitialConfiguration, FGEPoint newAbsolutePoint,
FGEPoint initialPoint, MouseEvent event) {
FGEPoint pt = getNearestPointOnAuthorizedArea(newRelativePoint);
FGEPoint p1 = getPolylin().getFirstPoint();
if (p1 == null) {
logger.warning("Inconsistent data while managing adjustable segment in RectPolylinConnector");
return false;
}
FGEPoint p2 = getPolylin().getPointAt(1);
if (p2 == null) {
logger.warning("Inconsistent data while managing adjustable segment in RectPolylinConnector");
return false;
}
p1 = startArea.nearestPointFrom(pt, currentOrientation.getOpposite());
if (currentOrientation.isHorizontal()) {
p2.y = pt.y;
} else if (currentOrientation.isVertical()) {
p2.x = pt.x;
} else {
logger.warning("Inconsistent data while managing adjustable segment in RectPolylinConnector");
return false;
}
getPolylin().updatePointAt(0, p1);
getConnector()._getControlPoints().elementAt(0).setPoint(p1);
getPolylin().updatePointAt(1, p2);
getConnector()._getControlPoints().elementAt(1).setPoint(p2);
getConnector()._connectorChanged(true);
getGraphicalRepresentation().notifyConnectorChanged();
return true;
}
/*@Override
public void stopDragging(DrawingController controller)
{
if (afterNextSegment != null && afterNextSegment.overlap(currentSegment)) {
getConnector()._simplifyLayoutOfCurrentPolylinByDeletingTwoPoints(1);
}
super.stopDragging(controller);
}*/
}