mirror of
https://github.com/unanmed/HumanBreak.git
synced 2025-01-18 20:09:27 +08:00
feat: 圆角矩形接口
This commit is contained in:
parent
dbe633290e
commit
285dc2e48f
@ -1,5 +1,5 @@
|
|||||||
import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d';
|
import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d';
|
||||||
import { ERenderItemEvent, RenderItem } from '../item';
|
import { ERenderItemEvent, RenderItem, RenderItemPosition } from '../item';
|
||||||
import { Transform } from '../transform';
|
import { Transform } from '../transform';
|
||||||
import { ElementNamespace, ComponentInternalInstance } from 'vue';
|
import { ElementNamespace, ComponentInternalInstance } from 'vue';
|
||||||
import { isNil } from 'lodash-es';
|
import { isNil } from 'lodash-es';
|
||||||
@ -773,3 +773,103 @@ export class Path extends GraphicItemBase {
|
|||||||
super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
|
super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const enum RectRType {
|
||||||
|
/** 圆角为椭圆 */
|
||||||
|
Ellipse,
|
||||||
|
/** 圆角为二次贝塞尔曲线 */
|
||||||
|
Quad,
|
||||||
|
/** 圆角为三次贝塞尔曲线。该模式下,包含两个控制点,一个控制点位于上下矩形边延长线,另一个控制点位于左右矩形边延长线 */
|
||||||
|
Cubic,
|
||||||
|
/** 圆角为直线连接 */
|
||||||
|
Line
|
||||||
|
}
|
||||||
|
|
||||||
|
export class RectR extends GraphicItemBase {
|
||||||
|
/** 矩形路径 */
|
||||||
|
private path: Path2D;
|
||||||
|
|
||||||
|
/** 圆角类型 */
|
||||||
|
roundType: RectRType = RectRType.Ellipse;
|
||||||
|
/** 横向圆角半径 */
|
||||||
|
radiusX: number = 0;
|
||||||
|
/** 纵向圆角半径 */
|
||||||
|
radiusY: number = 0;
|
||||||
|
/**
|
||||||
|
* 二次贝塞尔曲线下,表示控制点的横向比例,控制点在上下矩形边与圆角的交界处为0,在左右矩形边与圆角的交界处延长线为1
|
||||||
|
* 三次贝塞尔曲线下,表示在上下矩形边延长线上的控制点的比例
|
||||||
|
*/
|
||||||
|
cpx: number = 0;
|
||||||
|
/**
|
||||||
|
* 二次贝塞尔曲线下,表示控制点的纵向比例,控制点在左右矩形边与圆角的交界处为0,在上下矩形边与圆角的交界处延长线为1
|
||||||
|
* 三次贝塞尔曲线下,表示在左右矩形边延长线上的控制点的比例
|
||||||
|
*/
|
||||||
|
cpy: number = 0;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
type: RenderItemPosition,
|
||||||
|
cache: boolean = false,
|
||||||
|
fall: boolean = false
|
||||||
|
) {
|
||||||
|
super(type, cache, fall);
|
||||||
|
|
||||||
|
const path = new Path2D();
|
||||||
|
path.rect(this.x, this.y, this.width, this.height);
|
||||||
|
this.path = path;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 更新路径
|
||||||
|
*/
|
||||||
|
private updatePath() {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置圆角半径
|
||||||
|
* @param x 横向半径
|
||||||
|
* @param y 纵向半径
|
||||||
|
*/
|
||||||
|
setRadius(x: number, y: number) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置贝塞尔曲线模式下的控制点
|
||||||
|
* @param x cpx
|
||||||
|
* @param y cpy
|
||||||
|
*/
|
||||||
|
setControl(x: number, y: number) {}
|
||||||
|
|
||||||
|
protected render(
|
||||||
|
canvas: MotaOffscreenCanvas2D,
|
||||||
|
transform: Transform
|
||||||
|
): void {
|
||||||
|
const ctx = canvas.ctx;
|
||||||
|
this.setCanvasState(canvas);
|
||||||
|
switch (this.mode) {
|
||||||
|
case GraphicMode.Fill:
|
||||||
|
ctx.fill(this.path, this.fillRule);
|
||||||
|
break;
|
||||||
|
case GraphicMode.Stroke:
|
||||||
|
ctx.stroke(this.path);
|
||||||
|
break;
|
||||||
|
case GraphicMode.FillAndStroke:
|
||||||
|
ctx.fill(this.path, this.fillRule);
|
||||||
|
ctx.stroke(this.path);
|
||||||
|
break;
|
||||||
|
case GraphicMode.StrokeAndFill:
|
||||||
|
ctx.stroke(this.path);
|
||||||
|
ctx.fill(this.path, this.fillRule);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
patchProp(
|
||||||
|
key: string,
|
||||||
|
prevValue: any,
|
||||||
|
nextValue: any,
|
||||||
|
namespace?: ElementNamespace,
|
||||||
|
parentComponent?: ComponentInternalInstance | null
|
||||||
|
): void {
|
||||||
|
switch (key) {
|
||||||
|
}
|
||||||
|
super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -26,6 +26,7 @@ import {
|
|||||||
PathProps,
|
PathProps,
|
||||||
QuadraticProps,
|
QuadraticProps,
|
||||||
RectProps,
|
RectProps,
|
||||||
|
RectRProps,
|
||||||
ShaderProps,
|
ShaderProps,
|
||||||
SpriteProps,
|
SpriteProps,
|
||||||
TextProps,
|
TextProps,
|
||||||
@ -101,6 +102,7 @@ declare module 'vue/jsx-runtime' {
|
|||||||
'g-bezier': TagDefine<BezierProps, EGraphicItemEvent>;
|
'g-bezier': TagDefine<BezierProps, EGraphicItemEvent>;
|
||||||
'g-quad': TagDefine<QuadraticProps, EGraphicItemEvent>;
|
'g-quad': TagDefine<QuadraticProps, EGraphicItemEvent>;
|
||||||
'g-path': TagDefine<PathProps, EGraphicItemEvent>;
|
'g-path': TagDefine<PathProps, EGraphicItemEvent>;
|
||||||
|
'g-rectr': TagDefine<RectRProps, EGraphicItemEvent>;
|
||||||
icon: TagDefine<IconProps, EIconEvent>;
|
icon: TagDefine<IconProps, EIconEvent>;
|
||||||
winskin: TagDefine<WinskinProps, EWinskinEvent>;
|
winskin: TagDefine<WinskinProps, EWinskinEvent>;
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,8 @@ import {
|
|||||||
Line,
|
Line,
|
||||||
Path,
|
Path,
|
||||||
QuadraticCurve,
|
QuadraticCurve,
|
||||||
Rect
|
Rect,
|
||||||
|
RectR
|
||||||
} from '../preset/graphics';
|
} from '../preset/graphics';
|
||||||
import { BaseProps } from './props';
|
import { BaseProps } from './props';
|
||||||
|
|
||||||
|
@ -153,6 +153,29 @@ export interface PathProps extends GraphicPropsBase {
|
|||||||
path?: Path2D;
|
path?: Path2D;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface RectRProps extends GraphicPropsBase {
|
||||||
|
/** 圆角半径,此参数传入时,radiusX 和 radiusY 应保持一致 */
|
||||||
|
radius: number;
|
||||||
|
/** 圆角横向半径 */
|
||||||
|
radiusX?: number;
|
||||||
|
/** 圆角纵向半径 */
|
||||||
|
radiusY?: number;
|
||||||
|
/** 圆角为线模式 */
|
||||||
|
line?: boolean;
|
||||||
|
/** 圆角为椭圆模式,默认值 */
|
||||||
|
ellipse?: boolean;
|
||||||
|
/** 圆角为二次贝塞尔曲线模式 */
|
||||||
|
quad?: boolean;
|
||||||
|
/** 圆角为三次贝塞尔曲线模式 */
|
||||||
|
cubic?: boolean;
|
||||||
|
/** 控制点,此参数传入时,cpx 和 cpy 应保持一致 */
|
||||||
|
cp?: number;
|
||||||
|
/** 横向控制点 */
|
||||||
|
cpx?: number;
|
||||||
|
/** 纵向控制点 */
|
||||||
|
cpy?: number;
|
||||||
|
}
|
||||||
|
|
||||||
export interface IconProps extends BaseProps {
|
export interface IconProps extends BaseProps {
|
||||||
icon: AllNumbers;
|
icon: AllNumbers;
|
||||||
frame: number;
|
frame: number;
|
||||||
|
Loading…
Reference in New Issue
Block a user