@vnpn/lucky-canvas-core 1.7.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +42 -0
- package/dist/index.cjs.js +2 -0
- package/dist/index.cjs.js.map +1 -0
- package/dist/index.esm.js +2 -0
- package/dist/index.esm.js.map +1 -0
- package/dist/index.umd.js +1 -0
- package/dist/index.umd.js.map +1 -0
- package/index.js +1 -0
- package/package.json +71 -0
- package/types/index.d.ts +751 -0
- package/types/src/index.d.ts +4 -0
- package/types/src/lib/grid.d.ts +130 -0
- package/types/src/lib/lucky.d.ts +128 -0
- package/types/src/lib/slot.d.ts +109 -0
- package/types/src/lib/wheel.d.ts +109 -0
- package/types/src/observer/array.d.ts +2 -0
- package/types/src/observer/dep.d.ts +18 -0
- package/types/src/observer/index.d.ts +23 -0
- package/types/src/observer/utils.d.ts +4 -0
- package/types/src/observer/watcher.d.ts +30 -0
- package/types/src/types/grid.d.ts +85 -0
- package/types/src/types/index.d.ts +59 -0
- package/types/src/types/slot.d.ts +69 -0
- package/types/src/types/wheel.d.ts +59 -0
- package/types/src/utils/image.d.ts +29 -0
- package/types/src/utils/index.d.ts +53 -0
- package/types/src/utils/math.d.ts +26 -0
- package/types/src/utils/polyfill.d.ts +0 -0
- package/types/src/utils/tween.d.ts +21 -0
package/types/index.d.ts
ADDED
|
@@ -0,0 +1,751 @@
|
|
|
1
|
+
declare type FontItemType = {
|
|
2
|
+
text: string;
|
|
3
|
+
top?: string | number;
|
|
4
|
+
left?: string | number;
|
|
5
|
+
fontColor?: string;
|
|
6
|
+
fontSize?: string;
|
|
7
|
+
fontStyle?: string;
|
|
8
|
+
fontWeight?: string;
|
|
9
|
+
lineHeight?: string;
|
|
10
|
+
};
|
|
11
|
+
declare type FontExtendType = {
|
|
12
|
+
wordWrap?: boolean;
|
|
13
|
+
lengthLimit?: string | number;
|
|
14
|
+
lineClamp?: number;
|
|
15
|
+
};
|
|
16
|
+
declare type ImgType = HTMLImageElement | HTMLCanvasElement;
|
|
17
|
+
declare type ImgItemType = {
|
|
18
|
+
src: string;
|
|
19
|
+
top?: string | number;
|
|
20
|
+
left?: string | number;
|
|
21
|
+
width?: string;
|
|
22
|
+
height?: string;
|
|
23
|
+
formatter?: (img: ImgType) => ImgType;
|
|
24
|
+
$resolve?: Function;
|
|
25
|
+
$reject?: Function;
|
|
26
|
+
};
|
|
27
|
+
declare type BorderRadiusType = string | number;
|
|
28
|
+
declare type BackgroundType = string;
|
|
29
|
+
declare type ShadowType = string;
|
|
30
|
+
declare type ConfigType = {
|
|
31
|
+
nodeType?: number;
|
|
32
|
+
flag: 'WEB' | 'MP-WX' | 'UNI-H5' | 'UNI-MP' | 'TARO-H5' | 'TARO-MP';
|
|
33
|
+
el?: string;
|
|
34
|
+
divElement?: HTMLDivElement;
|
|
35
|
+
canvasElement?: HTMLCanvasElement;
|
|
36
|
+
ctx: CanvasRenderingContext2D;
|
|
37
|
+
dpr: number;
|
|
38
|
+
handleCssUnit?: (num: number, unit: string) => number;
|
|
39
|
+
rAF?: Function;
|
|
40
|
+
setTimeout: Function;
|
|
41
|
+
setInterval: Function;
|
|
42
|
+
clearTimeout: Function;
|
|
43
|
+
clearInterval: Function;
|
|
44
|
+
beforeCreate?: Function;
|
|
45
|
+
beforeResize?: Function;
|
|
46
|
+
afterResize?: Function;
|
|
47
|
+
beforeInit?: Function;
|
|
48
|
+
afterInit?: Function;
|
|
49
|
+
beforeDraw?: Function;
|
|
50
|
+
afterDraw?: Function;
|
|
51
|
+
afterStart?: Function;
|
|
52
|
+
};
|
|
53
|
+
declare type UserConfigType = Partial<ConfigType>;
|
|
54
|
+
declare type Tuple<T, Len extends number, Res extends T[] = []> = Res['length'] extends Len ? Res : Tuple<T, Len, [...Res, T]>;
|
|
55
|
+
|
|
56
|
+
interface WatchOptType {
|
|
57
|
+
handler?: () => Function;
|
|
58
|
+
immediate?: boolean;
|
|
59
|
+
deep?: boolean;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
declare class Lucky {
|
|
63
|
+
static version: string;
|
|
64
|
+
protected readonly version: string;
|
|
65
|
+
protected readonly config: ConfigType;
|
|
66
|
+
protected readonly ctx: CanvasRenderingContext2D;
|
|
67
|
+
protected htmlFontSize: number;
|
|
68
|
+
protected rAF: Function;
|
|
69
|
+
protected boxWidth: number;
|
|
70
|
+
protected boxHeight: number;
|
|
71
|
+
protected data: {
|
|
72
|
+
width: string | number;
|
|
73
|
+
height: string | number;
|
|
74
|
+
};
|
|
75
|
+
/**
|
|
76
|
+
* 公共构造器
|
|
77
|
+
* @param config
|
|
78
|
+
*/
|
|
79
|
+
constructor(config: string | HTMLDivElement | UserConfigType, data: {
|
|
80
|
+
width: string | number;
|
|
81
|
+
height: string | number;
|
|
82
|
+
});
|
|
83
|
+
/**
|
|
84
|
+
* 初始化组件大小/单位
|
|
85
|
+
*/
|
|
86
|
+
protected resize(): void;
|
|
87
|
+
/**
|
|
88
|
+
* 初始化方法
|
|
89
|
+
*/
|
|
90
|
+
protected initLucky(): void;
|
|
91
|
+
/**
|
|
92
|
+
* 鼠标点击事件
|
|
93
|
+
* @param e 事件参数
|
|
94
|
+
*/
|
|
95
|
+
protected handleClick(e: MouseEvent): void;
|
|
96
|
+
/**
|
|
97
|
+
* 根标签的字体大小
|
|
98
|
+
*/
|
|
99
|
+
protected setHTMLFontSize(): void;
|
|
100
|
+
clearCanvas(): void;
|
|
101
|
+
/**
|
|
102
|
+
* 设备像素比
|
|
103
|
+
* window 环境下自动获取, 其余环境手动传入
|
|
104
|
+
*/
|
|
105
|
+
protected setDpr(): void;
|
|
106
|
+
/**
|
|
107
|
+
* 重置盒子和canvas的宽高
|
|
108
|
+
*/
|
|
109
|
+
private resetWidthAndHeight;
|
|
110
|
+
/**
|
|
111
|
+
* 根据 dpr 缩放 canvas 并处理位移
|
|
112
|
+
*/
|
|
113
|
+
protected zoomCanvas(): void;
|
|
114
|
+
/**
|
|
115
|
+
* 从 window 对象上获取一些方法
|
|
116
|
+
*/
|
|
117
|
+
private initWindowFunction;
|
|
118
|
+
isWeb(): boolean;
|
|
119
|
+
/**
|
|
120
|
+
* 异步加载图片并返回图片的几何信息
|
|
121
|
+
* @param src 图片路径
|
|
122
|
+
* @param info 图片信息
|
|
123
|
+
*/
|
|
124
|
+
protected loadImg(src: string, info: ImgItemType, resolveName?: string): Promise<ImgType>;
|
|
125
|
+
/**
|
|
126
|
+
* 公共绘制图片的方法
|
|
127
|
+
* @param imgObj 图片对象
|
|
128
|
+
* @param rectInfo: [x轴位置, y轴位置, 渲染宽度, 渲染高度]
|
|
129
|
+
*/
|
|
130
|
+
protected drawImage(ctx: CanvasRenderingContext2D, imgObj: ImgType, ...rectInfo: [...Tuple<number, 4>, ...Partial<Tuple<number, 4>>]): void;
|
|
131
|
+
/**
|
|
132
|
+
* 计算图片的渲染宽高
|
|
133
|
+
* @param imgObj 图片标签元素
|
|
134
|
+
* @param imgInfo 图片信息
|
|
135
|
+
* @param maxWidth 最大宽度
|
|
136
|
+
* @param maxHeight 最大高度
|
|
137
|
+
* @return [渲染宽度, 渲染高度]
|
|
138
|
+
*/
|
|
139
|
+
protected computedWidthAndHeight(imgObj: ImgType, imgInfo: ImgItemType, maxWidth: number, maxHeight: number): [number, number];
|
|
140
|
+
/**
|
|
141
|
+
* 转换单位
|
|
142
|
+
* @param { string } value 将要转换的值
|
|
143
|
+
* @param { number } denominator 分子
|
|
144
|
+
* @return { number } 返回新的字符串
|
|
145
|
+
*/
|
|
146
|
+
protected changeUnits(value: string, denominator?: number): number;
|
|
147
|
+
/**
|
|
148
|
+
* 获取长度
|
|
149
|
+
* @param length 将要转换的长度
|
|
150
|
+
* @param maxLength 最大长度
|
|
151
|
+
* @return 返回长度
|
|
152
|
+
*/
|
|
153
|
+
protected getLength(length: string | number | undefined, maxLength?: number): number;
|
|
154
|
+
/**
|
|
155
|
+
* 获取相对(居中)X坐标
|
|
156
|
+
* @param width
|
|
157
|
+
* @param col
|
|
158
|
+
*/
|
|
159
|
+
protected getOffsetX(width: number, maxWidth?: number): number;
|
|
160
|
+
protected getOffscreenCanvas(width: number, height: number): {
|
|
161
|
+
_offscreenCanvas: HTMLCanvasElement;
|
|
162
|
+
_ctx: CanvasRenderingContext2D;
|
|
163
|
+
} | void;
|
|
164
|
+
/**
|
|
165
|
+
* 添加一个新的响应式数据 (临时)
|
|
166
|
+
* @param data 数据
|
|
167
|
+
* @param key 属性
|
|
168
|
+
* @param value 新值
|
|
169
|
+
*/
|
|
170
|
+
$set(data: object, key: string | number, value: any): void;
|
|
171
|
+
/**
|
|
172
|
+
* 添加一个属性计算 (临时)
|
|
173
|
+
* @param data 源数据
|
|
174
|
+
* @param key 属性名
|
|
175
|
+
* @param callback 回调函数
|
|
176
|
+
*/
|
|
177
|
+
protected $computed(data: object, key: string, callback: Function): void;
|
|
178
|
+
/**
|
|
179
|
+
* 添加一个观察者 create user watcher
|
|
180
|
+
* @param expr 表达式
|
|
181
|
+
* @param handler 回调函数
|
|
182
|
+
* @param watchOpt 配置参数
|
|
183
|
+
* @return 卸载当前观察者的函数 (暂未返回)
|
|
184
|
+
*/
|
|
185
|
+
protected $watch(expr: string | Function, handler: Function | WatchOptType, watchOpt?: WatchOptType): Function;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
declare type PrizeFontType$2 = FontItemType & FontExtendType;
|
|
189
|
+
declare type ButtonFontType$1 = FontItemType & {};
|
|
190
|
+
declare type BlockImgType$2 = ImgItemType & {
|
|
191
|
+
rotate?: boolean;
|
|
192
|
+
};
|
|
193
|
+
declare type PrizeImgType$2 = ImgItemType & {};
|
|
194
|
+
declare type ButtonImgType$1 = ImgItemType & {};
|
|
195
|
+
declare type BlockType$2 = {
|
|
196
|
+
padding?: string;
|
|
197
|
+
background?: BackgroundType;
|
|
198
|
+
imgs?: Array<BlockImgType$2>;
|
|
199
|
+
};
|
|
200
|
+
declare type PrizeType$2 = {
|
|
201
|
+
range?: number;
|
|
202
|
+
background?: BackgroundType;
|
|
203
|
+
fonts?: Array<PrizeFontType$2>;
|
|
204
|
+
imgs?: Array<PrizeImgType$2>;
|
|
205
|
+
};
|
|
206
|
+
declare type ButtonType$1 = {
|
|
207
|
+
radius?: string;
|
|
208
|
+
pointer?: boolean;
|
|
209
|
+
background?: BackgroundType;
|
|
210
|
+
fonts?: Array<ButtonFontType$1>;
|
|
211
|
+
imgs?: Array<ButtonImgType$1>;
|
|
212
|
+
};
|
|
213
|
+
declare type DefaultConfigType$2 = {
|
|
214
|
+
gutter?: string | number;
|
|
215
|
+
offsetDegree?: number;
|
|
216
|
+
speed?: number;
|
|
217
|
+
speedFunction?: string;
|
|
218
|
+
accelerationTime?: number;
|
|
219
|
+
decelerationTime?: number;
|
|
220
|
+
stopRange?: number;
|
|
221
|
+
};
|
|
222
|
+
declare type DefaultStyleType$2 = {
|
|
223
|
+
background?: BackgroundType;
|
|
224
|
+
fontColor?: PrizeFontType$2['fontColor'];
|
|
225
|
+
fontSize?: PrizeFontType$2['fontSize'];
|
|
226
|
+
fontStyle?: PrizeFontType$2['fontStyle'];
|
|
227
|
+
fontWeight?: PrizeFontType$2['fontWeight'];
|
|
228
|
+
lineHeight?: PrizeFontType$2['lineHeight'];
|
|
229
|
+
wordWrap?: PrizeFontType$2['wordWrap'];
|
|
230
|
+
lengthLimit?: PrizeFontType$2['lengthLimit'];
|
|
231
|
+
lineClamp?: PrizeFontType$2['lineClamp'];
|
|
232
|
+
};
|
|
233
|
+
declare type StartCallbackType$1 = (e: MouseEvent) => void;
|
|
234
|
+
declare type EndCallbackType$2 = (prize: object) => void;
|
|
235
|
+
interface LuckyWheelConfig {
|
|
236
|
+
width: string | number;
|
|
237
|
+
height: string | number;
|
|
238
|
+
blocks?: Array<BlockType$2>;
|
|
239
|
+
prizes?: Array<PrizeType$2>;
|
|
240
|
+
buttons?: Array<ButtonType$1>;
|
|
241
|
+
defaultConfig?: DefaultConfigType$2;
|
|
242
|
+
defaultStyle?: DefaultStyleType$2;
|
|
243
|
+
start?: StartCallbackType$1;
|
|
244
|
+
end?: EndCallbackType$2;
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
declare class LuckyWheel extends Lucky {
|
|
248
|
+
private blocks;
|
|
249
|
+
private prizes;
|
|
250
|
+
private buttons;
|
|
251
|
+
private defaultConfig;
|
|
252
|
+
private defaultStyle;
|
|
253
|
+
private _defaultConfig;
|
|
254
|
+
private _defaultStyle;
|
|
255
|
+
private startCallback?;
|
|
256
|
+
private endCallback?;
|
|
257
|
+
private Radius;
|
|
258
|
+
private prizeRadius;
|
|
259
|
+
private prizeDeg;
|
|
260
|
+
private prizeAng;
|
|
261
|
+
private rotateDeg;
|
|
262
|
+
private maxBtnRadius;
|
|
263
|
+
private startTime;
|
|
264
|
+
private endTime;
|
|
265
|
+
private stopDeg;
|
|
266
|
+
private endDeg;
|
|
267
|
+
private FPS;
|
|
268
|
+
/**
|
|
269
|
+
* 游戏当前的阶段
|
|
270
|
+
* step = 0 时, 游戏尚未开始
|
|
271
|
+
* step = 1 时, 此时处于加速阶段
|
|
272
|
+
* step = 2 时, 此时处于匀速阶段
|
|
273
|
+
* step = 3 时, 此时处于减速阶段
|
|
274
|
+
*/
|
|
275
|
+
private step;
|
|
276
|
+
/**
|
|
277
|
+
* 中奖索引
|
|
278
|
+
* prizeFlag = undefined 时, 处于开始抽奖阶段, 正常旋转
|
|
279
|
+
* prizeFlag >= 0 时, 说明stop方法被调用, 并且传入了中奖索引
|
|
280
|
+
* prizeFlag === -1 时, 说明stop方法被调用, 并且传入了负值, 本次抽奖无效
|
|
281
|
+
*/
|
|
282
|
+
private prizeFlag;
|
|
283
|
+
private ImageCache;
|
|
284
|
+
/**
|
|
285
|
+
* 大转盘构造器
|
|
286
|
+
* @param config 配置项
|
|
287
|
+
* @param data 抽奖数据
|
|
288
|
+
*/
|
|
289
|
+
constructor(config: UserConfigType, data: LuckyWheelConfig);
|
|
290
|
+
protected resize(): void;
|
|
291
|
+
protected initLucky(): void;
|
|
292
|
+
/**
|
|
293
|
+
* 初始化数据
|
|
294
|
+
* @param data
|
|
295
|
+
*/
|
|
296
|
+
private initData;
|
|
297
|
+
/**
|
|
298
|
+
* 初始化属性计算
|
|
299
|
+
*/
|
|
300
|
+
private initComputed;
|
|
301
|
+
/**
|
|
302
|
+
* 初始化观察者
|
|
303
|
+
*/
|
|
304
|
+
private initWatch;
|
|
305
|
+
/**
|
|
306
|
+
* 初始化 canvas 抽奖
|
|
307
|
+
*/
|
|
308
|
+
init(): Promise<void>;
|
|
309
|
+
private initImageCache;
|
|
310
|
+
/**
|
|
311
|
+
* canvas点击事件
|
|
312
|
+
* @param e 事件参数
|
|
313
|
+
*/
|
|
314
|
+
protected handleClick(e: MouseEvent): void;
|
|
315
|
+
/**
|
|
316
|
+
* 根据索引单独加载指定图片并缓存
|
|
317
|
+
* @param cellName 模块名称
|
|
318
|
+
* @param cellIndex 模块索引
|
|
319
|
+
* @param imgName 模块对应的图片缓存
|
|
320
|
+
* @param imgIndex 图片索引
|
|
321
|
+
*/
|
|
322
|
+
private loadAndCacheImg;
|
|
323
|
+
private drawBlock;
|
|
324
|
+
/**
|
|
325
|
+
* 开始绘制
|
|
326
|
+
*/
|
|
327
|
+
protected draw(): void;
|
|
328
|
+
/**
|
|
329
|
+
* 刻舟求剑
|
|
330
|
+
*/
|
|
331
|
+
private carveOnGunwaleOfAMovingBoat;
|
|
332
|
+
/**
|
|
333
|
+
* 对外暴露: 开始抽奖方法
|
|
334
|
+
*/
|
|
335
|
+
play(): void;
|
|
336
|
+
/**
|
|
337
|
+
* 对外暴露: 缓慢停止方法
|
|
338
|
+
* @param index 中奖索引
|
|
339
|
+
*/
|
|
340
|
+
stop(index?: number): void;
|
|
341
|
+
/**
|
|
342
|
+
* 实际开始执行方法
|
|
343
|
+
* @param num 记录帧动画执行多少次
|
|
344
|
+
*/
|
|
345
|
+
private run;
|
|
346
|
+
/**
|
|
347
|
+
* 换算渲染坐标
|
|
348
|
+
* @param x
|
|
349
|
+
* @param y
|
|
350
|
+
*/
|
|
351
|
+
protected conversionAxis(x: number, y: number): [number, number];
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
declare type PrizeFontType$1 = FontItemType & FontExtendType;
|
|
355
|
+
declare type ButtonFontType = FontItemType & FontExtendType;
|
|
356
|
+
declare type BlockImgType$1 = ImgItemType & {};
|
|
357
|
+
declare type PrizeImgType$1 = ImgItemType & {
|
|
358
|
+
activeSrc?: string;
|
|
359
|
+
};
|
|
360
|
+
declare type ButtonImgType = ImgItemType & {};
|
|
361
|
+
declare type BlockType$1 = {
|
|
362
|
+
borderRadius?: BorderRadiusType;
|
|
363
|
+
background?: BackgroundType;
|
|
364
|
+
padding?: string;
|
|
365
|
+
paddingTop?: string | number;
|
|
366
|
+
paddingRight?: string | number;
|
|
367
|
+
paddingBottom?: string | number;
|
|
368
|
+
paddingLeft?: string | number;
|
|
369
|
+
imgs?: Array<BlockImgType$1>;
|
|
370
|
+
};
|
|
371
|
+
declare type CellType<T, U> = {
|
|
372
|
+
x: number;
|
|
373
|
+
y: number;
|
|
374
|
+
col?: number;
|
|
375
|
+
row?: number;
|
|
376
|
+
borderRadius?: BorderRadiusType;
|
|
377
|
+
background?: BackgroundType;
|
|
378
|
+
shadow?: ShadowType;
|
|
379
|
+
fonts?: Array<T>;
|
|
380
|
+
imgs?: Array<U>;
|
|
381
|
+
};
|
|
382
|
+
declare type PrizeType$1 = CellType<PrizeFontType$1, PrizeImgType$1> & {
|
|
383
|
+
range?: number;
|
|
384
|
+
disabled?: boolean;
|
|
385
|
+
};
|
|
386
|
+
declare type ButtonType = CellType<ButtonFontType, ButtonImgType> & {
|
|
387
|
+
callback?: Function;
|
|
388
|
+
};
|
|
389
|
+
declare type DefaultConfigType$1 = {
|
|
390
|
+
gutter?: number;
|
|
391
|
+
speed?: number;
|
|
392
|
+
accelerationTime?: number;
|
|
393
|
+
decelerationTime?: number;
|
|
394
|
+
};
|
|
395
|
+
declare type DefaultStyleType$1 = {
|
|
396
|
+
borderRadius?: BorderRadiusType;
|
|
397
|
+
background?: BackgroundType;
|
|
398
|
+
shadow?: ShadowType;
|
|
399
|
+
fontColor?: PrizeFontType$1['fontColor'];
|
|
400
|
+
fontSize?: PrizeFontType$1['fontSize'];
|
|
401
|
+
fontStyle?: PrizeFontType$1['fontStyle'];
|
|
402
|
+
fontWeight?: PrizeFontType$1['fontWeight'];
|
|
403
|
+
lineHeight?: PrizeFontType$1['lineHeight'];
|
|
404
|
+
wordWrap?: PrizeFontType$1['wordWrap'];
|
|
405
|
+
lengthLimit?: PrizeFontType$1['lengthLimit'];
|
|
406
|
+
lineClamp?: PrizeFontType$1['lineClamp'];
|
|
407
|
+
};
|
|
408
|
+
declare type ActiveStyleType = {
|
|
409
|
+
background?: BackgroundType;
|
|
410
|
+
shadow?: ShadowType;
|
|
411
|
+
fontColor?: PrizeFontType$1['fontColor'];
|
|
412
|
+
fontSize?: PrizeFontType$1['fontSize'];
|
|
413
|
+
fontStyle?: PrizeFontType$1['fontStyle'];
|
|
414
|
+
fontWeight?: PrizeFontType$1['fontWeight'];
|
|
415
|
+
lineHeight?: PrizeFontType$1['lineHeight'];
|
|
416
|
+
};
|
|
417
|
+
declare type RowsType = number;
|
|
418
|
+
declare type ColsType = number;
|
|
419
|
+
declare type StartCallbackType = (e: MouseEvent, button?: ButtonType) => void;
|
|
420
|
+
declare type EndCallbackType$1 = (prize: object) => void;
|
|
421
|
+
interface LuckyGridConfig {
|
|
422
|
+
width: string | number;
|
|
423
|
+
height: string | number;
|
|
424
|
+
rows?: RowsType;
|
|
425
|
+
cols?: ColsType;
|
|
426
|
+
blocks?: Array<BlockType$1>;
|
|
427
|
+
prizes?: Array<PrizeType$1>;
|
|
428
|
+
buttons?: Array<ButtonType>;
|
|
429
|
+
button?: ButtonType;
|
|
430
|
+
defaultConfig?: DefaultConfigType$1;
|
|
431
|
+
defaultStyle?: DefaultStyleType$1;
|
|
432
|
+
activeStyle?: ActiveStyleType;
|
|
433
|
+
start?: StartCallbackType;
|
|
434
|
+
end?: EndCallbackType$1;
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
declare class LuckyGrid extends Lucky {
|
|
438
|
+
private rows;
|
|
439
|
+
private cols;
|
|
440
|
+
private blocks;
|
|
441
|
+
private prizes;
|
|
442
|
+
private buttons;
|
|
443
|
+
private button?;
|
|
444
|
+
private defaultConfig;
|
|
445
|
+
private defaultStyle;
|
|
446
|
+
private activeStyle;
|
|
447
|
+
private _defaultConfig;
|
|
448
|
+
private _defaultStyle;
|
|
449
|
+
private _activeStyle;
|
|
450
|
+
private startCallback?;
|
|
451
|
+
private endCallback?;
|
|
452
|
+
private cellWidth;
|
|
453
|
+
private cellHeight;
|
|
454
|
+
private startTime;
|
|
455
|
+
private endTime;
|
|
456
|
+
private currIndex;
|
|
457
|
+
private stopIndex;
|
|
458
|
+
private endIndex;
|
|
459
|
+
private demo;
|
|
460
|
+
private timer;
|
|
461
|
+
private FPS;
|
|
462
|
+
/**
|
|
463
|
+
* 游戏当前的阶段
|
|
464
|
+
* step = 0 时, 游戏尚未开始
|
|
465
|
+
* step = 1 时, 此时处于加速阶段
|
|
466
|
+
* step = 2 时, 此时处于匀速阶段
|
|
467
|
+
* step = 3 时, 此时处于减速阶段
|
|
468
|
+
*/
|
|
469
|
+
private step;
|
|
470
|
+
/**
|
|
471
|
+
* 中奖索引
|
|
472
|
+
* prizeFlag = undefined 时, 处于开始抽奖阶段, 正常旋转
|
|
473
|
+
* prizeFlag >= 0 时, 说明stop方法被调用, 并且传入了中奖索引
|
|
474
|
+
* prizeFlag === -1 时, 说明stop方法被调用, 并且传入了负值, 本次抽奖无效
|
|
475
|
+
*/
|
|
476
|
+
private prizeFlag;
|
|
477
|
+
private cells;
|
|
478
|
+
private prizeArea;
|
|
479
|
+
private ImageCache;
|
|
480
|
+
/**
|
|
481
|
+
* 九宫格构造器
|
|
482
|
+
* @param config 配置项
|
|
483
|
+
* @param data 抽奖数据
|
|
484
|
+
*/
|
|
485
|
+
constructor(config: UserConfigType, data: LuckyGridConfig);
|
|
486
|
+
protected resize(): void;
|
|
487
|
+
protected initLucky(): void;
|
|
488
|
+
/**
|
|
489
|
+
* 初始化数据
|
|
490
|
+
* @param data
|
|
491
|
+
*/
|
|
492
|
+
private initData;
|
|
493
|
+
/**
|
|
494
|
+
* 初始化属性计算
|
|
495
|
+
*/
|
|
496
|
+
private initComputed;
|
|
497
|
+
/**
|
|
498
|
+
* 初始化观察者
|
|
499
|
+
*/
|
|
500
|
+
private initWatch;
|
|
501
|
+
/**
|
|
502
|
+
* 初始化 canvas 抽奖
|
|
503
|
+
*/
|
|
504
|
+
init(): Promise<void>;
|
|
505
|
+
private initImageCache;
|
|
506
|
+
/**
|
|
507
|
+
* canvas点击事件
|
|
508
|
+
* @param e 事件参数
|
|
509
|
+
*/
|
|
510
|
+
protected handleClick(e: MouseEvent): void;
|
|
511
|
+
/**
|
|
512
|
+
* 根据索引单独加载指定图片并缓存
|
|
513
|
+
* @param cellName 模块名称
|
|
514
|
+
* @param cellIndex 模块索引
|
|
515
|
+
* @param imgName 模块对应的图片缓存
|
|
516
|
+
* @param imgIndex 图片索引
|
|
517
|
+
*/
|
|
518
|
+
private loadAndCacheImg;
|
|
519
|
+
/**
|
|
520
|
+
* 绘制九宫格抽奖
|
|
521
|
+
*/
|
|
522
|
+
protected draw(): void;
|
|
523
|
+
/**
|
|
524
|
+
* 处理背景色
|
|
525
|
+
* @param x
|
|
526
|
+
* @param y
|
|
527
|
+
* @param width
|
|
528
|
+
* @param height
|
|
529
|
+
* @param background
|
|
530
|
+
* @param isActive
|
|
531
|
+
*/
|
|
532
|
+
private handleBackground;
|
|
533
|
+
/**
|
|
534
|
+
* 刻舟求剑
|
|
535
|
+
*/
|
|
536
|
+
private carveOnGunwaleOfAMovingBoat;
|
|
537
|
+
/**
|
|
538
|
+
* 对外暴露: 开始抽奖方法
|
|
539
|
+
*/
|
|
540
|
+
play(): void;
|
|
541
|
+
/**
|
|
542
|
+
* 对外暴露: 缓慢停止方法
|
|
543
|
+
* @param index 中奖索引
|
|
544
|
+
*/
|
|
545
|
+
stop(index?: number): void;
|
|
546
|
+
/**
|
|
547
|
+
* 实际开始执行方法
|
|
548
|
+
* @param num 记录帧动画执行多少次
|
|
549
|
+
*/
|
|
550
|
+
private run;
|
|
551
|
+
/**
|
|
552
|
+
* 计算奖品格子的几何属性
|
|
553
|
+
* @param { array } [...矩阵坐标, col, row]
|
|
554
|
+
* @return { array } [...真实坐标, width, height]
|
|
555
|
+
*/
|
|
556
|
+
private getGeometricProperty;
|
|
557
|
+
/**
|
|
558
|
+
* 换算渲染坐标
|
|
559
|
+
* @param x
|
|
560
|
+
* @param y
|
|
561
|
+
*/
|
|
562
|
+
protected conversionAxis(x: number, y: number): [number, number];
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
declare type PrizeFontType = FontItemType & FontExtendType;
|
|
566
|
+
declare type BlockImgType = ImgItemType & {};
|
|
567
|
+
declare type PrizeImgType = ImgItemType;
|
|
568
|
+
declare type BlockType = {
|
|
569
|
+
borderRadius?: BorderRadiusType;
|
|
570
|
+
background?: BackgroundType;
|
|
571
|
+
padding?: string;
|
|
572
|
+
paddingTop?: string | number;
|
|
573
|
+
paddingRight?: string | number;
|
|
574
|
+
paddingBottom?: string | number;
|
|
575
|
+
paddingLeft?: string | number;
|
|
576
|
+
imgs?: Array<BlockImgType>;
|
|
577
|
+
};
|
|
578
|
+
declare type PrizeType = {
|
|
579
|
+
borderRadius?: BorderRadiusType;
|
|
580
|
+
background?: BackgroundType;
|
|
581
|
+
fonts?: Array<PrizeFontType>;
|
|
582
|
+
imgs?: Array<PrizeImgType>;
|
|
583
|
+
};
|
|
584
|
+
declare type SlotType = {
|
|
585
|
+
order?: number[];
|
|
586
|
+
speed?: number;
|
|
587
|
+
direction?: 1 | -1;
|
|
588
|
+
};
|
|
589
|
+
declare type DefaultConfigType = {
|
|
590
|
+
/**
|
|
591
|
+
* vertical 为纵向旋转
|
|
592
|
+
* horizontal 为横向旋转
|
|
593
|
+
*/
|
|
594
|
+
mode?: 'vertical' | 'horizontal';
|
|
595
|
+
/**
|
|
596
|
+
* 当排列方向 = `vertical`时
|
|
597
|
+
* 1 bottom to top
|
|
598
|
+
* -1 top to bottom
|
|
599
|
+
* 当排列方向 = `horizontal`时
|
|
600
|
+
* 1 right to left
|
|
601
|
+
* -1 left to right
|
|
602
|
+
*/
|
|
603
|
+
direction?: 1 | -1;
|
|
604
|
+
rowSpacing?: number;
|
|
605
|
+
colSpacing?: number;
|
|
606
|
+
speed?: number;
|
|
607
|
+
accelerationTime?: number;
|
|
608
|
+
decelerationTime?: number;
|
|
609
|
+
};
|
|
610
|
+
declare type DefaultStyleType = {
|
|
611
|
+
borderRadius?: BorderRadiusType;
|
|
612
|
+
background?: BackgroundType;
|
|
613
|
+
fontColor?: PrizeFontType['fontColor'];
|
|
614
|
+
fontSize?: PrizeFontType['fontSize'];
|
|
615
|
+
fontStyle?: PrizeFontType['fontStyle'];
|
|
616
|
+
fontWeight?: PrizeFontType['fontWeight'];
|
|
617
|
+
lineHeight?: PrizeFontType['lineHeight'];
|
|
618
|
+
wordWrap?: PrizeFontType['wordWrap'];
|
|
619
|
+
lengthLimit?: PrizeFontType['lengthLimit'];
|
|
620
|
+
lineClamp?: PrizeFontType['lineClamp'];
|
|
621
|
+
};
|
|
622
|
+
declare type EndCallbackType = (prize: PrizeType | undefined) => void;
|
|
623
|
+
interface SlotMachineConfig {
|
|
624
|
+
width: string | number;
|
|
625
|
+
height: string | number;
|
|
626
|
+
blocks?: Array<BlockType>;
|
|
627
|
+
prizes?: Array<PrizeType>;
|
|
628
|
+
slots?: Array<SlotType>;
|
|
629
|
+
defaultConfig?: DefaultConfigType;
|
|
630
|
+
defaultStyle?: DefaultStyleType;
|
|
631
|
+
end?: EndCallbackType;
|
|
632
|
+
}
|
|
633
|
+
|
|
634
|
+
declare class SlotMachine extends Lucky {
|
|
635
|
+
private blocks;
|
|
636
|
+
private prizes;
|
|
637
|
+
private slots;
|
|
638
|
+
private defaultConfig;
|
|
639
|
+
private _defaultConfig;
|
|
640
|
+
private defaultStyle;
|
|
641
|
+
private _defaultStyle;
|
|
642
|
+
private endCallback;
|
|
643
|
+
private _offscreenCanvas?;
|
|
644
|
+
private cellWidth;
|
|
645
|
+
private cellHeight;
|
|
646
|
+
private cellAndSpacing;
|
|
647
|
+
private widthAndSpacing;
|
|
648
|
+
private heightAndSpacing;
|
|
649
|
+
private FPS;
|
|
650
|
+
private scroll;
|
|
651
|
+
private stopScroll;
|
|
652
|
+
private endScroll;
|
|
653
|
+
private startTime;
|
|
654
|
+
private endTime;
|
|
655
|
+
/**
|
|
656
|
+
* 游戏当前的阶段
|
|
657
|
+
* step = 0 时, 游戏尚未开始
|
|
658
|
+
* step = 1 时, 此时处于加速阶段
|
|
659
|
+
* step = 2 时, 此时处于匀速阶段
|
|
660
|
+
* step = 3 时, 此时处于减速阶段
|
|
661
|
+
*/
|
|
662
|
+
private step;
|
|
663
|
+
/**
|
|
664
|
+
* 中奖索引
|
|
665
|
+
* prizeFlag = undefined 时, 处于开始抽奖阶段, 正常旋转
|
|
666
|
+
* prizeFlag >= 0 时, 说明stop方法被调用, 并且传入了中奖索引
|
|
667
|
+
* prizeFlag === -1 时, 说明stop方法被调用, 并且传入了负值, 本次抽奖无效
|
|
668
|
+
*/
|
|
669
|
+
private prizeFlag;
|
|
670
|
+
private prizeArea?;
|
|
671
|
+
private ImageCache;
|
|
672
|
+
/**
|
|
673
|
+
* 老虎机构造器
|
|
674
|
+
* @param config 配置项
|
|
675
|
+
* @param data 抽奖数据
|
|
676
|
+
*/
|
|
677
|
+
constructor(config: UserConfigType, data: SlotMachineConfig);
|
|
678
|
+
protected resize(): void;
|
|
679
|
+
protected initLucky(): void;
|
|
680
|
+
/**
|
|
681
|
+
* 初始化数据
|
|
682
|
+
* @param data
|
|
683
|
+
*/
|
|
684
|
+
private initData;
|
|
685
|
+
/**
|
|
686
|
+
* 初始化属性计算
|
|
687
|
+
*/
|
|
688
|
+
private initComputed;
|
|
689
|
+
/**
|
|
690
|
+
* 初始化观察者
|
|
691
|
+
*/
|
|
692
|
+
private initWatch;
|
|
693
|
+
/**
|
|
694
|
+
* 初始化 canvas 抽奖
|
|
695
|
+
*/
|
|
696
|
+
init(): Promise<void>;
|
|
697
|
+
private initImageCache;
|
|
698
|
+
/**
|
|
699
|
+
* 根据索引单独加载指定图片并缓存
|
|
700
|
+
* @param cellName 模块名称
|
|
701
|
+
* @param cellIndex 模块索引
|
|
702
|
+
* @param imgName 模块对应的图片缓存
|
|
703
|
+
* @param imgIndex 图片索引
|
|
704
|
+
*/
|
|
705
|
+
private loadAndCacheImg;
|
|
706
|
+
/**
|
|
707
|
+
* 绘制离屏canvas
|
|
708
|
+
*/
|
|
709
|
+
protected drawOffscreenCanvas(): void;
|
|
710
|
+
/**
|
|
711
|
+
* 绘制背景区域
|
|
712
|
+
*/
|
|
713
|
+
protected drawBlocks(): SlotMachine['prizeArea'];
|
|
714
|
+
/**
|
|
715
|
+
* 绘制老虎机抽奖
|
|
716
|
+
*/
|
|
717
|
+
protected draw(): void;
|
|
718
|
+
/**
|
|
719
|
+
* 刻舟求剑
|
|
720
|
+
*/
|
|
721
|
+
private carveOnGunwaleOfAMovingBoat;
|
|
722
|
+
/**
|
|
723
|
+
* 对外暴露: 开始抽奖方法
|
|
724
|
+
*/
|
|
725
|
+
play(): void;
|
|
726
|
+
stop(index: number | number[], slotIndex?: number): void;
|
|
727
|
+
/**
|
|
728
|
+
* 让游戏动起来
|
|
729
|
+
* @param num 记录帧动画执行多少次
|
|
730
|
+
*/
|
|
731
|
+
private run;
|
|
732
|
+
private displacement;
|
|
733
|
+
private displacementWidthOrHeight;
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
/**
|
|
737
|
+
* 切割圆角
|
|
738
|
+
* @param img 将要裁剪的图片对象
|
|
739
|
+
* @param radius 裁剪的圆角半径
|
|
740
|
+
* @returns 返回一个离屏 canvas 用于渲染
|
|
741
|
+
*/
|
|
742
|
+
declare const cutRound: (img: ImgType, radius: number) => ImgType;
|
|
743
|
+
/**
|
|
744
|
+
* 透明度
|
|
745
|
+
* @param img 将要处理的图片对象
|
|
746
|
+
* @param opacity 透明度
|
|
747
|
+
* @returns 返回一个离屏 canvas 用于渲染
|
|
748
|
+
*/
|
|
749
|
+
declare const opacity: (img: ImgType, opacity: number) => ImgType;
|
|
750
|
+
|
|
751
|
+
export { LuckyGrid, LuckyWheel, SlotMachine, cutRound, opacity };
|