From 68d130d23384afe34d365fa2472d47079cab4b10 Mon Sep 17 00:00:00 2001 From: Zhilin Liu Date: Sun, 25 Feb 2024 12:10:01 +0800 Subject: [PATCH] fix: add padding for canvas (#93) --- src/Kernel/ToolBox/controller/PenToolController.ts | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/Kernel/ToolBox/controller/PenToolController.ts b/src/Kernel/ToolBox/controller/PenToolController.ts index 2ee75bc..2459367 100644 --- a/src/Kernel/ToolBox/controller/PenToolController.ts +++ b/src/Kernel/ToolBox/controller/PenToolController.ts @@ -5,6 +5,8 @@ import { selectionManager, slideManager, toolBox, zoom } from '@Kernel/index' import { ArrayStore } from '@Kernel/Store/ArrayStore' import { OriginMap } from '@Kernel/Store/_Store' +const CANVAS_PADDING = 10 + export class PenToolController extends ToolController { private _drawing = false private _canvasBlock?: CanvasBlock @@ -35,16 +37,16 @@ export class PenToolController extends ToolController { if (this._drawing) { this._drawing = false const block = new CanvasBlock( - this._range.left, - this._range.top, - this._range.right - this._range.left, - this._range.bottom - this._range.top + this._range.left - CANVAS_PADDING, + this._range.top - CANVAS_PADDING, + this._range.right - this._range.left + CANVAS_PADDING * 2, + this._range.bottom - this._range.top + CANVAS_PADDING * 2 ) for (const point of this._canvasBlock?.points as ArrayStore) { const { x, y } = point as OriginMap block.points.push({ - x: (x as number) - this._range.left, - y: (y as number) - this._range.top, + x: (x as number) - this._range.left + CANVAS_PADDING, + y: (y as number) - this._range.top + CANVAS_PADDING, }) } const slide = slideManager.currentSlide