From 515233d0a07ae160ca8b57b13cf9e8e2f15633d5 Mon Sep 17 00:00:00 2001 From: ShaMan123 Date: Sat, 6 Jan 2024 15:33:55 +0200 Subject: [PATCH 1/3] isVisible --- src/Collection.ts | 2 +- src/canvas/SelectableCanvas.ts | 2 +- src/shapes/Object/Object.ts | 10 ++++------ src/shapes/Text/Text.ts | 4 ++-- 4 files changed, 8 insertions(+), 10 deletions(-) diff --git a/src/Collection.ts b/src/Collection.ts index 3846f655d70..b2be5835fcd 100644 --- a/src/Collection.ts +++ b/src/Collection.ts @@ -336,7 +336,7 @@ export function createCollectionMixin(Base: TBase) { const object = this._objects[i] as unknown as InteractiveFabricObject; if ( object.selectable && - object.visible && + object.isVisible() && ((includeIntersecting && object.intersectsWithRect(tl, br)) || object.isContainedWithinRect(tl, br) || (includeIntersecting && object.containsPoint(tl)) || diff --git a/src/canvas/SelectableCanvas.ts b/src/canvas/SelectableCanvas.ts index 94af4847b75..e5ee8ab231e 100644 --- a/src/canvas/SelectableCanvas.ts +++ b/src/canvas/SelectableCanvas.ts @@ -806,7 +806,7 @@ export class SelectableCanvas _checkTarget(obj: FabricObject, pointer: Point): boolean { if ( obj && - obj.visible && + obj.isVisible() && obj.evented && this._pointIsInObjectSelectionArea( obj, diff --git a/src/shapes/Object/Object.ts b/src/shapes/Object/Object.ts index d6ca9d23815..5cf05438728 100644 --- a/src/shapes/Object/Object.ts +++ b/src/shapes/Object/Object.ts @@ -739,11 +739,9 @@ export class FabricObject< * @memberOf FabricObject.prototype * @return {Boolean} */ - isNotVisible() { + isVisible() { return ( - this.opacity === 0 || - (!this.width && !this.height && this.strokeWidth === 0) || - !this.visible + this.visible && this.opacity > 0 && this.width > 0 && this.height > 0 ); } @@ -753,7 +751,7 @@ export class FabricObject< */ render(ctx: CanvasRenderingContext2D) { // do not render if width/height are zeros or object is not visible - if (this.isNotVisible()) { + if (!this.isVisible()) { return; } if ( @@ -978,7 +976,7 @@ export class FabricObject< * on parent canvas. */ isCacheDirty(skipCanvas = false) { - if (this.isNotVisible()) { + if (!this.isVisible()) { return false; } if ( diff --git a/src/shapes/Text/Text.ts b/src/shapes/Text/Text.ts index caf125493ad..ba1d68dbea9 100644 --- a/src/shapes/Text/Text.ts +++ b/src/shapes/Text/Text.ts @@ -599,7 +599,7 @@ export class FabricText< */ _render(ctx: CanvasRenderingContext2D) { const path = this.path; - path && !path.isNotVisible() && path._render(ctx); + path && path.isVisible() && path._render(ctx); this._setTextStyles(ctx); this._renderTextLinesBackground(ctx); this._renderTextDecoration(ctx, 'underline'); @@ -1679,7 +1679,7 @@ export class FabricText< * @param {CanvasRenderingContext2D} ctx Context to render on */ render(ctx: CanvasRenderingContext2D) { - if (!this.visible) { + if (!this.isVisible()) { return; } if ( From d7de37a70254ca67d6a969db9bfc0a179aa9bed7 Mon Sep 17 00:00:00 2001 From: ShaMan123 Date: Sat, 6 Jan 2024 15:42:17 +0200 Subject: [PATCH 2/3] unit tests --- test/unit/ellipse.js | 6 +++--- test/unit/object.js | 12 ++++++------ 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/test/unit/ellipse.js b/test/unit/ellipse.js index 43302703b4d..8b444930652 100644 --- a/test/unit/ellipse.js +++ b/test/unit/ellipse.js @@ -95,16 +95,16 @@ }); }); - QUnit.test('isNotVisible', function(assert) { + QUnit.test('isVisible', function(assert) { var ellipse = new fabric.Ellipse(); ellipse.set('rx', 0); ellipse.set('ry', 0); - assert.equal(ellipse.isNotVisible(), false, 'isNotVisible false when rx/ry are 0 because strokeWidth is > 0'); + assert.equal(ellipse.isVisible(), true, 'isVisible false when rx/ry are 0 because strokeWidth is > 0'); ellipse.set('strokeWidth', 0); - assert.equal(ellipse.isNotVisible(), true, 'should not render anymore with also strokeWidth 0'); + assert.equal(ellipse.isVisible(), false, 'should not render anymore with also strokeWidth 0'); }); diff --git a/test/unit/object.js b/test/unit/object.js index 9f8350dd6b6..9bcba89d182 100644 --- a/test/unit/object.js +++ b/test/unit/object.js @@ -1210,17 +1210,17 @@ object._set('fill', 'blue'); assert.equal(object.dirty, false, 'dirty is not raised'); }); - QUnit.test('isNotVisible', function(assert) { + QUnit.test('isVisible', function(assert) { var object = new fabric.Object({ fill: 'blue', width: 100, height: 100 }); - assert.equal(object.isNotVisible(), false, 'object is default visible'); + assert.equal(object.isVisible(), true, 'object is default visible'); object = new fabric.Object({ fill: 'blue', width: 0, height: 0, strokeWidth: 1 }); - assert.equal(object.isNotVisible(), false, 'object is visible with width and height equal 0, but strokeWidth 1'); + assert.equal(object.isVisible(), false, 'object is visible with width and height equal 0, but strokeWidth 1'); object = new fabric.Object({ opacity: 0, fill: 'blue' }); - assert.equal(object.isNotVisible(), true, 'object is not visible with opacity 0'); + assert.equal(object.isVisible(), false, 'object is not visible with opacity 0'); object = new fabric.Object({ fill: 'blue', visible: false }); - assert.equal(object.isNotVisible(), true, 'object is not visible with visible false'); + assert.equal(object.isVisible(), false, 'object is not visible with visible false'); object = new fabric.Object({ fill: 'blue', width: 0, height: 0, strokeWidth: 0 }); - assert.equal(object.isNotVisible(), true, 'object is not visible with also strokeWidth equal 0'); + assert.equal(object.isVisible(), false, 'object is not visible with also strokeWidth equal 0'); }); QUnit.test('shouldCache', function(assert) { var object = new fabric.Object(); From 536c3084b952f918da80435e0870b24575352bc5 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Sat, 6 Jan 2024 13:45:04 +0000 Subject: [PATCH 3/3] update CHANGELOG.md --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 16da7ba1ba8..4597ee5763d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,7 @@ ## [next] +- fix(): `isNotVisible` + rename to `isVisible` [#9574](https://github.com/fabricjs/fabric.js/pull/9574) - fix() Addressing path cloning slowness ( partially ) [#9573](https://github.com/fabricjs/fabric.js/pull/9573) - feat(): Add save/restore ability to group LayoutManager [#9564](https://github.com/fabricjs/fabric.js/pull/9564) - fix() Remove unwanted set type warning [#9569](https://github.com/fabricjs/fabric.js/pull/9569)