Skip to content

Commit

Permalink
fix(FreehandMouseTool): Small fixes to the freehand tool in the curre…
Browse files Browse the repository at this point in the history
…nt multipart-tool framework.

Scrolling whilst drawing finished the previous annotation and closes it. Edit no longer broken.
Cannot draw 2 points polygon.
  • Loading branch information
James Petts committed Mar 11, 2019
1 parent 59f7054 commit dc62726
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 22 deletions.
2 changes: 0 additions & 2 deletions examples-old/freehand/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -301,8 +301,6 @@ <h1>Freehand Sculpter Mouse Tool API</h1>
const mouseButtonMask = evt.buttons
? evt.buttons
: convertMouseEventWhichToButtons(evt.which)
// TODO: Let's make this happen automagically for mask/touch conflicts?
setAllToolsPassive();
const toolType = evt.target.getAttribute('data-tool-type')
setButtonActive(toolName, mouseButtonMask, toolType);
cornerstoneTools.setToolActive(toolName, { mouseButtonMask });
Expand Down
77 changes: 57 additions & 20 deletions src/tools/annotation/FreehandMouseTool.js
Original file line number Diff line number Diff line change
Expand Up @@ -514,8 +514,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
addNewMeasurement(evt) {
const eventData = evt.detail;

this._drawing = true;

this._startDrawing(eventData);
this._addPoint(eventData);

Expand Down Expand Up @@ -571,7 +569,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
this._activateModify(element);

// Interupt eventDispatchers
state.isMultiPartToolActive = true;

preventPropagation(evt);
}
Expand Down Expand Up @@ -658,10 +655,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
_drawingMouseUpCallback(evt) {
const eventData = evt.detail;

if (!this.options.mouseButtonMask.includes(eventData.buttons)) {
return;
}

if (!this._dragging) {
return;
}
Expand Down Expand Up @@ -795,10 +788,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
_editMouseUpCallback(evt) {
const eventData = evt.detail;

if (!this.options.mouseButtonMask.includes(eventData.buttons)) {
return;
}

const element = eventData.element;
const toolState = getToolState(eventData.element, this.name);

Expand All @@ -807,8 +796,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
this._dropHandle(eventData, toolState);
this._endDrawing(element);

state.isMultiPartToolActive = false;

external.cornerstone.updateImage(eventData.element);
}

Expand Down Expand Up @@ -865,7 +852,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
const config = this.configuration;

// Block event distpatcher whilst drawing
state.isMultiPartToolActive = true;

this._referencedElement = element;

Expand All @@ -877,6 +863,8 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
const toolState = getToolState(eventData.element, this.name);

config.currentTool = toolState.data.length - 1;

config.activeDrawingToolReference = toolState.data[config.currentTool];
}

/**
Expand Down Expand Up @@ -976,8 +964,6 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
data.canComplete = false;

if (this._drawing) {
this._drawing = false;
state.isMultiPartToolActive = false;
this._deactivateDraw(element);
}

Expand Down Expand Up @@ -1118,7 +1104,11 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
mousePoint
);

if (mouseAtOriginHandle && !freehandIntersect.end(points)) {
if (
mouseAtOriginHandle &&
!freehandIntersect.end(points) &&
points.length > 2
) {
data.canComplete = true;
invalidHandlePlacement = false;
} else {
Expand Down Expand Up @@ -1276,6 +1266,9 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
* @returns {undefined}
*/
_activateDraw(element) {
this._drawing = true;
state.isMultiPartToolActive = true;

// Polygonal Mode
element.addEventListener(EVENTS.MOUSE_DOWN, this._drawingMouseDownCallback);
element.addEventListener(EVENTS.MOUSE_MOVE, this._drawingMouseMoveCallback);
Expand All @@ -1296,6 +1289,10 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
* @returns {undefined}
*/
_deactivateDraw(element) {
this._drawing = false;
state.isMultiPartToolActive = false;
this.configuration.activeDrawingToolReference = null;

element.removeEventListener(
EVENTS.MOUSE_DOWN,
this._drawingMouseDownCallback
Expand All @@ -1322,6 +1319,8 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
* @returns {undefined}
*/
_activateModify(element) {
state.isToolLocked = true;

element.addEventListener(EVENTS.MOUSE_UP, this._editMouseUpCallback);
element.addEventListener(EVENTS.MOUSE_DRAG, this._editMouseDragCallback);
element.addEventListener(EVENTS.MOUSE_CLICK, this._editMouseUpCallback);
Expand All @@ -1338,6 +1337,8 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
* @returns {undefined}
*/
_deactivateModify(element) {
state.isToolLocked = false;

element.removeEventListener(EVENTS.MOUSE_UP, this._editMouseUpCallback);
element.removeEventListener(EVENTS.MOUSE_DRAG, this._editMouseDragCallback);
element.removeEventListener(EVENTS.MOUSE_CLICK, this._editMouseUpCallback);
Expand Down Expand Up @@ -1453,7 +1454,7 @@ export default class FreehandMouseTool extends BaseAnnotationTool {
*
* @public
* @param {Object} element - The element on which the roi is being drawn.
* @returns {undefined}
* @returns {null}
*/
cancelDrawing(element) {
if (!this._drawing) {
Expand All @@ -1476,8 +1477,43 @@ export default class FreehandMouseTool extends BaseAnnotationTool {

removeToolState(element, this.name, data);

this._drawing = false;
state.isMultiPartToolActive = false;
this._deactivateDraw(element);

external.cornerstone.updateImage(element);
}

/**
* newImageCallback - new image event handler.
*
* @public
* @param {object} evt The event.
* @returns {null}
*/
newImageCallback(evt) {
const config = this.configuration;

if (!(this._drawing && config.activeDrawingToolReference)) {
return;
}

// Actively drawing but scrolled to different image.

const element = evt.detail.element;
const data = config.activeDrawingToolReference;

data.active = false;
data.highlight = false;
data.handles.invalidHandlePlacement = false;

// Connect the end handle to the origin handle
const points = data.handles.points;
points[config.currentHandle - 1].lines.push(points[0]);

// Reset the current handle
config.currentHandle = 0;
config.currentTool = -1;
data.canComplete = false;

this._deactivateDraw(element);

external.cornerstone.updateImage(element);
Expand All @@ -1501,6 +1537,7 @@ function defaultFreehandConfiguration() {
invalidColor: 'crimson',
currentHandle: 0,
currentTool: -1,
activeDrawingToolReference: null,
};
}

Expand Down

0 comments on commit dc62726

Please sign in to comment.