Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

React UI: Batch of fixes #1445

Merged
merged 12 commits into from
Apr 22, 2020
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,13 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Fixed
- Auto annotation, TF annotation and Auto segmentation apps (https://github.com/opencv/cvat/pull/1409)
- Import works with truncated images now: "OSError:broken data stream" on corrupt images (https://github.com/opencv/cvat/pull/1430)
- Hide functionality (H) doesn't work (<https://github.com/opencv/cvat/pull/1445>)
- The highlighted attribute doesn't correspond to the chosen attribute in AAM (<https://github.com/opencv/cvat/pull/1445>)
- Inconvinient image shaking while drawing a polygon (hold Alt key during drawing/editing/grouping to drag an image) (<https://github.com/opencv/cvat/pull/1445>)
- Filter property "shape" doesn't work and extra operator in description (<https://github.com/opencv/cvat/pull/1445>)
- Block of text information doesn't disappear after deactivating for locked shapes (<https://github.com/opencv/cvat/pull/1445>)
- Annotation uploading fails in annotation view (<https://github.com/opencv/cvat/pull/1445>)
- UI freezes after canceling pasting with escape (<https://github.com/opencv/cvat/pull/1445>)
- Duplicating keypoints in COCO export (https://github.com/opencv/cvat/pull/1435)

### Security
Expand Down
4 changes: 3 additions & 1 deletion cvat-canvas/src/typescript/canvasModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -368,7 +368,9 @@ export class CanvasModelImpl extends MasterImpl implements CanvasModel {
}

public activate(clientID: number | null, attributeID: number | null): void {
if (this.data.activeElement.clientID === clientID) {
if (this.data.activeElement.clientID === clientID
&& this.data.activeElement.attributeID === attributeID
) {
return;
}

Expand Down
24 changes: 10 additions & 14 deletions cvat-canvas/src/typescript/canvasView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ export class CanvasViewImpl implements CanvasView, Listener {
});

this.canvas.dispatchEvent(event);
} else {
} else if (!continueDraw) {
const event: CustomEvent = new CustomEvent('canvas.canceled', {
bubbles: false,
cancelable: true,
Expand All @@ -107,12 +107,7 @@ export class CanvasViewImpl implements CanvasView, Listener {
this.canvas.dispatchEvent(event);
}

if (continueDraw) {
this.drawHandler.draw(
this.controller.drawData,
this.geometry,
);
} else {
if (!continueDraw) {
this.mode = Mode.IDLE;
this.controller.draw({
enabled: false,
Expand Down Expand Up @@ -672,8 +667,10 @@ export class CanvasViewImpl implements CanvasView, Listener {
});

this.content.addEventListener('mousedown', (event): void => {
if ([1, 2].includes(event.which)) {
if (![Mode.ZOOM_CANVAS, Mode.GROUP].includes(this.mode) || event.which === 2) {
if ([0, 1].includes(event.button)) {
if ([Mode.IDLE, Mode.DRAG, Mode.MERGE, Mode.SPLIT].includes(this.mode)
|| event.button === 1 || event.altKey
) {
self.controller.enableDrag(event.clientX, event.clientY);
}
}
Expand Down Expand Up @@ -1379,11 +1376,6 @@ export class CanvasViewImpl implements CanvasView, Listener {
}
});

this.activeElement = {
...this.activeElement,
clientID,
};

this.canvas.dispatchEvent(new CustomEvent('canvas.activated', {
bubbles: false,
cancelable: true,
Expand All @@ -1407,6 +1399,10 @@ export class CanvasViewImpl implements CanvasView, Listener {
const { clientID, attributeID } = activeElement;
if (clientID !== null && this.activeElement.clientID !== clientID) {
this.activateShape(clientID);
this.activeElement = {
...this.activeElement,
clientID,
};
}

if (clientID !== null
Expand Down
68 changes: 19 additions & 49 deletions cvat-canvas/src/typescript/drawHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,10 @@
// SPDX-License-Identifier: MIT

import * as SVG from 'svg.js';
import consts from './consts';
import 'svg.draw.js';
import './svg.patch';

import { AutoborderHandler } from './autoborderHandler';

import {
translateToSVG,
displayShapeSize,
Expand All @@ -18,7 +16,7 @@ import {
BBox,
Box,
} from './shared';

import consts from './consts';
import {
DrawData,
Geometry,
Expand Down Expand Up @@ -136,7 +134,6 @@ export class DrawHandlerImpl implements DrawHandler {
this.autoborderHandler.autoborder(false);
this.initialized = false;
this.canvas.off('mousedown.draw');
this.canvas.off('mouseup.draw');
this.canvas.off('mousemove.draw');
this.canvas.off('click.draw');

Expand Down Expand Up @@ -171,9 +168,7 @@ export class DrawHandlerImpl implements DrawHandler {
this.removeCrosshair();
}

if (!this.drawData.initialState) {
this.onDrawDone(null);
}
this.onDrawDone(null);
}

private initDrawing(): void {
Expand Down Expand Up @@ -256,7 +251,7 @@ export class DrawHandlerImpl implements DrawHandler {

// Add ability to cancel the latest drawn point
this.canvas.on('mousedown.draw', (e: MouseEvent): void => {
if (e.which === 3) {
if (e.button === 2) {
e.stopPropagation();
e.preventDefault();
this.drawInstance.draw('undo');
Expand Down Expand Up @@ -377,7 +372,10 @@ export class DrawHandlerImpl implements DrawHandler {
.map((coord: string): number => +coord);

const { points } = this.getFinalPolyshapeCoordinates(targetPoints);
this.release();
if (!e.detail.originalEvent.ctrlKey) {
this.release();
}

this.onDrawDone({
shapeType: this.drawData.initialState.shapeType,
objectType: this.drawData.initialState.objectType,
Expand Down Expand Up @@ -417,7 +415,10 @@ export class DrawHandlerImpl implements DrawHandler {
this.drawInstance.on('done', (e: CustomEvent): void => {
const bbox = this.drawInstance.node.getBBox();
const [xtl, ytl, xbr, ybr] = this.getFinalRectCoordinates(bbox);
this.release();
if (!e.detail.originalEvent.ctrlKey) {
this.release();
}

this.onDrawDone({
shapeType: this.drawData.initialState.shapeType,
objectType: this.drawData.initialState.objectType,
Expand Down Expand Up @@ -502,54 +503,23 @@ export class DrawHandlerImpl implements DrawHandler {
}

private setupPasteEvents(): void {
let mouseX: number | null = null;
let mouseY: number | null = null;

this.canvas.on('mousedown.draw', (e: MouseEvent): void => {
if (e.which === 1) {
mouseX = e.clientX;
mouseY = e.clientY;
}
});

this.canvas.on('mouseup.draw', (e: MouseEvent): void => {
const threshold = 10; // px
if (e.which === 1) {
if (Math.sqrt( // l2 distance < threshold
((mouseX - e.clientX) ** 2)
+ ((mouseY - e.clientY) ** 2),
) < threshold) {
this.drawInstance.fire('done', { originalEvent: e });
}
if (e.button === 0 && !e.altKey) {
this.drawInstance.fire('done', { originalEvent: e });
}
});
}

private setupDrawEvents(): void {
let initialized = false;
let mouseX: number | null = null;
let mouseY: number | null = null;

this.canvas.on('mousedown.draw', (e: MouseEvent): void => {
if (e.which === 1) {
mouseX = e.clientX;
mouseY = e.clientY;
}
});

this.canvas.on('mouseup.draw', (e: MouseEvent): void => {
const threshold = 10; // px
if (e.which === 1) {
if (Math.sqrt( // l2 distance < threshold
((mouseX - e.clientX) ** 2)
+ ((mouseY - e.clientY) ** 2),
) < threshold) {
if (!initialized) {
this.drawInstance.draw(e, { snapToGrid: 0.1 });
initialized = true;
} else {
this.drawInstance.draw(e);
}
if (e.button === 0 && !e.altKey) {
if (!initialized) {
this.drawInstance.draw(e, { snapToGrid: 0.1 });
initialized = true;
} else {
this.drawInstance.draw(e);
}
}
});
Expand Down
22 changes: 2 additions & 20 deletions cvat-canvas/src/typescript/editHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,13 +95,9 @@ export class EditHandlerImpl implements EditHandler {
}

private setupEditEvents(): void {
let mouseX: number | null = null;
let mouseY: number | null = null;

this.canvas.on('mousedown.edit', (e: MouseEvent): void => {
if (e.button === 0) {
mouseX = e.clientX;
mouseY = e.clientY;
if (e.button === 0 && !e.altKey) {
(this.editLine as any).draw('point', e);
} else if (e.button === 2 && this.editLine) {
if (this.editData.state.shapeType === 'points'
|| this.editLine.attr('points').split(' ').length > 2
Expand All @@ -110,18 +106,6 @@ export class EditHandlerImpl implements EditHandler {
}
}
});

this.canvas.on('mouseup.edit', (e: MouseEvent): void => {
const threshold = 10; // px
if (e.button === 0) {
if (Math.sqrt( // l2 distance < threshold
((mouseX - e.clientX) ** 2)
+ ((mouseY - e.clientY) ** 2),
) < threshold) {
(this.editLine as any).draw('point', e);
}
}
});
}

private selectPolygon(shape: SVG.Polygon): void {
Expand Down Expand Up @@ -192,7 +176,6 @@ export class EditHandlerImpl implements EditHandler {

// We do not need these events any more
this.canvas.off('mousedown.edit');
this.canvas.off('mouseup.edit');
this.canvas.off('mousemove.edit');

(this.editLine as any).draw('stop');
Expand Down Expand Up @@ -274,7 +257,6 @@ export class EditHandlerImpl implements EditHandler {

private release(): void {
this.canvas.off('mousedown.edit');
this.canvas.off('mouseup.edit');
this.canvas.off('mousemove.edit');
this.autoborderHandler.autoborder(false);

Expand Down
4 changes: 2 additions & 2 deletions cvat-core/src/annotations-filter.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ const { ArgumentError } = require('./exceptions');
class AnnotationsFilter {
constructor() {
// eslint-disable-next-line security/detect-unsafe-regex
this.operatorRegex = /(==|!=|<=|>=|>|<|~=)(?=(?:[^"]*(["])[^"]*\2)*[^"]*$)/g;
this.operatorRegex = /(==|!=|<=|>=|>|<)(?=(?:[^"]*(["])[^"]*\2)*[^"]*$)/g;
}

// Method splits expression by operators that are outside of any brackets
Expand Down Expand Up @@ -204,7 +204,7 @@ class AnnotationsFilter {
serverID: state.serverID,
clientID: state.clientID,
type: state.objectType,
shape: state.objectShape,
shape: state.shapeType,
occluded: state.occluded,
};
});
Expand Down
2 changes: 1 addition & 1 deletion cvat-core/src/annotations-objects.js
Original file line number Diff line number Diff line change
Expand Up @@ -371,7 +371,7 @@
updateTimestamp(updated) {
const anyChanges = updated.label || updated.attributes || updated.points
|| updated.outside || updated.occluded || updated.keyframe
|| updated.zOrder;
|| updated.zOrder || updated.hidden || updated.lock || updated.pinned;

if (anyChanges) {
this.updated = Date.now();
Expand Down
8 changes: 5 additions & 3 deletions cvat-ui/src/actions/annotation-actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -362,6 +362,10 @@ ThunkAction<Promise<void>, {}, {}, AnyAction> {
},
);

await job.annotations.clear(true);
await job.actions.clear();
const history = await job.actions.get();

// One more update to escape some problems
// in canvas when shape with the same
// clientID has different type (polygon, rectangle) for example
Expand All @@ -370,12 +374,10 @@ ThunkAction<Promise<void>, {}, {}, AnyAction> {
payload: {
job,
states: [],
history,
},
});

await job.annotations.clear(true);
await job.actions.clear();
const history = await job.actions.get();
const states = await job.annotations.get(frame, showAllInterpolationTracks, filters);

setTimeout(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ function filtersHelpModalContent(
width, height, label, serverID, clientID, type, shape, occluded
<br />
<Text strong>Supported operators: </Text>
==, !=, &gt;, &gt;=, &lt;, &lt;=, ~=, (), &amp; and |
==, !=, &gt;, &gt;=, &lt;, &lt;=, (), &amp; and |
<br />
<Text strong>
If you have double quotes in your query string,
Expand All @@ -107,6 +107,7 @@ function filtersHelpModalContent(
<Title level={3}>Examples</Title>
<ul>
<li>label==&quot;car&quot; | label==[&quot;road sign&quot;]</li>
<li>shape == &quot;polygon&quot;</li>
<li>width &gt;= height</li>
<li>attr[&quot;Attribute 1&quot;] == attr[&quot;Attribute 2&quot;]</li>
<li>clientID == 50</li>
Expand Down