use of org.knime.workbench.editor2.editparts.WorkflowInPortEditPart in project knime-core by knime.
the class NodeContainerEditPart method stateChanged.
/**
* {@inheritDoc}
*/
@Override
public void stateChanged(final NodeStateEvent state) {
// works because we are retrieving the current state information!
if (m_updateInProgress.compareAndSet(false, true)) {
Display display = Display.getDefault();
if (display.isDisposed()) {
return;
}
display.asyncExec(new Runnable() {
@Override
public void run() {
// let others know we are in the middle of processing
// this update - they will now need to start their own job.
NodeContainerFigure fig = (NodeContainerFigure) getFigure();
m_updateInProgress.set(false);
if (isActive()) {
NodeContainerUI nc = getNodeContainer();
fig.setStateFromNC(nc);
updateNodeMessage();
// reset the tooltip text of the outports
for (Object part : getChildren()) {
if (part instanceof NodeOutPortEditPart || part instanceof WorkflowInPortEditPart || part instanceof MetaNodeOutPortEditPart) {
AbstractPortEditPart outPortPart = (AbstractPortEditPart) part;
outPortPart.rebuildTooltip();
}
}
// always refresh visuals (does not seem to do anything
// by default though: call repaints on updated figures).
refreshVisuals();
}
}
});
}
}
use of org.knime.workbench.editor2.editparts.WorkflowInPortEditPart in project knime-core by knime.
the class SnapToPortGeometry method snapRectangle.
/**
* {@inheritDoc}
*/
@Override
public int snapRectangle(final Request request, int snapOrientation, PrecisionRectangle baseRect, final PrecisionRectangle result) {
assert (request instanceof ChangeBoundsRequest) : "Unexpected request type: " + request.getClass();
ChangeBoundsRequest changeBoundsRequest = (ChangeBoundsRequest) request;
baseRect = baseRect.getPreciseCopy();
makeRelative(m_container.getContentPane(), baseRect);
PrecisionRectangle correction = new PrecisionRectangle();
makeRelative(m_container.getContentPane(), correction);
// Recalculate snapping locations if needed
boolean isClone = request.getType().equals(RequestConstants.REQ_CLONE);
List exclusionSet = null;
if (m_rows == null || m_cols == null || isClone != m_cachedCloneBool) {
m_cachedCloneBool = isClone;
exclusionSet = Collections.EMPTY_LIST;
if (!isClone) {
exclusionSet = changeBoundsRequest.getEditParts();
}
populateRowsAndCols(generateSnapPartsList(exclusionSet), exclusionSet);
}
if ((snapOrientation & HORIZONTAL) != 0) {
double xcorrect = getCorrectionFor(m_cols, changeBoundsRequest.getExtendedData(), true, baseRect.preciseX, baseRect.preciseRight());
if (xcorrect != THRESHOLD) {
snapOrientation &= ~HORIZONTAL;
correction.preciseX += xcorrect;
}
}
// get y values of the draged node part ports
if (exclusionSet != null) {
List<AbstractPortEditPart> ports = getPorts(exclusionSet);
Entry[] yValues = new Entry[ports.size()];
int i = 0;
for (AbstractPortEditPart port : ports) {
boolean inport = false;
if (port instanceof NodeInPortEditPart || port instanceof WorkflowInPortEditPart) {
inport = true;
}
yValues[i] = new Entry(0, getFigureBounds(port).getLeft().y, inport, port.getType());
i++;
}
m_yValues = yValues;
}
// get the move delta of the orignial location
Point moveDeltaPoint = changeBoundsRequest.getMoveDelta();
WorkflowEditor.adaptZoom(m_zoomManager, moveDeltaPoint, false);
int moveDelta = moveDeltaPoint.y;
if ((snapOrientation & VERTICAL) != 0) {
double ycorrect = THRESHOLD;
ycorrect = getCorrectionForY(m_rows, changeBoundsRequest.getExtendedData(), m_yValues, moveDelta);
if (Math.abs(ycorrect) < THRESHOLD) {
snapOrientation &= ~VERTICAL;
correction.preciseY += ycorrect;
}
}
if ((snapOrientation & EAST) != 0) {
double rightCorrection = getCorrectionFor(m_cols, request.getExtendedData(), true, baseRect.preciseRight() - 1, 1);
if (rightCorrection != THRESHOLD) {
snapOrientation &= ~EAST;
correction.preciseWidth += rightCorrection;
}
}
if ((snapOrientation & WEST) != 0) {
double leftCorrection = getCorrectionFor(m_cols, request.getExtendedData(), true, baseRect.preciseX, -1);
if (leftCorrection != THRESHOLD) {
snapOrientation &= ~WEST;
correction.preciseWidth -= leftCorrection;
correction.preciseX += leftCorrection;
}
}
if ((snapOrientation & SOUTH) != 0) {
double bottom = getCorrectionFor(m_rows, request.getExtendedData(), false, baseRect.preciseBottom() - 1, 1);
if (bottom != THRESHOLD) {
snapOrientation &= ~SOUTH;
correction.preciseHeight += bottom;
}
}
if ((snapOrientation & NORTH) != 0) {
double topCorrection = getCorrectionFor(m_rows, request.getExtendedData(), false, baseRect.preciseY, -1);
if (topCorrection != THRESHOLD) {
snapOrientation &= ~NORTH;
correction.preciseHeight -= topCorrection;
correction.preciseY += topCorrection;
}
}
correction.updateInts();
makeAbsolute(m_container.getContentPane(), correction);
result.preciseX += correction.preciseX;
result.preciseY += correction.preciseY;
result.preciseWidth += correction.preciseWidth;
result.preciseHeight += correction.preciseHeight;
result.updateInts();
return snapOrientation;
}
Aggregations