/
types.ts
61 lines (59 loc) · 1.71 KB
/
types.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
export interface BaseOptions extends CanvasTextDrawingStyles {
/** 水印之间的水平间距 */
gapX: number;
/** 水印之间的垂直间距 */
gapY: number;
/** 水印在 canvas 画布上绘制的水平偏移量 */
offsetLeft: number;
/** 水印在 canvas 画布上绘制的垂直偏移量 */
offsetTop: number;
/** 单个水印宽度 */
width: number;
/** 单个水印高度 */
height: number;
/** 水印透明度 */
opacity: number;
/** 旋转的角度 */
rotate: number;
/** 设置字体大小 */
fontSize: number;
/** 设置字体粗细 */
fontWeight: string | number;
/** 规定字体样式 */
fontStyle: 'normal' | 'italic';
/** 规定字体变体 */
fontVariant: 'normal' | 'small-caps';
/** 设置字体颜色 */
fontColor: string;
/** 设置水印文字的字体 */
fontFamily: string;
}
export interface WatermarkOptions extends Partial<BaseOptions> {
/** 是否开启监视模式 */
monitor?: boolean;
/** 图片源,建议导出 2 倍或 3 倍图,优先使用图片渲染水印 */
image?: string;
/** 水印文本, 为数组时表示多行水印 */
text?: string | string[];
/** 盲水印文本 */
blindText?: string;
/** 盲水印文本大小 */
blindFontSize?: string | number;
/** 盲水印透明度 */
blindOpacity?: number;
/** 样式层级 */
zIndex?: number;
/** 是否使用水印组件包裹内容 */
pack?: boolean;
/** 水印挂载的容器 */
container?: HTMLElement | string | null;
/** 水印挂载的样式 */
containerStyle?: Record<string, any>;
/** 展示模式,interval表示错行展示 */
mode?: 'repeat' | 'interval';
}
export interface DrawPatternResult {
url: string;
width: number;
height: number;
}