Skip to content

Commit

Permalink
fix: support gradient text in canvas & svg #1572
Browse files Browse the repository at this point in the history
  • Loading branch information
xiaoiver committed May 23, 2024
1 parent 04212b0 commit 4df5315
Show file tree
Hide file tree
Showing 7 changed files with 357 additions and 170 deletions.
6 changes: 6 additions & 0 deletions .changeset/lazy-berries-pretend.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@antv/g-plugin-canvas-renderer': patch
'@antv/g-plugin-svg-renderer': patch
---

Support gradient text in canvas & svg renderer.
55 changes: 55 additions & 0 deletions __tests__/demos/bugfix/1572.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
import { Text, Rect } from '../../../packages/g';

export async function gradient_text(context) {
const { canvas } = context;
await canvas.ready;

const rect = new Rect({
style: {
x: 0,
y: 0,
width: 100,
height: 100,
fill: 'linear-gradient(90deg, red 0%, green 100%)',
},
});
canvas.appendChild(rect);

const text = new Text({
style: {
text: `两种渐变都有一个叫做 gradientUnits(渐变单元)的属性,它描述了用来描述渐变的大小和方向的单元系统。该属性有两个值:userSpaceOnUse 、objectBoundingBox。默认值为 objectBoundingBox,我们目前看到的效果都是在这种系统下的,它大体上定义了对象的渐变大小范围,所以你只要指定从 0 到 1 的坐标值,渐变就会自动的缩放到对象相同大小。userSpaceOnUse 使用绝对单元,所以你必须知道对象的位置,并将渐变放在同样地位置上。在每个.shp,.shx与.dbf文件之中,图形在每个文件的排序是一致的。也就是说,.shp的第一条记录与.shx及.dbf之中的第一条记录相对应,如此类推。此外,在.shp与.shx之中,有许多字段的字节序是不一样的。因此用户在编写读取这些文件格式的程序时,必须十分小心地处理不同文件的不同字节序。`,
x: 0,
y: 0,
// dy: 10,
textBaseline: 'top',
wordWrap: true,
wordWrapWidth: 800,
fill: 'linear-gradient(90deg, red 0%, green 100%)',
},
});
canvas.appendChild(text);

const rect2 = new Rect({
style: {
x: 0,
y: 200,
width: 100,
height: 100,
fill: 'linear-gradient(90deg, red 0.1%, green 100%)',
},
});
canvas.appendChild(rect2);
const text2 = new Text({
style: {
text: `两种渐变都有一个叫做 gradientUnits(渐变单元)的属性,它描述了用来描述渐变的大小和方向的单元系统。该属性有两个值:userSpaceOnUse 、objectBoundingBox。默认值为 objectBoundingBox,我们目前看到的效果都是在这种系统下的,它大体上定义了对象的渐变大小范围,所以你只要指定从 0 到 1 的坐标值,渐变就会自动的缩放到对象相同大小。userSpaceOnUse 使用绝对单元,所以你必须知道对象的位置,并将渐变放在同样地位置上。在每个.shp,.shx与.dbf文件之中,图形在每个文件的排序是一致的。也就是说,.shp的第一条记录与.shx及.dbf之中的第一条记录相对应,如此类推。此外,在.shp与.shx之中,有许多字段的字节序是不一样的。因此用户在编写读取这些文件格式的程序时,必须十分小心地处理不同文件的不同字节序。`,
x: 0,
y: 200,
// dy: 10,
textBaseline: 'top',
wordWrap: true,
wordWrapWidth: 800,
fill: 'linear-gradient(90deg, red 0.1%, green 100%)',
},
});
canvas.appendChild(text2);
}
1 change: 1 addition & 0 deletions __tests__/demos/bugfix/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@ export { scale0 } from './scale0';
export { dirty } from './dirty';
export { image } from './1636';
export { shadowroot_offset } from './1677';
export { gradient_text } from './1572';
6 changes: 4 additions & 2 deletions packages/g-plugin-canvas-renderer/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ export class Plugin extends AbstractRendererPlugin<{
[Shape.ELLIPSE]: defaultRenderer,
[Shape.RECT]: defaultRenderer,
[Shape.IMAGE]: new ImageRenderer(imagePool),
[Shape.TEXT]: new TextRenderer(),
[Shape.TEXT]: new TextRenderer(imagePool),
[Shape.LINE]: defaultRenderer,
[Shape.POLYLINE]: defaultRenderer,
[Shape.POLYGON]: defaultRenderer,
Expand All @@ -48,7 +48,9 @@ export class Plugin extends AbstractRendererPlugin<{
this.context.defaultStyleRendererFactory = defaultStyleRendererFactory;
this.context.styleRendererFactory = defaultStyleRendererFactory;

this.addRenderingPlugin(new CanvasRendererPlugin(canvasRendererPluginOptions));
this.addRenderingPlugin(
new CanvasRendererPlugin(canvasRendererPluginOptions),
);
}
destroy(): void {
this.removeAllRenderingPlugins();
Expand Down
Loading

0 comments on commit 4df5315

Please sign in to comment.