mirror of
https://github.com/unanmed/HumanBreak.git
synced 2025-01-19 04:19:30 +08:00
修复一些类型错误,完成布局插件
This commit is contained in:
parent
565dcab6dd
commit
5087b06633
@ -1,3 +1,5 @@
|
|||||||
|
import { has } from '../utils';
|
||||||
|
|
||||||
type CanvasStyle = string | CanvasPattern | CanvasGradient;
|
type CanvasStyle = string | CanvasPattern | CanvasGradient;
|
||||||
|
|
||||||
export class Layout {
|
export class Layout {
|
||||||
@ -18,23 +20,23 @@ export class Layout {
|
|||||||
this.ctx = canvas.getContext('2d')!;
|
this.ctx = canvas.getContext('2d')!;
|
||||||
}
|
}
|
||||||
|
|
||||||
image(layout: Layout | HTMLCanvasElement | Path2D, type: number): Layout;
|
image(layout: Layout | CanvasImageSource | Path2D, type: number): this;
|
||||||
image(
|
image(
|
||||||
layout: Layout | HTMLCanvasElement | Path2D,
|
layout: Layout | CanvasImageSource | Path2D,
|
||||||
type: number,
|
type: number,
|
||||||
x: number,
|
x: number,
|
||||||
y: number
|
y: number
|
||||||
): Layout;
|
): this;
|
||||||
image(
|
image(
|
||||||
layout: Layout | HTMLCanvasElement | Path2D,
|
layout: Layout | CanvasImageSource | Path2D,
|
||||||
type: number,
|
type: number,
|
||||||
x: number,
|
x: number,
|
||||||
y: number,
|
y: number,
|
||||||
w: number,
|
w: number,
|
||||||
h: number
|
h: number
|
||||||
): Layout;
|
): this;
|
||||||
image(
|
image(
|
||||||
layout: Layout | HTMLCanvasElement | Path2D,
|
layout: Layout | CanvasImageSource | Path2D,
|
||||||
type: number,
|
type: number,
|
||||||
sx: number,
|
sx: number,
|
||||||
sy: number,
|
sy: number,
|
||||||
@ -44,12 +46,12 @@ export class Layout {
|
|||||||
dy: number,
|
dy: number,
|
||||||
dw: number,
|
dw: number,
|
||||||
dh: number
|
dh: number
|
||||||
): Layout;
|
): this;
|
||||||
image(
|
image(
|
||||||
layout: Layout | HTMLCanvasElement | Path2D,
|
layout: Layout | CanvasImageSource | Path2D,
|
||||||
type: number,
|
type: number,
|
||||||
sx?: number,
|
sx: number = 0,
|
||||||
sy?: number,
|
sy: number = 0,
|
||||||
sw?: number,
|
sw?: number,
|
||||||
sh?: number,
|
sh?: number,
|
||||||
dx?: number,
|
dx?: number,
|
||||||
@ -57,6 +59,40 @@ export class Layout {
|
|||||||
dw?: number,
|
dw?: number,
|
||||||
dh?: number
|
dh?: number
|
||||||
) {
|
) {
|
||||||
|
const img = layout instanceof Layout ? layout.canvas : layout;
|
||||||
|
const fill = () => {
|
||||||
|
if (img instanceof Path2D) {
|
||||||
|
this.ctx.fill(img);
|
||||||
|
} else {
|
||||||
|
this.ctx.drawImage(img, sx, sy, sw!, sh!, dx!, dy!, dw!, dh!);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if (type & Layout.IMAGE) {
|
||||||
|
// 绘制图片
|
||||||
|
fill();
|
||||||
|
}
|
||||||
|
if (type & Layout.CLEAR) {
|
||||||
|
// 按照图片清除一个区域
|
||||||
|
this.ctx.save();
|
||||||
|
this.ctx.globalCompositeOperation = 'destination-out';
|
||||||
|
fill();
|
||||||
|
this.ctx.restore();
|
||||||
|
}
|
||||||
|
if (type & Layout.MASK) {
|
||||||
|
// 蒙版,只显示蒙版内的东西
|
||||||
|
this.ctx.save();
|
||||||
|
this.ctx.globalCompositeOperation = 'destination-in';
|
||||||
|
fill();
|
||||||
|
this.ctx.restore();
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 擦除一个矩形
|
||||||
|
*/
|
||||||
|
clear(x: number, y: number, w: number, h: number): this {
|
||||||
|
this.ctx.clearRect(x, y, w, h);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,7 +110,9 @@ export class Layout {
|
|||||||
x: number,
|
x: number,
|
||||||
y: number,
|
y: number,
|
||||||
maxWidth?: number
|
maxWidth?: number
|
||||||
): Layout {
|
): this {
|
||||||
|
if (type & Layout.FILL) this.ctx.fillText(str, x, y, maxWidth);
|
||||||
|
if (type & Layout.STROKE) this.ctx.strokeText(str, x, y, maxWidth);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,21 +121,25 @@ export class Layout {
|
|||||||
* @param path 路径
|
* @param path 路径
|
||||||
* @param type 绘制类型
|
* @param type 绘制类型
|
||||||
*/
|
*/
|
||||||
path(path: Path2D, type: number): Layout {
|
path(path: Path2D, type: number, rule?: CanvasFillRule): this {
|
||||||
|
if (type & Layout.FILL) this.ctx.fill(path, rule);
|
||||||
|
if (type & Layout.STROKE) this.ctx.stroke(path);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存画布状态
|
* 保存画布状态
|
||||||
*/
|
*/
|
||||||
save(): Layout {
|
save(): this {
|
||||||
|
this.ctx.save();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 回退画布状态
|
* 回退画布状态
|
||||||
*/
|
*/
|
||||||
restore(): Layout {
|
restore(): this {
|
||||||
|
this.ctx.restore();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -105,7 +147,8 @@ export class Layout {
|
|||||||
* 设置填充样式
|
* 设置填充样式
|
||||||
* @param style 样式
|
* @param style 样式
|
||||||
*/
|
*/
|
||||||
fillStyle(style: CanvasStyle): Layout {
|
fillStyle(style: CanvasStyle): this {
|
||||||
|
this.ctx.fillStyle = style;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,7 +156,8 @@ export class Layout {
|
|||||||
* 设置描边样式
|
* 设置描边样式
|
||||||
* @param style 样式
|
* @param style 样式
|
||||||
*/
|
*/
|
||||||
strokeStyle(style: CanvasStyle): Layout {
|
strokeStyle(style: CanvasStyle): this {
|
||||||
|
this.ctx.strokeStyle = style;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -121,7 +165,8 @@ export class Layout {
|
|||||||
* 设置文本对齐
|
* 设置文本对齐
|
||||||
* @param align 文本左右对齐方式
|
* @param align 文本左右对齐方式
|
||||||
*/
|
*/
|
||||||
textAlign(align: CanvasTextAlign): Layout {
|
textAlign(align: CanvasTextAlign): this {
|
||||||
|
this.ctx.textAlign = align;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,7 +174,8 @@ export class Layout {
|
|||||||
* 设置文本基线
|
* 设置文本基线
|
||||||
* @param align 文本基线,即文本上下对齐方式
|
* @param align 文本基线,即文本上下对齐方式
|
||||||
*/
|
*/
|
||||||
textBaseline(align: CanvasTextBaseline): Layout {
|
textBaseline(align: CanvasTextBaseline): this {
|
||||||
|
this.ctx.textBaseline = align;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -137,7 +183,8 @@ export class Layout {
|
|||||||
* 设置滤镜
|
* 设置滤镜
|
||||||
* @param filter 滤镜
|
* @param filter 滤镜
|
||||||
*/
|
*/
|
||||||
filter(filter: string): Layout {
|
filter(filter: string): this {
|
||||||
|
this.ctx.filter = filter;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,7 +192,11 @@ export class Layout {
|
|||||||
* 设置阴影信息
|
* 设置阴影信息
|
||||||
* @param shadow 阴影信息
|
* @param shadow 阴影信息
|
||||||
*/
|
*/
|
||||||
shadow(shadow: Partial<CanvasShadowStyles>): Layout {
|
shadow(shadow: Partial<CanvasShadowStyles>): this {
|
||||||
|
for (const [p, v] of Object.entries(shadow)) {
|
||||||
|
// @ts-ignore
|
||||||
|
this.ctx[p] = v;
|
||||||
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,7 +204,8 @@ export class Layout {
|
|||||||
* 设置线宽(描边宽度,包括字体描边)
|
* 设置线宽(描边宽度,包括字体描边)
|
||||||
* @param width 宽度
|
* @param width 宽度
|
||||||
*/
|
*/
|
||||||
lineWidth(width: number): Layout {
|
lineWidth(width: number): this {
|
||||||
|
this.ctx.lineWidth = width;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -161,7 +213,8 @@ export class Layout {
|
|||||||
* 设置线尾样式
|
* 设置线尾样式
|
||||||
* @param cap 线尾样式
|
* @param cap 线尾样式
|
||||||
*/
|
*/
|
||||||
lineCap(cap: CanvasLineCap): Layout {
|
lineCap(cap: CanvasLineCap): this {
|
||||||
|
this.ctx.lineCap = cap;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,7 +222,8 @@ export class Layout {
|
|||||||
* 设置线段连接方式样式
|
* 设置线段连接方式样式
|
||||||
* @param join 线段连接方式
|
* @param join 线段连接方式
|
||||||
*/
|
*/
|
||||||
lineJoin(join: CanvasLineJoin): Layout {
|
lineJoin(join: CanvasLineJoin): this {
|
||||||
|
this.ctx.lineJoin = join;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -177,7 +231,8 @@ export class Layout {
|
|||||||
* 设置画布的字体
|
* 设置画布的字体
|
||||||
* @param font 字体
|
* @param font 字体
|
||||||
*/
|
*/
|
||||||
font(font: string): Layout {
|
font(font: string): this {
|
||||||
|
this.ctx.font = font;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -185,7 +240,8 @@ export class Layout {
|
|||||||
* 设置画布之后绘制的不透明度
|
* 设置画布之后绘制的不透明度
|
||||||
* @param alpha 不透明度
|
* @param alpha 不透明度
|
||||||
*/
|
*/
|
||||||
alpha(alpha: number): Layout {
|
alpha(alpha: number): this {
|
||||||
|
this.ctx.globalAlpha = alpha;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -193,7 +249,8 @@ export class Layout {
|
|||||||
* 设置虚线样式
|
* 设置虚线样式
|
||||||
* @param dash 虚线样式
|
* @param dash 虚线样式
|
||||||
*/
|
*/
|
||||||
lineDash(dash: number[]): Layout {
|
lineDash(dash: number[]): this {
|
||||||
|
this.ctx.setLineDash(dash);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,7 +259,8 @@ export class Layout {
|
|||||||
* @param x 横向放缩量
|
* @param x 横向放缩量
|
||||||
* @param y 纵向放缩量
|
* @param y 纵向放缩量
|
||||||
*/
|
*/
|
||||||
scale(x: number, y: number): Layout {
|
scale(x: number, y: number): this {
|
||||||
|
this.ctx.scale(x, y);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -210,7 +268,8 @@ export class Layout {
|
|||||||
* 旋转画布
|
* 旋转画布
|
||||||
* @param rad 顺时针旋转的弧度数
|
* @param rad 顺时针旋转的弧度数
|
||||||
*/
|
*/
|
||||||
rotate(rad: number): Layout {
|
rotate(rad: number): this {
|
||||||
|
this.ctx.rotate(rad);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,7 +278,8 @@ export class Layout {
|
|||||||
* @param x 水平平移量
|
* @param x 水平平移量
|
||||||
* @param y 竖直平移量
|
* @param y 竖直平移量
|
||||||
*/
|
*/
|
||||||
translate(x: number, y: number): Layout {
|
translate(x: number, y: number): this {
|
||||||
|
this.ctx.translate(x, y);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,6 +316,8 @@ export class Layout {
|
|||||||
e?: number,
|
e?: number,
|
||||||
f?: number
|
f?: number
|
||||||
) {
|
) {
|
||||||
|
if (!has(a)) this.ctx.resetTransform();
|
||||||
|
else this.ctx.transform(a, b!, c!, d!, e!, f!);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -263,7 +325,15 @@ export class Layout {
|
|||||||
* 设置混合方式,像image的蒙版功能与擦除功能本质上也是通过设置混合方式实现的
|
* 设置混合方式,像image的蒙版功能与擦除功能本质上也是通过设置混合方式实现的
|
||||||
* @param value 混合方式
|
* @param value 混合方式
|
||||||
*/
|
*/
|
||||||
composite(value: GlobalCompositeOperation): Layout {
|
composite(value: GlobalCompositeOperation): this {
|
||||||
|
this.ctx.globalCompositeOperation = value;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除这个布局
|
||||||
|
*/
|
||||||
|
destroy() {
|
||||||
|
this.canvas.remove();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
255
src/plugin/layout/layoutGame.ts
Normal file
255
src/plugin/layout/layoutGame.ts
Normal file
@ -0,0 +1,255 @@
|
|||||||
|
import { Layout } from './layout';
|
||||||
|
|
||||||
|
export class LayoutGame extends Layout {
|
||||||
|
/** 画布id */
|
||||||
|
id: string;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
id: string,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
w: number,
|
||||||
|
h: number,
|
||||||
|
z: number
|
||||||
|
) {
|
||||||
|
const ctx = core.createCanvas(id, x, y, w, h, z);
|
||||||
|
super(ctx.canvas);
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
image2(
|
||||||
|
layout: Layout | CanvasImageSource | Path2D | ImageIds,
|
||||||
|
type: number
|
||||||
|
): LayoutGame;
|
||||||
|
image2(
|
||||||
|
layout: Layout | CanvasImageSource | Path2D | ImageIds,
|
||||||
|
type: number,
|
||||||
|
x: number,
|
||||||
|
y: number
|
||||||
|
): LayoutGame;
|
||||||
|
image2(
|
||||||
|
layout: Layout | CanvasImageSource | Path2D | ImageIds,
|
||||||
|
type: number,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
w: number,
|
||||||
|
h: number
|
||||||
|
): LayoutGame;
|
||||||
|
image2(
|
||||||
|
layout: Layout | CanvasImageSource | Path2D | ImageIds,
|
||||||
|
type: number,
|
||||||
|
sx: number,
|
||||||
|
sy: number,
|
||||||
|
sw: number,
|
||||||
|
sh: number,
|
||||||
|
dx: number,
|
||||||
|
dy: number,
|
||||||
|
dw: number,
|
||||||
|
dh: number
|
||||||
|
): LayoutGame;
|
||||||
|
image2(
|
||||||
|
layout: Layout | CanvasImageSource | Path2D | ImageIds,
|
||||||
|
type: number,
|
||||||
|
sx?: number,
|
||||||
|
sy?: number,
|
||||||
|
sw?: number,
|
||||||
|
sh?: number,
|
||||||
|
dx?: number,
|
||||||
|
dy?: number,
|
||||||
|
dw?: number,
|
||||||
|
dh?: number
|
||||||
|
): this {
|
||||||
|
const img =
|
||||||
|
typeof layout === 'string'
|
||||||
|
? core.material.images.images[layout]
|
||||||
|
: layout;
|
||||||
|
|
||||||
|
this.image(img, type, sx!, sy!, sw!, sh!, dx!, dy!, dw!, dh!);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制一个图标
|
||||||
|
* @param id 图标id
|
||||||
|
* @param x 横坐标
|
||||||
|
* @param y 纵坐标
|
||||||
|
* @param w 宽度
|
||||||
|
* @param h 高度
|
||||||
|
* @param frame 绘制第几帧
|
||||||
|
*/
|
||||||
|
icon(
|
||||||
|
id: AllIds,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
w?: number,
|
||||||
|
h?: number,
|
||||||
|
frame?: number
|
||||||
|
): this {
|
||||||
|
core.drawIcon(this.ctx, id, x, y, w, h, frame);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制WindowSkin
|
||||||
|
* @param direction 指向箭头的方向
|
||||||
|
*/
|
||||||
|
winskin(
|
||||||
|
background: any,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
w: number,
|
||||||
|
h: number,
|
||||||
|
direction?: 'up' | 'down',
|
||||||
|
px?: number,
|
||||||
|
py?: number
|
||||||
|
): this {
|
||||||
|
core.drawWindowSkin(
|
||||||
|
background,
|
||||||
|
this.ctx,
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
w,
|
||||||
|
h,
|
||||||
|
direction,
|
||||||
|
px,
|
||||||
|
py
|
||||||
|
);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制一个箭头
|
||||||
|
* @param x1 起始点横坐标
|
||||||
|
* @param y1 起始点纵坐标
|
||||||
|
* @param x2 终止点横坐标
|
||||||
|
* @param y2 终止点纵坐标
|
||||||
|
*/
|
||||||
|
arrow(x1: number, y1: number, x2: number, y2: number): this {
|
||||||
|
core.drawArrow(this.ctx, x1, y1, x2, y2);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制线段
|
||||||
|
*/
|
||||||
|
line(x1: number, y1: number, x2: number, y2: number): this {
|
||||||
|
this.ctx.beginPath();
|
||||||
|
this.ctx.moveTo(x1, y1);
|
||||||
|
this.ctx.lineTo(x2, y2);
|
||||||
|
this.ctx.stroke();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制圆弧或扇形
|
||||||
|
* @param type 绘制类型
|
||||||
|
* @param start 起始弧度
|
||||||
|
* @param end 终止弧度
|
||||||
|
* @param anticlockwise 是否逆时针
|
||||||
|
*/
|
||||||
|
arc(
|
||||||
|
type: number,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
r: number,
|
||||||
|
start: number,
|
||||||
|
end: number,
|
||||||
|
anticlockwise: boolean = false
|
||||||
|
): this {
|
||||||
|
this.ctx.beginPath();
|
||||||
|
this.ctx.arc(x, y, r, start, end, anticlockwise);
|
||||||
|
this.draw(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制一个圆
|
||||||
|
* @param type 绘制类型
|
||||||
|
*/
|
||||||
|
circle(type: number, x: number, y: number, r: number): this {
|
||||||
|
return this.arc(type, x, y, r, 0, Math.PI * 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制椭圆
|
||||||
|
*/
|
||||||
|
ellipse(
|
||||||
|
type: number,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
a: number,
|
||||||
|
b: number,
|
||||||
|
rotation: number = 0,
|
||||||
|
start: number = 0,
|
||||||
|
end: number = Math.PI * 2,
|
||||||
|
anticlockwise: boolean = false
|
||||||
|
): this {
|
||||||
|
this.ctx.beginPath();
|
||||||
|
this.ctx.ellipse(x, y, a, b, rotation, start, end, anticlockwise);
|
||||||
|
this.draw(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制多边形
|
||||||
|
* @param type 绘制类型
|
||||||
|
* @param nodes 多边形节点
|
||||||
|
* @param close 是否闭合路径
|
||||||
|
*/
|
||||||
|
polygon(type: number, nodes: LocArr[], close: boolean = true): this {
|
||||||
|
this.ctx.beginPath();
|
||||||
|
this.ctx.moveTo(nodes[0][0], nodes[0][1]);
|
||||||
|
for (let i = 1; i < nodes.length; i++) {
|
||||||
|
this.ctx.lineTo(nodes[i][0], nodes[i][1]);
|
||||||
|
}
|
||||||
|
if (close) this.ctx.closePath();
|
||||||
|
this.draw(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制矩形
|
||||||
|
*/
|
||||||
|
rect(type: number, x: number, y: number, w: number, h: number): this {
|
||||||
|
if (type & Layout.FILL) this.ctx.fillRect(x, y, w, h);
|
||||||
|
if (type & Layout.STROKE) this.ctx.strokeRect(x, y, w, h);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 绘制圆角矩形
|
||||||
|
*/
|
||||||
|
roundRect(
|
||||||
|
type: number,
|
||||||
|
x: number,
|
||||||
|
y: number,
|
||||||
|
w: number,
|
||||||
|
h: number,
|
||||||
|
r: number
|
||||||
|
) {
|
||||||
|
this.ctx.beginPath();
|
||||||
|
this.ctx.moveTo(x + r, y);
|
||||||
|
this.ctx.lineTo(x + w - r, y);
|
||||||
|
this.ctx.quadraticCurveTo(x + w, y, x + w, y + r);
|
||||||
|
this.ctx.lineTo(x + w, y + h - r);
|
||||||
|
this.ctx.quadraticCurveTo(x + w, y + h, x + w - r, y + h);
|
||||||
|
this.ctx.lineTo(x + r, y + h);
|
||||||
|
this.ctx.quadraticCurveTo(x, y + h, x, y + h - r);
|
||||||
|
this.ctx.lineTo(x, y + r);
|
||||||
|
this.ctx.quadraticCurveTo(x, y, x + r, y);
|
||||||
|
this.ctx.closePath();
|
||||||
|
this.draw(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除这个布局
|
||||||
|
*/
|
||||||
|
destroy() {
|
||||||
|
core.deleteCanvas(this.id);
|
||||||
|
}
|
||||||
|
|
||||||
|
private draw(type: number) {
|
||||||
|
if (type & Layout.FILL) this.ctx.fill();
|
||||||
|
if (type & Layout.STROKE) this.ctx.stroke();
|
||||||
|
}
|
||||||
|
}
|
17
src/types/core.d.ts
vendored
17
src/types/core.d.ts
vendored
@ -528,7 +528,7 @@ type MainDom = {
|
|||||||
* 自绘状态栏画布的context
|
* 自绘状态栏画布的context
|
||||||
*/
|
*/
|
||||||
statusCanvasCtx: CanvasRenderingContext2D;
|
statusCanvasCtx: CanvasRenderingContext2D;
|
||||||
|
} & {
|
||||||
[key: string]: HTMLElement;
|
[key: string]: HTMLElement;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -806,7 +806,7 @@ type CoreStatusBarElements = {
|
|||||||
* 状态栏的图标元素
|
* 状态栏的图标元素
|
||||||
*/
|
*/
|
||||||
readonly image: Record<string, HTMLImageElement>;
|
readonly image: Record<string, HTMLImageElement>;
|
||||||
|
} & {
|
||||||
readonly [key: string]: HTMLElement;
|
readonly [key: string]: HTMLElement;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1079,7 +1079,7 @@ interface Core extends Pick<Main, CoreDataFromMain> {
|
|||||||
* @param _this 执行函数的上下文
|
* @param _this 执行函数的上下文
|
||||||
* @param params 函数的参数
|
* @param params 函数的参数
|
||||||
*/
|
*/
|
||||||
doFunc<F extends Function>(
|
doFunc<F extends (...args: any) => any>(
|
||||||
func: F,
|
func: F,
|
||||||
_this: any,
|
_this: any,
|
||||||
...params: Parameters<F>
|
...params: Parameters<F>
|
||||||
@ -1210,7 +1210,16 @@ interface Main extends MainData {
|
|||||||
/**
|
/**
|
||||||
* 所有的素材图片名称
|
* 所有的素材图片名称
|
||||||
*/
|
*/
|
||||||
readonly materials: Materials;
|
readonly materials: [
|
||||||
|
'animates',
|
||||||
|
'enemys',
|
||||||
|
'items',
|
||||||
|
'npcs',
|
||||||
|
'terrains',
|
||||||
|
'enemy48',
|
||||||
|
'npc48',
|
||||||
|
'icons'
|
||||||
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 要加载的project目录下的文件
|
* 要加载的project目录下的文件
|
||||||
|
5
src/types/data.d.ts
vendored
5
src/types/data.d.ts
vendored
@ -24,6 +24,11 @@ interface MainData {
|
|||||||
*/
|
*/
|
||||||
readonly bgms: BgmIds[];
|
readonly bgms: BgmIds[];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 所有的图片
|
||||||
|
*/
|
||||||
|
readonly images: ImageIds[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 所有的音效
|
* 所有的音效
|
||||||
*/
|
*/
|
||||||
|
2
src/types/eventStatus.d.ts
vendored
2
src/types/eventStatus.d.ts
vendored
@ -309,7 +309,7 @@ interface ActionStatusData {
|
|||||||
/**
|
/**
|
||||||
* 当前的事件类型
|
* 当前的事件类型
|
||||||
*/
|
*/
|
||||||
type: EventType;
|
type: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 当前事件
|
* 当前事件
|
||||||
|
18
src/types/map.d.ts
vendored
18
src/types/map.d.ts
vendored
@ -266,7 +266,7 @@ interface ResolvedFloor<T extends FloorIds = FloorIds> extends FloorBase<T> {
|
|||||||
eachArrive?: MotaEvent;
|
eachArrive?: MotaEvent;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface BlockInfo<T extends AllNumbers = AllNumbers> {
|
interface BlockInfo<T extends keyof NumberToId = keyof NumberToId> {
|
||||||
/**
|
/**
|
||||||
* 图块数字
|
* 图块数字
|
||||||
*/
|
*/
|
||||||
@ -421,16 +421,6 @@ interface DrawThumbnailConfig {
|
|||||||
*/
|
*/
|
||||||
inFlyMap: boolean;
|
inFlyMap: boolean;
|
||||||
|
|
||||||
/**
|
|
||||||
* 小地图模式下的横坐标
|
|
||||||
*/
|
|
||||||
x: number;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 小地图模式下的纵坐标
|
|
||||||
*/
|
|
||||||
y: number;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 小地图模式下的宽度
|
* 小地图模式下的宽度
|
||||||
*/
|
*/
|
||||||
@ -537,7 +527,7 @@ interface Maps {
|
|||||||
* 根据数字获得图块
|
* 根据数字获得图块
|
||||||
* @param number 图块数字
|
* @param number 图块数字
|
||||||
*/
|
*/
|
||||||
getBlockByNumber<T extends AllNumbers>(number: T): Block<T>;
|
getBlockByNumber<T extends keyof NumberToId>(number: T): Block<T>;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据ID获得图块
|
* 根据ID获得图块
|
||||||
@ -634,7 +624,7 @@ interface Maps {
|
|||||||
* @param mapArr 地图信息
|
* @param mapArr 地图信息
|
||||||
* @param floorId 地图id
|
* @param floorId 地图id
|
||||||
*/
|
*/
|
||||||
decompressMap(mapArr?: number[][], floorId: FloorIds): number[][];
|
decompressMap(mapArr?: number[][], floorId?: FloorIds): number[][];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 将所有地图重新变成数字,以便于存档
|
* 将所有地图重新变成数字,以便于存档
|
||||||
@ -1021,7 +1011,7 @@ interface Maps {
|
|||||||
* 获得某个图块或素材的信息
|
* 获得某个图块或素材的信息
|
||||||
* @param block 图块信息,可以填图块,数字,id
|
* @param block 图块信息,可以填图块,数字,id
|
||||||
*/
|
*/
|
||||||
getBlockInfo<T extends AllNumbers>(
|
getBlockInfo<T extends keyof NumberToId>(
|
||||||
block?: Block<T> | NumberToId[T] | T
|
block?: Block<T> | NumberToId[T] | T
|
||||||
): BlockInfo<T>;
|
): BlockInfo<T>;
|
||||||
|
|
||||||
|
4
src/types/plugin.d.ts
vendored
4
src/types/plugin.d.ts
vendored
@ -207,7 +207,7 @@ interface PluginUis {
|
|||||||
readonly shopOpened: Ref<boolean>;
|
readonly shopOpened: Ref<boolean>;
|
||||||
|
|
||||||
/** ui栈 */
|
/** ui栈 */
|
||||||
readonly uiStack: Ref<Component[]>;
|
readonly uiStack: Ref<any[]>;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 显示章节
|
* 显示章节
|
||||||
@ -237,7 +237,7 @@ interface PluginUse {
|
|||||||
fn: DragFn,
|
fn: DragFn,
|
||||||
ondown?: DragFn,
|
ondown?: DragFn,
|
||||||
onUp?: (e: MouseEvent | TouchEvent) => void,
|
onUp?: (e: MouseEvent | TouchEvent) => void,
|
||||||
global: boolean = false
|
global?: boolean
|
||||||
): void;
|
): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
12
src/types/status.d.ts
vendored
12
src/types/status.d.ts
vendored
@ -591,7 +591,7 @@ interface InitGameStatus {
|
|||||||
/**
|
/**
|
||||||
* 是否开始了游戏
|
* 是否开始了游戏
|
||||||
*/
|
*/
|
||||||
played: false;
|
played: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 游戏是否结束
|
* 游戏是否结束
|
||||||
@ -648,7 +648,7 @@ interface InitGameStatus {
|
|||||||
/**
|
/**
|
||||||
* 是否锁定了用户控制
|
* 是否锁定了用户控制
|
||||||
*/
|
*/
|
||||||
lockControl: false;
|
lockControl: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 勇士移动状态,每个数字干啥的自己去libs翻,这东西太复杂了,不过应该不会有人用这个东西吧(
|
* 勇士移动状态,每个数字干啥的自己去libs翻,这东西太复杂了,不过应该不会有人用这个东西吧(
|
||||||
@ -718,7 +718,9 @@ interface InitGameStatus {
|
|||||||
/**
|
/**
|
||||||
* 全局动画对象
|
* 全局动画对象
|
||||||
*/
|
*/
|
||||||
globalAnimateObjs: Block<AllIdsOf<Exclude<AnimatableCls, 'autotile'>>>[];
|
globalAnimateObjs: Block<
|
||||||
|
IdToNumber[AllIdsOf<Exclude<AnimatableCls, 'autotile'>>]
|
||||||
|
>[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 楼层贴图
|
* 楼层贴图
|
||||||
@ -733,7 +735,7 @@ interface InitGameStatus {
|
|||||||
/**
|
/**
|
||||||
* 所有的自动元件动画
|
* 所有的自动元件动画
|
||||||
*/
|
*/
|
||||||
autotileAnimateObjs: Block<AllIdsOf<'autotile'>>[];
|
autotileAnimateObjs: Block<IdToNumber[AllIdsOf<'autotile'>]>[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 全局动画状态,每经过一个全局动画时间便加一
|
* 全局动画状态,每经过一个全局动画时间便加一
|
||||||
@ -769,7 +771,7 @@ interface InitGameStatus {
|
|||||||
* 数字转图块
|
* 数字转图块
|
||||||
*/
|
*/
|
||||||
number2block: {
|
number2block: {
|
||||||
[P in AllNumbers]: Block<P>;
|
[P in keyof NumberToId]: Block<P>;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
4
src/types/util.d.ts
vendored
4
src/types/util.d.ts
vendored
@ -843,7 +843,7 @@ type DeepRequired<T> = {
|
|||||||
* 使一个对象的所有属性可写
|
* 使一个对象的所有属性可写
|
||||||
*/
|
*/
|
||||||
type Writable<T> = {
|
type Writable<T> = {
|
||||||
-readonly [P in keyof T]: P[T];
|
-readonly [P in keyof T]: T[P];
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -889,4 +889,4 @@ type NonObjectOf<T> = SelectType<T, NonObject>;
|
|||||||
*/
|
*/
|
||||||
type EndsWith<T extends string> = `${string}${T}`;
|
type EndsWith<T extends string> = `${string}${T}`;
|
||||||
|
|
||||||
type KeyExcludesUnderline<T> = Excluede<keyof T, `_${string}`>;
|
type KeyExcludesUnderline<T> = Exclude<keyof T, `_${string}`>;
|
||||||
|
Loading…
Reference in New Issue
Block a user