Skip to content

Commit

Permalink
Interaction handler keyboard handlers fix (#3881)
Browse files Browse the repository at this point in the history
* initinal implementaion

* additional action, README and version changes

* update changelog

* remove excess reducer

* comment fixes

* changelog update

* canvas3d destroy call upd
  • Loading branch information
klakhov authored Nov 15, 2021
1 parent cddc76a commit 14262fa
Show file tree
Hide file tree
Showing 14 changed files with 93 additions and 50 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- TDB

### Fixed
- TDB
- Fixed Interaction handler keyboard handlers (<https://github.com/openvinotoolkit/cvat/pull/3881>)

### Security
- TDB
Expand Down
3 changes: 3 additions & 0 deletions cvat-canvas/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ Canvas itself handles:
cancel(): void;
configure(configuration: Configuration): void;
isAbleToChangeFrame(): boolean;
destroy(): void;

readonly geometry: Geometry;
}
Expand Down Expand Up @@ -189,6 +190,7 @@ Standard JS events are used.
- canvas.resizeshape => {id: number}
- canvas.contextmenu => { mouseEvent: MouseEvent, objectState: ObjectState, pointID: number }
- canvas.error => { exception: Error }
- canvas.destroy
```

### WEB
Expand Down Expand Up @@ -239,6 +241,7 @@ canvas.draw({
| bitmap() | + | + | + | + | + | + | + | + | + | + | + |
| setZLayer() | + | + | + | + | + | + | + | + | + | + | + |
| setupReviewROIs() | + | + | + | + | + | + | + | + | + | + | + |
| destroy() | + | + | + | + | + | + | + | + | + | + | + |

<!--lint enable maximum-line-length-->

Expand Down
4 changes: 2 additions & 2 deletions cvat-canvas/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion cvat-canvas/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "cvat-canvas",
"version": "2.8.0",
"version": "2.9.0",
"description": "Part of Computer Vision Annotation Tool which presents its canvas library",
"main": "src/canvas.ts",
"scripts": {
Expand Down
5 changes: 5 additions & 0 deletions cvat-canvas/src/typescript/canvas.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ interface Canvas {
cancel(): void;
configure(configuration: Configuration): void;
isAbleToChangeFrame(): boolean;
destroy(): void;

readonly geometry: Geometry;
}
Expand Down Expand Up @@ -163,6 +164,10 @@ class CanvasImpl implements Canvas {
public get geometry(): Geometry {
return this.model.geometry;
}

public destroy(): void {
this.model.destroy();
}
}

export type InteractionData = _InteractionData;
Expand Down
6 changes: 6 additions & 0 deletions cvat-canvas/src/typescript/canvasModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,7 @@ export enum UpdateReasons {
ZOOM_CANVAS = 'zoom_canvas',
CONFIG_UPDATED = 'config_updated',
DATA_FAILED = 'data_failed',
DESTROY = 'destroy',
}

export enum Mode {
Expand Down Expand Up @@ -210,6 +211,7 @@ export interface CanvasModel {
isAbleToChangeFrame(): boolean;
configure(configuration: Configuration): void;
cancel(): void;
destroy(): void;
}

export class CanvasModelImpl extends MasterImpl implements CanvasModel {
Expand Down Expand Up @@ -685,6 +687,10 @@ export class CanvasModelImpl extends MasterImpl implements CanvasModel {
this.notify(UpdateReasons.CANCEL);
}

public destroy(): void {
this.notify(UpdateReasons.DESTROY);
}

public get configuration(): Configuration {
return { ...this.data.configuration };
}
Expand Down
10 changes: 10 additions & 0 deletions cvat-canvas/src/typescript/canvasView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1358,6 +1358,16 @@ export class CanvasViewImpl implements CanvasView, Listener {
},
});
this.canvas.dispatchEvent(event);
} else if (reason === UpdateReasons.DESTROY) {
this.canvas.dispatchEvent(
new CustomEvent('canvas.destroy', {
bubbles: false,
cancelable: true,
}),
);
// We can't call namespaced svgjs event
// see - https://svgjs.dev/docs/2.7/events/
this.adoptedContent.fire('destroy');
}

if (model.imageBitmap && [UpdateReasons.IMAGE_CHANGED, UpdateReasons.OBJECTS_UPDATED].includes(reason)) {
Expand Down
44 changes: 26 additions & 18 deletions cvat-canvas/src/typescript/interactionHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,27 @@ export class InteractionHandlerImpl implements InteractionHandler {
return false;
}

private onKeyUp = (e: KeyboardEvent): void => {
if (this.interactionData.enabled && e.keyCode === 17) {
if (this.interactionData.onChangeToolsBlockerState && !this.thresholdWasModified) {
this.interactionData.onChangeToolsBlockerState('keyup');
}
if (this.shouldRaiseEvent(false)) {
// 17 is ctrl
this.onInteraction(this.prepareResult(), true, false);
}
}
};

private onKeyDown = (e: KeyboardEvent): void => {
if (!e.repeat && this.interactionData.enabled && e.keyCode === 17) {
if (this.interactionData.onChangeToolsBlockerState && !this.thresholdWasModified) {
this.interactionData.onChangeToolsBlockerState('keydown');
}
this.thresholdWasModified = false;
}
};

public constructor(
onInteraction: (
shapes: InteractionResult[] | null,
Expand Down Expand Up @@ -452,25 +473,12 @@ export class InteractionHandlerImpl implements InteractionHandler {
}
});

window.addEventListener('keyup', (e: KeyboardEvent): void => {
if (this.interactionData.enabled && e.keyCode === 17) {
if (this.interactionData.onChangeToolsBlockerState && !this.thresholdWasModified) {
this.interactionData.onChangeToolsBlockerState('keyup');
}
if (this.shouldRaiseEvent(false)) {
// 17 is ctrl
this.onInteraction(this.prepareResult(), true, false);
}
}
});
window.addEventListener('keyup', this.onKeyUp);
window.addEventListener('keydown', this.onKeyDown);

window.addEventListener('keydown', (e: KeyboardEvent): void => {
if (!e.repeat && this.interactionData.enabled && e.keyCode === 17) {
if (this.interactionData.onChangeToolsBlockerState && !this.thresholdWasModified) {
this.interactionData.onChangeToolsBlockerState('keydown');
}
this.thresholdWasModified = false;
}
this.canvas.on('destroy.canvas', ():void => {
window.removeEventListener('keyup', this.onKeyUp);
window.removeEventListener('keydown', this.onKeyDown);
});
}

Expand Down
5 changes: 5 additions & 0 deletions cvat-canvas3d/src/typescript/canvas3d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ interface Canvas3d {
fitCanvas(): void;
fit(): void;
group(groupData: GroupData): void;
destroy(): void;
}

class Canvas3dImpl implements Canvas3d {
Expand Down Expand Up @@ -104,6 +105,10 @@ class Canvas3dImpl implements Canvas3d {
public fitCanvas(): void {
this.model.fit();
}

public destroy(): void {
this.model.destroy();
}
}

export {
Expand Down
7 changes: 5 additions & 2 deletions cvat-canvas3d/src/typescript/canvas3dModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ export interface Canvas3dModel {
configureShapes(shapeProperties: any): void;
fit(): void;
group(groupData: GroupData): void;
destroy(): void;
}

export class Canvas3dModelImpl extends MasterImpl implements Canvas3dModel {
Expand Down Expand Up @@ -234,8 +235,8 @@ export class Canvas3dModelImpl extends MasterImpl implements Canvas3dModel {
}

public isAbleToChangeFrame(): boolean {
const isUnable = [Mode.DRAG, Mode.EDIT, Mode.RESIZE, Mode.INTERACT, Mode.BUSY].includes(this.data.mode)
|| (this.data.mode === Mode.DRAW && typeof this.data.drawData.redraw === 'number');
const isUnable = [Mode.DRAG, Mode.EDIT, Mode.RESIZE, Mode.INTERACT, Mode.BUSY].includes(this.data.mode) ||
(this.data.mode === Mode.DRAW && typeof this.data.drawData.redraw === 'number');
return !isUnable;
}

Expand Down Expand Up @@ -340,4 +341,6 @@ export class Canvas3dModelImpl extends MasterImpl implements Canvas3dModel {
public get groupData(): GroupData {
return { ...this.data.groupData };
}

public destroy(): void {}
}
47 changes: 24 additions & 23 deletions cvat-canvas3d/src/typescript/canvas3dView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,7 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
(_state: any): boolean => _state.clientID === Number(intersects[0].object.name),
);
if (item.length !== 0) {
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
this.model.data.groupData.grouped = this.model.data.groupData.grouped.filter(
(_state: any): boolean => _state.clientID !== Number(intersects[0].object.name),
Expand Down Expand Up @@ -543,9 +544,9 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
this.action.rotation.screenInit = { x: diffX, y: diffY };
this.action.rotation.screenMove = { x: diffX, y: diffY };
if (
this.model.data.selected
&& !this.model.data.selected.perspective.userData.lock
&& !this.model.data.selected.perspective.userData.hidden
this.model.data.selected &&
!this.model.data.selected.perspective.userData.lock &&
!this.model.data.selected.perspective.userData.hidden
) {
this.action.scan = view;
this.model.mode = Mode.EDIT;
Expand Down Expand Up @@ -698,8 +699,8 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
cuboid.setOpacity(opacity);

if (
this.model.data.activeElement.clientID === clientID
&& ![Mode.DRAG_CANVAS, Mode.GROUP].includes(this.mode)
this.model.data.activeElement.clientID === clientID &&
![Mode.DRAG_CANVAS, Mode.GROUP].includes(this.mode)
) {
cuboid.setOpacity(selectedOpacity);
if (!object.lock) {
Expand Down Expand Up @@ -964,12 +965,12 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
const sphereCenter = points.geometry.boundingSphere.center;
const { radius } = points.geometry.boundingSphere;
if (!this.views.perspective.camera) return;
const xRange = -radius / 2 < this.views.perspective.camera.position.x - sphereCenter.x
&& radius / 2 > this.views.perspective.camera.position.x - sphereCenter.x;
const yRange = -radius / 2 < this.views.perspective.camera.position.y - sphereCenter.y
&& radius / 2 > this.views.perspective.camera.position.y - sphereCenter.y;
const zRange = -radius / 2 < this.views.perspective.camera.position.z - sphereCenter.z
&& radius / 2 > this.views.perspective.camera.position.z - sphereCenter.z;
const xRange = -radius / 2 < this.views.perspective.camera.position.x - sphereCenter.x &&
radius / 2 > this.views.perspective.camera.position.x - sphereCenter.x;
const yRange = -radius / 2 < this.views.perspective.camera.position.y - sphereCenter.y &&
radius / 2 > this.views.perspective.camera.position.y - sphereCenter.y;
const zRange = -radius / 2 < this.views.perspective.camera.position.z - sphereCenter.z &&
radius / 2 > this.views.perspective.camera.position.z - sphereCenter.z;
let newX = 0;
let newY = 0;
let newZ = 0;
Expand Down Expand Up @@ -1085,10 +1086,10 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {

private positionAllViews(x: number, y: number, z: number, animation: boolean): void {
if (
this.views.perspective.controls
&& this.views.top.controls
&& this.views.side.controls
&& this.views.front.controls
this.views.perspective.controls &&
this.views.top.controls &&
this.views.side.controls &&
this.views.front.controls
) {
this.views.perspective.controls.setLookAt(x - 8, y - 8, z + 3, x, y, z, animation);
this.views.top.camera.position.set(x, y, z + 8);
Expand Down Expand Up @@ -1266,8 +1267,8 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {

private renderTranslateAction(view: ViewType, viewType: any): void {
if (
this.action.translation.helper.x === this.views[view].rayCaster.mouseVector.x
&& this.action.translation.helper.y === this.views[view].rayCaster.mouseVector.y
this.action.translation.helper.x === this.views[view].rayCaster.mouseVector.x &&
this.action.translation.helper.y === this.views[view].rayCaster.mouseVector.y
) {
return;
}
Expand Down Expand Up @@ -1332,8 +1333,8 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
}

if (
this.action.resize.recentMouseVector.x === currentPosX
&& this.action.resize.recentMouseVector.y === currentPosY
this.action.resize.recentMouseVector.x === currentPosX &&
this.action.resize.recentMouseVector.y === currentPosY
) {
return;
}
Expand Down Expand Up @@ -1736,15 +1737,15 @@ export class Canvas3dViewImpl implements Canvas3dView, Listener {
y: canvas.offsetTop + canvas.offsetHeight / 2,
};
if (
this.action.rotation.screenInit.x === this.action.rotation.screenMove.x
&& this.action.rotation.screenInit.y === this.action.rotation.screenMove.y
this.action.rotation.screenInit.x === this.action.rotation.screenMove.x &&
this.action.rotation.screenInit.y === this.action.rotation.screenMove.y
) {
return;
}

if (
this.action.rotation.recentMouseVector.x === this.views[view].rayCaster.mouseVector.x
&& this.action.rotation.recentMouseVector.y === this.views[view].rayCaster.mouseVector.y
this.action.rotation.recentMouseVector.x === this.views[view].rayCaster.mouseVector.x &&
this.action.rotation.recentMouseVector.y === this.views[view].rayCaster.mouseVector.y
) {
return;
}
Expand Down
4 changes: 2 additions & 2 deletions cvat-ui/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion cvat-ui/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "cvat-ui",
"version": "1.25.0",
"version": "1.25.1",
"description": "CVAT single-page application",
"main": "src/index.tsx",
"scripts": {
Expand Down
2 changes: 2 additions & 0 deletions cvat-ui/src/reducers/annotation-reducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,8 @@ export default (state = defaultState, action: AnyAction): AnnotationState => {
activeShapeType = ShapeType.CUBOID;
}

state.canvas.instance.destroy();

return {
...state,
job: {
Expand Down

0 comments on commit 14262fa

Please sign in to comment.