-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
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
chore(TS): migrate brushes #8182
Changes from 12 commits
6b42166
eb0c73d
c7aa58d
b41de6e
505fbb4
306bae8
4c1614b
2d062a9
3ca01f0
35778ef
79c7f68
ddee4dd
7c618e0
65083c4
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
/** | ||
* @todo remove transient | ||
*/ | ||
export type Shadow = any; | ||
export type Canvas = any; | ||
export type Rect = any; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. transient types |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,148 +1,152 @@ | ||
//@ts-nocheck | ||
|
||
import { fabric } from "../../HEADER"; | ||
import { Color } from "../color"; | ||
import { Point } from "../point.class"; | ||
import { Canvas, Shadow } from "../__types__"; | ||
|
||
/** | ||
* @see {@link http://fabricjs.com/freedrawing|Freedrawing demo} | ||
*/ | ||
export abstract class BaseBrush { | ||
|
||
/** | ||
* Color of a brush | ||
* @type String | ||
* @default | ||
*/ | ||
color = 'rgb(0, 0, 0)' | ||
|
||
/** | ||
* Width of a brush, has to be a Number, no string literals | ||
* @type Number | ||
* @default | ||
*/ | ||
width = 1 | ||
|
||
/** | ||
* Shadow object representing shadow of this shape. | ||
* <b>Backwards incompatibility note:</b> This property replaces "shadowColor" (String), "shadowOffsetX" (Number), | ||
* "shadowOffsetY" (Number) and "shadowBlur" (Number) since v1.2.12 | ||
* @type fabric.Shadow | ||
* @default | ||
*/ | ||
shadow: Shadow | null = null | ||
|
||
/** | ||
* Line endings style of a brush (one of "butt", "round", "square") | ||
* @type String | ||
* @default | ||
*/ | ||
strokeLineCap: CanvasLineCap = 'round' | ||
|
||
/** | ||
* Corner style of a brush (one of "bevel", "round", "miter") | ||
* @type String | ||
* @default | ||
*/ | ||
strokeLineJoin: CanvasLineJoin = 'round' | ||
|
||
/** | ||
* Maximum miter length (used for strokeLineJoin = "miter") of a brush's | ||
* @type Number | ||
* @default | ||
*/ | ||
strokeMiterLimit = 10 | ||
|
||
/** | ||
* Stroke Dash Array. | ||
* @type Array | ||
* @default | ||
*/ | ||
strokeDashArray: number[] | null = null | ||
|
||
(function(global) { | ||
var fabric = global.fabric; | ||
/** | ||
* BaseBrush class | ||
* @class fabric.BaseBrush | ||
* @see {@link http://fabricjs.com/freedrawing|Freedrawing demo} | ||
* When `true`, the free drawing is limited to the whiteboard size. Default to false. | ||
* @type Boolean | ||
* @default false | ||
*/ | ||
|
||
limitedToCanvasSize = false | ||
|
||
/** | ||
* @todo add type | ||
*/ | ||
canvas: Canvas | ||
|
||
constructor(canvas: Canvas) { | ||
this.canvas = canvas; | ||
} | ||
|
||
|
||
/** | ||
* Sets brush styles | ||
* @private | ||
* @param {CanvasRenderingContext2D} ctx | ||
*/ | ||
_setBrushStyles(ctx: CanvasRenderingContext2D) { | ||
ctx.strokeStyle = this.color; | ||
ctx.lineWidth = this.width; | ||
ctx.lineCap = this.strokeLineCap; | ||
ctx.miterLimit = this.strokeMiterLimit; | ||
ctx.lineJoin = this.strokeLineJoin; | ||
ctx.setLineDash(this.strokeDashArray || []); | ||
} | ||
|
||
/** | ||
* Sets the transformation on given context | ||
* @param {CanvasRenderingContext2D} ctx context to render on | ||
* @private | ||
*/ | ||
fabric.BaseBrush = fabric.util.createClass(/** @lends fabric.BaseBrush.prototype */ { | ||
|
||
/** | ||
* Color of a brush | ||
* @type String | ||
* @default | ||
*/ | ||
color: 'rgb(0, 0, 0)', | ||
|
||
/** | ||
* Width of a brush, has to be a Number, no string literals | ||
* @type Number | ||
* @default | ||
*/ | ||
width: 1, | ||
|
||
/** | ||
* Shadow object representing shadow of this shape. | ||
* <b>Backwards incompatibility note:</b> This property replaces "shadowColor" (String), "shadowOffsetX" (Number), | ||
* "shadowOffsetY" (Number) and "shadowBlur" (Number) since v1.2.12 | ||
* @type fabric.Shadow | ||
* @default | ||
*/ | ||
shadow: null, | ||
|
||
/** | ||
* Line endings style of a brush (one of "butt", "round", "square") | ||
* @type String | ||
* @default | ||
*/ | ||
strokeLineCap: 'round', | ||
|
||
/** | ||
* Corner style of a brush (one of "bevel", "round", "miter") | ||
* @type String | ||
* @default | ||
*/ | ||
strokeLineJoin: 'round', | ||
|
||
/** | ||
* Maximum miter length (used for strokeLineJoin = "miter") of a brush's | ||
* @type Number | ||
* @default | ||
*/ | ||
strokeMiterLimit: 10, | ||
|
||
/** | ||
* Stroke Dash Array. | ||
* @type Array | ||
* @default | ||
*/ | ||
strokeDashArray: null, | ||
|
||
/** | ||
* When `true`, the free drawing is limited to the whiteboard size. Default to false. | ||
* @type Boolean | ||
* @default false | ||
*/ | ||
|
||
limitedToCanvasSize: false, | ||
|
||
|
||
/** | ||
* Sets brush styles | ||
* @private | ||
* @param {CanvasRenderingContext2D} ctx | ||
*/ | ||
_setBrushStyles: function (ctx) { | ||
ctx.strokeStyle = this.color; | ||
ctx.lineWidth = this.width; | ||
ctx.lineCap = this.strokeLineCap; | ||
ctx.miterLimit = this.strokeMiterLimit; | ||
ctx.lineJoin = this.strokeLineJoin; | ||
ctx.setLineDash(this.strokeDashArray || []); | ||
}, | ||
|
||
/** | ||
* Sets the transformation on given context | ||
* @param {RenderingContext2d} ctx context to render on | ||
* @private | ||
*/ | ||
_saveAndTransform: function(ctx) { | ||
var v = this.canvas.viewportTransform; | ||
ctx.save(); | ||
ctx.transform(v[0], v[1], v[2], v[3], v[4], v[5]); | ||
}, | ||
|
||
/** | ||
* Sets brush shadow styles | ||
* @private | ||
*/ | ||
_setShadow: function() { | ||
if (!this.shadow) { | ||
return; | ||
} | ||
|
||
var canvas = this.canvas, | ||
shadow = this.shadow, | ||
ctx = canvas.contextTop, | ||
zoom = canvas.getZoom(); | ||
if (canvas && canvas._isRetinaScaling()) { | ||
zoom *= fabric.devicePixelRatio; | ||
} | ||
|
||
ctx.shadowColor = shadow.color; | ||
ctx.shadowBlur = shadow.blur * zoom; | ||
ctx.shadowOffsetX = shadow.offsetX * zoom; | ||
ctx.shadowOffsetY = shadow.offsetY * zoom; | ||
}, | ||
|
||
needsFullRender: function() { | ||
var color = new Color(this.color); | ||
return color.getAlpha() < 1 || !!this.shadow; | ||
}, | ||
|
||
/** | ||
* Removes brush shadow styles | ||
* @private | ||
*/ | ||
_resetShadow: function() { | ||
var ctx = this.canvas.contextTop; | ||
|
||
ctx.shadowColor = ''; | ||
ctx.shadowBlur = ctx.shadowOffsetX = ctx.shadowOffsetY = 0; | ||
}, | ||
|
||
/** | ||
* Check is pointer is outside canvas boundaries | ||
* @param {Object} pointer | ||
* @private | ||
*/ | ||
_isOutSideCanvas: function(pointer) { | ||
return pointer.x < 0 || pointer.x > this.canvas.getWidth() || | ||
pointer.y < 0 || pointer.y > this.canvas.getHeight(); | ||
protected _saveAndTransform(ctx: CanvasRenderingContext2D) { | ||
const v = this.canvas.viewportTransform; | ||
ctx.save(); | ||
ctx.transform(v[0], v[1], v[2], v[3], v[4], v[5]); | ||
} | ||
|
||
/** | ||
* Sets brush shadow styles | ||
* @private | ||
*/ | ||
protected _setShadow() { | ||
if (!this.shadow || !this.canvas) { | ||
return; | ||
} | ||
}); | ||
})(typeof exports !== 'undefined' ? exports : window); | ||
|
||
const canvas = this.canvas, | ||
shadow = this.shadow, | ||
ctx = canvas.contextTop, | ||
zoom = canvas.getZoom() * canvas.getRetinaScaling(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. changed this line There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yes but it should be 100% equivalent There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It should |
||
|
||
ctx.shadowColor = shadow.color; | ||
ctx.shadowBlur = shadow.blur * zoom; | ||
ctx.shadowOffsetX = shadow.offsetX * zoom; | ||
ctx.shadowOffsetY = shadow.offsetY * zoom; | ||
} | ||
|
||
protected needsFullRender() { | ||
const color = new Color(this.color); | ||
return color.getAlpha() < 1 || !!this.shadow; | ||
} | ||
|
||
/** | ||
* Removes brush shadow styles | ||
* @private | ||
*/ | ||
protected _resetShadow() { | ||
const ctx = this.canvas.contextTop; | ||
|
||
ctx.shadowColor = ''; | ||
ctx.shadowBlur = ctx.shadowOffsetX = ctx.shadowOffsetY = 0; | ||
} | ||
|
||
/** | ||
* Check is pointer is outside canvas boundaries | ||
* @param {Object} pointer | ||
* @private | ||
*/ | ||
protected _isOutSideCanvas(pointer: Point) { | ||
return pointer.x < 0 || pointer.x > this.canvas.getWidth() || | ||
pointer.y < 0 || pointer.y > this.canvas.getHeight(); | ||
} | ||
} | ||
|
||
fabric.BaseBrush = BaseBrush; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
moved to end because brushes depend on shapes