Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add referenceResolutionPerUnit and fix hierarchy dirty bug #37

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
105 commits
Select commit Hold shift + click to select a range
2df50f9
feat: ui transform
cptbtptpbcptdtptp Jun 12, 2024
cf0643d
feat: update code
cptbtptpbcptdtptp Jun 17, 2024
22582e1
feat: merge code
cptbtptpbcptdtptp Jun 20, 2024
cdecbc5
feat: udpae code
cptbtptpbcptdtptp Jun 20, 2024
d3599b2
feat: update code
cptbtptpbcptdtptp Jun 20, 2024
9ed8451
feat: merge transform and uitransform
cptbtptpbcptdtptp Jun 26, 2024
ed65e2a
fix: merge code
cptbtptpbcptdtptp Aug 28, 2024
a04790f
fix: merge code
cptbtptpbcptdtptp Aug 28, 2024
ef86b49
feat: update code
cptbtptpbcptdtptp Aug 29, 2024
9a883be
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Aug 30, 2024
0866129
feat: update ui input
cptbtptpbcptdtptp Sep 9, 2024
ff4bdb1
feat: update code
cptbtptpbcptdtptp Sep 19, 2024
75e4c83
feat: ui pointer event
cptbtptpbcptdtptp Sep 25, 2024
e87b7cd
feat: udpate code
cptbtptpbcptdtptp Oct 7, 2024
cc001f1
feat: merge code
cptbtptpbcptdtptp Oct 7, 2024
eea964a
feat: update code
cptbtptpbcptdtptp Oct 10, 2024
05f11da
feat: udpate code
cptbtptpbcptdtptp Oct 10, 2024
6c6be60
feat: udpate code
cptbtptpbcptdtptp Oct 10, 2024
c6cbdee
feat: update code
cptbtptpbcptdtptp Oct 10, 2024
8e70ce9
feat: update code
cptbtptpbcptdtptp Oct 10, 2024
c12b295
feat: update code
cptbtptpbcptdtptp Oct 11, 2024
9d90de5
feat: update code
cptbtptpbcptdtptp Oct 12, 2024
7abc773
feat: update code
cptbtptpbcptdtptp Oct 12, 2024
5c3c47d
feat: update code
cptbtptpbcptdtptp Oct 14, 2024
7f77234
feat: update code
cptbtptpbcptdtptp Oct 14, 2024
48f735c
feat: update code
cptbtptpbcptdtptp Oct 17, 2024
7aa2657
feat: update code
cptbtptpbcptdtptp Oct 20, 2024
0e36499
feat: update code
cptbtptpbcptdtptp Oct 21, 2024
f2158fc
feat: update code
cptbtptpbcptdtptp Oct 22, 2024
685e450
feat: update code
cptbtptpbcptdtptp Oct 22, 2024
45deb33
feat: update code
cptbtptpbcptdtptp Oct 22, 2024
fcb0994
feat: update code
cptbtptpbcptdtptp Oct 22, 2024
b30b2ee
feat: update code
cptbtptpbcptdtptp Oct 22, 2024
85a15fe
feat: merge code
cptbtptpbcptdtptp Oct 23, 2024
af4135d
feat: update code
cptbtptpbcptdtptp Oct 24, 2024
b61b9e7
feat: update code
cptbtptpbcptdtptp Oct 24, 2024
bb145d4
feat: update localbounds
cptbtptpbcptdtptp Oct 24, 2024
74de716
feat: update code
cptbtptpbcptdtptp Oct 27, 2024
49cc82a
feat: merge code
cptbtptpbcptdtptp Oct 27, 2024
c808352
feat: merge code
cptbtptpbcptdtptp Oct 27, 2024
c3c5568
feat: update code
cptbtptpbcptdtptp Oct 29, 2024
b154e57
feat: update ui code
cptbtptpbcptdtptp Nov 1, 2024
951b1a0
feat: udpate code
cptbtptpbcptdtptp Nov 4, 2024
4d930f2
feat: add button
cptbtptpbcptdtptp Nov 5, 2024
72be260
feat: add button
cptbtptpbcptdtptp Nov 5, 2024
c60fa0a
feat: update code
cptbtptpbcptdtptp Nov 5, 2024
f7ffd30
feat: update code
cptbtptpbcptdtptp Nov 5, 2024
7f25dc3
feat: update code
cptbtptpbcptdtptp Nov 6, 2024
c37bee4
feat: merge code
cptbtptpbcptdtptp Nov 6, 2024
a7249b3
feat: update code
cptbtptpbcptdtptp Nov 7, 2024
396656c
feat: update code
cptbtptpbcptdtptp Nov 7, 2024
5fea91f
feat: update code
cptbtptpbcptdtptp Nov 7, 2024
4e66663
feat: update code
cptbtptpbcptdtptp Nov 7, 2024
48d783d
feat: update code
cptbtptpbcptdtptp Nov 7, 2024
3b90739
feat: update code
cptbtptpbcptdtptp Nov 13, 2024
c0cf05a
feat: update code
cptbtptpbcptdtptp Nov 13, 2024
e68d510
feat: update code
cptbtptpbcptdtptp Nov 14, 2024
b385900
feat: update code
cptbtptpbcptdtptp Nov 18, 2024
7ba272c
feat: update code
cptbtptpbcptdtptp Nov 18, 2024
a09efd5
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
0a0155d
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
e12ff0b
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
3bd87bd
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
2860723
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
1eab47c
fix: lint error
cptbtptpbcptdtptp Nov 20, 2024
a7b232e
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 4, 2024
7bc504a
fix: udpate ui transform init
cptbtptpbcptdtptp Dec 5, 2024
dea19ce
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 6, 2024
8b8dab9
Merge branch 'feature/ui-init' of https://github.com/singlecoder/engi…
cptbtptpbcptdtptp Dec 12, 2024
0b3218d
feat: update code
cptbtptpbcptdtptp Dec 12, 2024
eb28c10
feat: update code
cptbtptpbcptdtptp Dec 13, 2024
7407f3e
feat: update code
cptbtptpbcptdtptp Dec 16, 2024
59782d3
feat: udpate code
cptbtptpbcptdtptp Dec 16, 2024
9f71641
feat: udpate code
cptbtptpbcptdtptp Dec 16, 2024
4d6b453
feat: update code
cptbtptpbcptdtptp Dec 16, 2024
d552ee8
feat: update code
cptbtptpbcptdtptp Dec 17, 2024
ae510a2
feat: merge code
cptbtptpbcptdtptp Dec 17, 2024
432c465
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 17, 2024
8ece555
feat: update code
cptbtptpbcptdtptp Dec 18, 2024
1eb88b5
feat: merge code
cptbtptpbcptdtptp Dec 18, 2024
1caa84d
feat: udpate code
cptbtptpbcptdtptp Dec 18, 2024
8527942
feat: update code
cptbtptpbcptdtptp Dec 19, 2024
4d3ae40
feat: update code
cptbtptpbcptdtptp Dec 23, 2024
7fb40e8
fix: merge code
cptbtptpbcptdtptp Dec 23, 2024
29446a9
feat: merge code
cptbtptpbcptdtptp Dec 24, 2024
6570a06
feat: merge code
cptbtptpbcptdtptp Dec 24, 2024
25e165d
feat: udpate code
cptbtptpbcptdtptp Dec 24, 2024
9254641
feat: udpate code
cptbtptpbcptdtptp Dec 24, 2024
1556d94
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 24, 2024
73662a9
feat: udpate code
cptbtptpbcptdtptp Dec 25, 2024
f85da64
feat: udpate code
cptbtptpbcptdtptp Dec 25, 2024
fcc7813
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 25, 2024
7137967
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 30, 2024
a31cd4e
feat: udpate code
cptbtptpbcptdtptp Dec 30, 2024
d4ce2dd
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 31, 2024
1ee2cc4
feat: udpate code
cptbtptpbcptdtptp Dec 31, 2024
026b219
feat: udpate code
cptbtptpbcptdtptp Dec 31, 2024
1719b32
feat: udpate code
cptbtptpbcptdtptp Dec 31, 2024
9de9ea5
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 31, 2024
0cf2a1f
feat: update code
cptbtptpbcptdtptp Dec 31, 2024
e465050
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Dec 31, 2024
88d73f3
feat: update code
cptbtptpbcptdtptp Dec 31, 2024
63ac486
Merge remote-tracking branch 'ck/feature/ui-init' into feature/ui-init
cptbtptpbcptdtptp Jan 2, 2025
99ad181
feat: update code
cptbtptpbcptdtptp Jan 2, 2025
5f1221d
feat: update code
cptbtptpbcptdtptp Jan 2, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion packages/core/src/2d/assembler/ISpriteAssembler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@ export interface ISpriteAssembler {
height: number,
pivot: Vector2,
flipX?: boolean,
flipY?: boolean
flipY?: boolean,
referenceResolutionPerUnit?: number
): void;
updateUVs(renderer: ISpriteRenderer): void;
updateColor(renderer: ISpriteRenderer, alpha?: number): void;
Expand Down
8 changes: 5 additions & 3 deletions packages/core/src/2d/assembler/SlicedSpriteAssembler.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { Matrix, Vector2 } from "@galacean/engine-math";
import { Engine } from "../../Engine";
import { StaticInterfaceImplement } from "../../base/StaticInterfaceImplement";
import { ISpriteAssembler } from "./ISpriteAssembler";
import { ISpriteRenderer } from "./ISpriteRenderer";
Expand Down Expand Up @@ -32,16 +33,17 @@ export class SlicedSpriteAssembler {
height: number,
pivot: Vector2,
flipX: boolean = false,
flipY: boolean = false
flipY: boolean = false,
referenceResolutionPerUnit: number = 1
): void {
const { sprite } = renderer;
const { border } = sprite;
// Update local positions.
const spritePositions = sprite._getPositions();
const { x: left, y: bottom } = spritePositions[0];
const { x: right, y: top } = spritePositions[3];
const expectWidth = sprite.width;
const expectHeight = sprite.height;
const expectWidth = sprite.width * referenceResolutionPerUnit;
const expectHeight = sprite.height * referenceResolutionPerUnit;
const fixedLeft = expectWidth * border.x;
const fixedBottom = expectHeight * border.y;
const fixedRight = expectWidth * border.z;
Expand Down
12 changes: 7 additions & 5 deletions packages/core/src/2d/assembler/TiledSpriteAssembler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,13 +39,14 @@ export class TiledSpriteAssembler {
height: number,
pivot: Vector2,
flipX: boolean = false,
flipY: boolean = false
flipY: boolean = false,
referenceResolutionPerUnit: number = 1
): void {
// Calculate row and column
const { _posRow: rPos, _posColumn: cPos, _uvRow: rUV, _uvColumn: cUV } = TiledSpriteAssembler;
TiledSpriteAssembler.resetData(
renderer,
TiledSpriteAssembler._calculateDividing(renderer, width, height, rPos, cPos, rUV, cUV)
TiledSpriteAssembler._calculateDividing(renderer, width, height, rPos, cPos, rUV, cUV, referenceResolutionPerUnit)
);
// Update renderer's worldMatrix
const { x: pivotX, y: pivotY } = pivot;
Expand Down Expand Up @@ -172,7 +173,8 @@ export class TiledSpriteAssembler {
rPos: DisorderedArray<number>,
cPos: DisorderedArray<number>,
rUV: DisorderedArray<number>,
cUV: DisorderedArray<number>
cUV: DisorderedArray<number>,
referenceResolutionPerUnit: number
): number {
rPos.length = cPos.length = rUV.length = cUV.length = 0;
const { sprite, tiledAdaptiveThreshold: threshold } = renderer;
Expand All @@ -181,8 +183,8 @@ export class TiledSpriteAssembler {
const { x: left, y: bottom } = spritePositions[0];
const { x: right, y: top } = spritePositions[3];
const [spriteUV0, spriteUV1, spriteUV2, spriteUV3] = sprite._getUVs();
const expectWidth = sprite.width;
const expectHeight = sprite.height;
const expectWidth = sprite.width * referenceResolutionPerUnit;
const expectHeight = sprite.height * referenceResolutionPerUnit;
const fixedL = expectWidth * border.x;
const fixedR = expectWidth * border.z;
const fixedLR = fixedL + fixedR;
Expand Down
21 changes: 19 additions & 2 deletions packages/ui/src/component/UICanvas.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ import { UIInteractive } from "./interactive/UIInteractive";
@dependentComponents(UITransform, DependentMode.AutoAdd)
export class UICanvas extends Component implements IElement {
/** @internal */
static _hierarchyCounter: number = 1;
private static _tempGroupAbleList: IGroupAble[] = [];

/** @internal */
Expand Down Expand Up @@ -79,10 +80,25 @@ export class UICanvas extends Component implements IElement {
@ignoreClone
private _distance: number = 10;
@deepClone
private _referenceResolution: Vector2 = new Vector2(8, 6);
private _referenceResolution: Vector2 = new Vector2(800, 600);
@deepClone
private _referenceResolutionPerUnit: number = 100;
@ignoreClone
private _hierarchyVersion: number = -1;

/**
* The conversion ratio between reference resolution and unit for UI elements in this canvas.
*/
get referenceResolutionPerUnit(): number {
return this._referenceResolutionPerUnit;
}

set referenceResolutionPerUnit(value: number) {
if (this._referenceResolutionPerUnit !== value) {
this._referenceResolutionPerUnit = value;
}
}

/**
* The reference resolution of the UI canvas in `ScreenSpaceCamera` and `ScreenSpaceOverlay` mode.
*/
Expand Down Expand Up @@ -332,6 +348,7 @@ export class UICanvas extends Component implements IElement {
renderers.length = this._walk(this.entity, renderers);
UICanvas._tempGroupAbleList.length = 0;
this._hierarchyVersion = uiHierarchyVersion;
++UICanvas._hierarchyCounter;
}
return renderers;
}
Expand Down Expand Up @@ -521,7 +538,7 @@ export class UICanvas extends Component implements IElement {
this._updateCameraObserver();
this._setRealRenderMode(this._getRealRenderMode());
if (isRootCanvas) {
this.entity._updateUIHierarchyVersion(this.engine.time.frameCount);
this.entity._updateUIHierarchyVersion(UICanvas._hierarchyCounter);
} else {
const { _disorderedElements: disorderedElements } = this;
disorderedElements.forEach((element: IElement) => {
Expand Down
8 changes: 6 additions & 2 deletions packages/ui/src/component/UIRenderer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import {
ShaderProperty,
Vector3,
Vector4,
assignmentClone,
deepClone,
dependentComponents,
ignoreClone
Expand Down Expand Up @@ -77,6 +78,8 @@ export class UIRenderer extends Renderer implements IGraphics {
protected _alpha: number = 1;
@deepClone
protected _color: Color = new Color(1, 1, 1, 1);
@assignmentClone
protected _referenceResolutionPerUnit: number = 100;

/**
* Rendering color for the ui renderer.
Expand Down Expand Up @@ -154,7 +157,7 @@ export class UIRenderer extends Renderer implements IGraphics {
override _onEnableInScene(): void {
// @ts-ignore
this._overrideUpdate && this.scene._componentsManager.addOnUpdateRenderers(this);
this.entity._updateUIHierarchyVersion(this.engine.time.frameCount);
this.entity._updateUIHierarchyVersion(UICanvas._hierarchyCounter);
Utils.setRootCanvasDirty(this);
Utils.setGroupDirty(this);
}
Expand All @@ -163,6 +166,7 @@ export class UIRenderer extends Renderer implements IGraphics {
override _onDisableInScene(): void {
// @ts-ignore
this._overrideUpdate && this.scene._componentsManager.removeOnUpdateRenderers(this);
this.entity._updateUIHierarchyVersion(UICanvas._hierarchyCounter);
Utils.cleanRootCanvas(this);
Utils.cleanGroup(this);
}
Expand Down Expand Up @@ -205,7 +209,7 @@ export class UIRenderer extends Renderer implements IGraphics {
Utils.setRootCanvasDirty(this);
Utils.setGroupDirty(this);
case EntityModifyFlags.SiblingIndex:
entity._updateUIHierarchyVersion(this.engine.time.frameCount);
entity._updateUIHierarchyVersion(UICanvas._hierarchyCounter);
break;
default:
break;
Expand Down
2 changes: 1 addition & 1 deletion packages/ui/src/component/UITransform.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { Entity, Transform, Vector2, deepClone, ignoreClone } from "@galacean/en
*/
export class UITransform extends Transform {
@deepClone
private _size: Vector2 = new Vector2(1, 1);
private _size: Vector2 = new Vector2(100, 100);
@deepClone
private _pivot: Vector2 = new Vector2(0.5, 0.5);

Expand Down
18 changes: 16 additions & 2 deletions packages/ui/src/component/advanced/Image.ts
Original file line number Diff line number Diff line change
Expand Up @@ -174,9 +174,24 @@ export class Image extends UIRenderer implements ISpriteRenderer {
}

let { _dirtyUpdateFlag: dirtyUpdateFlag } = this;
const canvas = this._getRootCanvas();
if (this._referenceResolutionPerUnit !== canvas.referenceResolutionPerUnit) {
this._referenceResolutionPerUnit = canvas.referenceResolutionPerUnit;
dirtyUpdateFlag |= ImageUpdateFlags.Position;
}

// Update position
if (dirtyUpdateFlag & ImageUpdateFlags.Position) {
this._assembler.updatePositions(this, transform.worldMatrix, width, height, transform.pivot);
this._assembler.updatePositions(
this,
transform.worldMatrix,
width,
height,
transform.pivot,
false,
false,
this._referenceResolutionPerUnit
);
dirtyUpdateFlag &= ~ImageUpdateFlags.Position;
}

Expand All @@ -195,7 +210,6 @@ export class Image extends UIRenderer implements ISpriteRenderer {
this._dirtyUpdateFlag = dirtyUpdateFlag;
// Init sub render element.
const { engine } = context.camera;
const canvas = this._getRootCanvas();
const subRenderElement = engine._subRenderElementPool.get();
const subChunk = this._subChunk;
subRenderElement.set(this, material, subChunk.chunk.primitive, subChunk.subMesh, this.sprite.texture, subChunk);
Expand Down
28 changes: 18 additions & 10 deletions packages/ui/src/component/advanced/Label.ts
Original file line number Diff line number Diff line change
Expand Up @@ -306,9 +306,14 @@ export class Label extends UIRenderer implements ITextRenderer {
this._setDirtyFlagFalse(DirtyFlag.SubFont);
}

const canvas = this._getRootCanvas();
if (this._referenceResolutionPerUnit !== canvas.referenceResolutionPerUnit) {
this._referenceResolutionPerUnit = canvas.referenceResolutionPerUnit;
this._setDirtyFlagTrue(DirtyFlag.LocalPositionBounds);
}

if (this._isContainDirtyFlag(DirtyFlag.LocalPositionBounds)) {
this._updateLocalData();
this._setDirtyFlagFalse(DirtyFlag.LocalPositionBounds);
}

if (this._isContainDirtyFlag(DirtyFlag.WorldPosition)) {
Expand All @@ -324,7 +329,6 @@ export class Label extends UIRenderer implements ITextRenderer {
const engine = context.camera.engine;
const textSubRenderElementPool = engine._textSubRenderElementPool;
const material = this.getMaterial();
const canvas = this._getRootCanvas();
const renderElement = canvas._renderElement;
const textChunks = this._textChunks;
const isOverlay = canvas._realRenderMode === CanvasRenderMode.ScreenSpaceOverlay;
Expand Down Expand Up @@ -416,7 +420,7 @@ export class Label extends UIRenderer implements ITextRenderer {

private _updateLocalData(): void {
// @ts-ignore
const pixelsPerUnit = Engine._pixelsPerUnit;
const pixelsPerResolution = Engine._pixelsPerUnit / this._referenceResolutionPerUnit;
const { min, max } = this._localBounds;
const charRenderInfos = Label._charRenderInfos;
const charFont = this._getSubFont();
Expand All @@ -428,11 +432,15 @@ export class Label extends UIRenderer implements ITextRenderer {
const textMetrics = this.enableWrapping
? TextUtils.measureTextWithWrap(
this,
rendererWidth * pixelsPerUnit,
rendererHeight * pixelsPerUnit,
this._lineSpacing * pixelsPerUnit
rendererWidth * pixelsPerResolution,
rendererHeight * pixelsPerResolution,
this._lineSpacing * pixelsPerResolution
)
: TextUtils.measureTextWithoutWrap(this, rendererHeight * pixelsPerUnit, this._lineSpacing * pixelsPerUnit);
: TextUtils.measureTextWithoutWrap(
this,
rendererHeight * pixelsPerResolution,
this._lineSpacing * pixelsPerResolution
);
const { height, lines, lineWidths, lineHeight, lineMaxSizes } = textMetrics;
// @ts-ignore
const charRenderInfoPool = this.engine._charRenderInfoPool;
Expand All @@ -441,9 +449,9 @@ export class Label extends UIRenderer implements ITextRenderer {

if (linesLen > 0) {
const { horizontalAlignment } = this;
const pixelsPerUnitReciprocal = 1.0 / pixelsPerUnit;
rendererWidth *= pixelsPerUnit;
rendererHeight *= pixelsPerUnit;
const pixelsPerUnitReciprocal = 1.0 / pixelsPerResolution;
rendererWidth *= pixelsPerResolution;
rendererHeight *= pixelsPerResolution;
const halfRendererWidth = rendererWidth * 0.5;
const halfLineHeight = lineHeight * 0.5;

Expand Down
8 changes: 4 additions & 4 deletions packages/ui/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,17 +15,17 @@ import {
import uiDefaultFs from "./shader/uiDefault.fs.glsl";
import uiDefaultVs from "./shader/uiDefault.vs.glsl";

export { UICanvas } from "./component/UICanvas";
export { UIGroup } from "./component/UIGroup";
export { UIRenderer } from "./component/UIRenderer";
export { UITransform } from "./component/UITransform";
export { Button } from "./component/advanced/Button";
export { Image } from "./component/advanced/Image";
export { Label } from "./component/advanced/Label";
export { ColorTransition } from "./component/interactive/transition/ColorTransition";
export { ScaleTransition } from "./component/interactive/transition/ScaleTransition";
export { SpriteTransition } from "./component/interactive/transition/SpriteTransition";
export { Transition } from "./component/interactive/transition/Transition";
export { UICanvas } from "./component/UICanvas";
export { UIGroup } from "./component/UIGroup";
export { UIRenderer } from "./component/UIRenderer";
export { UITransform } from "./component/UITransform";
export { CanvasRenderMode } from "./enums/CanvasRenderMode";
export { ResolutionAdaptationStrategy } from "./enums/ResolutionAdaptationStrategy";
export { UIPointerEventEmitter } from "./input/UIPointerEventEmitter";
Expand Down
Loading