feat(2d): add antialiased signal to Shape (#282)

This commit is contained in:
DJ
2023-02-11 02:28:57 -05:00
committed by GitHub
parent a975c5a987
commit 7c6905d72c

View File

@@ -24,6 +24,7 @@ export interface ShapeProps extends LayoutProps {
lineCap?: SignalValue<CanvasLineCap>;
lineDash?: SignalValue<number>[];
lineDashOffset?: SignalValue<number>;
antialiased?: SignalValue<boolean>;
}
export abstract class Shape extends Layout {
@@ -49,6 +50,9 @@ export abstract class Shape extends Layout {
@initial(0)
@signal()
public declare readonly lineDashOffset: SimpleSignal<number, this>;
@initial(true)
@signal()
public declare readonly antialiased: SimpleSignal<boolean, this>;
protected readonly rippleStrength = createSignal<number, this>(0);
@@ -69,6 +73,11 @@ export abstract class Shape extends Layout {
context.lineCap = this.lineCap();
context.setLineDash(this.lineDash());
context.lineDashOffset = this.lineDashOffset();
if (!this.antialiased()) {
// from https://stackoverflow.com/a/68372384
context.filter =
'url(#filter)';
}
}
protected override draw(context: CanvasRenderingContext2D) {