-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
fix submeshes have different instancing options #12786
Conversation
Interface Check Report! WARNING this pull request has changed these public interfaces:
@@ -6669,13 +6669,8 @@
* @param ev100
*/
protected setExposure(ev100: any): void;
}
- export interface IInstancedAttributeBlock {
- buffer: Uint8Array;
- views: __private._types_globals__TypedArray[];
- attributes: gfx.Attribute[];
- }
export enum ModelType {
DEFAULT = 0,
SKINNING = 1,
BAKED_SKINNING = 2,
@@ -6731,13 +6726,8 @@
* @zh 获取上次更新时间戳
*/
get updateStamp(): number;
/**
- * @en Whether GPU instancing is enabled for the current model
- * @zh 是否开启实例化渲染
- */
- get isInstancingEnabled(): boolean;
- /**
* @en Model level shadow bias
* @zh 阴影偏移值
*/
get shadowBias(): number;
@@ -6808,13 +6798,8 @@
* @zh 是否动态合批
*/
isDynamicBatching: boolean;
/**
- * @en The instance attributes
- * @zh 实例化属性
- */
- instancedAttributes: IInstancedAttributeBlock;
- /**
* @en The world axis-aligned bounding box
* @zh 世界空间包围盒
*/
protected _worldBounds: geometry.AABB | null;
@@ -7027,15 +7012,19 @@
* @param subModelIndex sub model's index
*/
getMacroPatches(subModelIndex: number): IMacroPatch[] | null;
protected _updateAttributesAndBinding(subModelIndex: number): void;
- protected _getInstancedAttributeIndex(name: string): number;
- protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: Pass): void;
+ protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: SubModel): void;
protected _initLocalDescriptors(subModelIndex: number): void;
protected _initWorldBoundDescriptors(subModelIndex: number): void;
protected _updateLocalDescriptors(subModelIndex: number, descriptorSet: gfx.DescriptorSet): void;
protected _updateWorldBoundDescriptors(subModelIndex: number, descriptorSet: gfx.DescriptorSet): void;
}
+ export interface IInstancedAttributeBlock {
+ buffer: Uint8Array;
+ views: __private._types_globals__TypedArray[];
+ attributes: gfx.Attribute[];
+ }
/**
* @en A sub part of the model, it describes how to render a specific sub mesh.
* It contains geometry information in [[RenderingSubMesh]] and all sort of rendering configuration like shaders, macro patches, passes etc.
* @zh 组成模型对象的子模型,它用来描述如何渲染模型的一个子网格。
@@ -7054,8 +7043,10 @@
protected _planarInstanceShader: gfx.Shader | null;
protected _planarShader: gfx.Shader | null;
protected _reflectionTex: gfx.Texture | null;
protected _reflectionSampler: gfx.Sampler | null;
+ protected _instancedAttributeBlock: IInstancedAttributeBlock;
+ protected _instancedWorldMatrixIndex: number;
/**
* @en
* sub model's passes
* @zh
@@ -7115,8 +7106,19 @@
* @zh 用于渲染平面阴影的着色器。
*/
get planarShader(): gfx.Shader | null;
/**
+ * @en The instance attribute block, access by sub model
+ * @zh 硬件实例化属性,通过子模型访问
+ */
+ get instancedAttributeBlock(): IInstancedAttributeBlock;
+ /**
+ * @en Get or set instance matrix id, access by sub model
+ * @zh 获取或者设置硬件实例化中的矩阵索引,通过子模型访问
+ */
+ set instancedWorldMatrixIndex(val: number);
+ get instancedWorldMatrixIndex(): number;
+ /**
* @en
* init sub model
* @zh
* 子模型初始化
@@ -7172,8 +7174,38 @@
* @zh
* 几何数据改变后的回调
*/
onGeometryChanged(): void;
+ /**
+ * @en
+ * get instanced attribute index
+ * @zh
+ * 获取硬件实例化相关索引
+ */
+ /**
+ * @internal
+ */
+ getInstancedAttributeIndex(name: string): number;
+ /**
+ * @en
+ * update instancing related data, invoked by model
+ * @zh
+ * 更新硬件实例化相关数据,一般由model调用
+ */
+ /**
+ * @internal
+ */
+ updateInstancedWorldMatrix(mat: math.Mat4, idx: number): void;
+ /**
+ * @en
+ * update instancing related data, invoked by model
+ * @zh
+ * 更新硬件实例化相关数据,一般由model调用
+ */
+ /**
+ * @internal
+ */
+ UpdateInstancedAttributes(attributes: gfx.Attribute[]): void;
protected _flushPassInfo(): void;
}
/**
* @en Ambient lighting representation in the render scene.
@@ -22350,9 +22382,9 @@
hasPendingModels: boolean;
dynamicOffsets: number[];
constructor(pass: renderer.Pass);
destroy(): void;
- merge(subModel: renderer.scene.SubModel, attrs: renderer.scene.IInstancedAttributeBlock, passIdx: number, shaderImplant?: gfx.Shader | null): void;
+ merge(subModel: renderer.scene.SubModel, passIdx: number, shaderImplant?: gfx.Shader | null): void;
uploadBuffers(cmdBuff: gfx.CommandBuffer): void;
clear(): void;
}
export class PipelineStateManager {
@@ -52094,9 +52126,9 @@
/**
* @deprecated since v3.5.0, this is an engine private interface that will be removed in the future.
*/
_updateLocalDescriptors(submodelIdx: number, descriptorSet: gfx.DescriptorSet): void;
- protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: renderer.Pass): void;
+ protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: renderer.scene.SubModel): void;
}
export interface _cocos_3d_skeletal_animation_skeletal_animation_utils__IInternalJointAnimInfo {
downstream?: math.Mat4;
curveData?: math.Mat4[];
@@ -52142,9 +52174,9 @@
*/
uploadAnimation(anim: AnimationClip | null): void;
protected _applyJointTexture(texture?: _cocos_3d_skeletal_animation_skeletal_animation_utils__IJointTextureHandle | null): void;
protected _updateLocalDescriptors(submodelIdx: number, descriptorSet: gfx.DescriptorSet): void;
- protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: renderer.Pass): void;
+ protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: renderer.scene.SubModel): void;
}
/**
* 动画使用的循环模式。
*/
|
@cocos-robot run test cases |
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
* The modification of instanced synchronize data to native * fix instanced error
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
for (const p of passes) { | ||
if (p.phase !== this._currentQueue.phaseID) continue; | ||
const batchingScheme = p.batchingScheme; | ||
// If the size of instances is not 0, it has been added | ||
if (batchingScheme === BatchingSchemes.INSTANCING | ||
&& !this._submitInfo.instances.size) { | ||
const instancedBuffer = p.getInstancedBuffer(); | ||
instancedBuffer.merge(submodel, ro.model.instancedAttributes, passes.indexOf(p)); | ||
instancedBuffer.merge(subModel, ro.model.getInstancedAttributeBlock(subModel), passes.indexOf(p)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this get function is named as same as native engine
@jk20012001, Please check the result of
Task Details
|
@@ -50,15 +50,16 @@ void InstancedBuffer::destroy() { | |||
_instances.clear(); | |||
} | |||
|
|||
void InstancedBuffer::merge(const scene::Model *model, const scene::SubModel *subModel, uint32_t passIdx) { | |||
merge(model, subModel, passIdx, nullptr); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
arguments are modified as same as ts engine
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
let hasNonInstancingPass = false; | ||
for (let i = 0; i < this._subModels.length; i++) { | ||
const subModel = this._subModels[i]; | ||
const idx = this._instAnimInfoIdx; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure if define variable outside for loop is better in ts.
@jk20012001, Please check the result of
Task Details
|
++i; | ||
const auto &subModels = model->getSubModels(); | ||
const auto subModelCount = subModels.size(); | ||
for (uint32_t subModelIdx = 0; subModelIdx < subModelCount; ++subModelIdx) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can use for in like
for (const auto &subModel : subModels) {
}
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
@jk20012001, Please check the result of
Task Details
|
* when checking useSystemFont, the fontFamily should appear (#12684) Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com> * remove rebundant useLocalData (#12640) (cherry picked from commit 7cca981) Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com> * Modify version number (#12726) Co-authored-by: liuyi <liuyi@cocos.com> * fix builtin asset hot-reload (#12736) * improve: move xr init to infrastructure (#12765) * improve: move xr init to infrastructure * fix: move initxr, before gfx * fix: format warning * [Feature] build template add config file (#12701) * part of build template add config json for creating build templates and version checks for each platform * update default template version * add RenderQueue custom ability to classic pipeline (#12760) * Wgpu 3.6.2 WGPU_CI_ON (#12731) * fix okhttp onClosing not call close (#12783) * fix transparency, emissive and specularfactor with dcc effects (#12798) * reverse occlusion parameter in effects (#12795) * [native] Fix getting wrong value of globals.ambient.skyLightingColor (#12810) * refine: remove unneeded code (#12808) * feat: update meta files (#12807) * middleware2d components rendering in native mode (#12788) * middleware2d components rendering in native mode * support spine/dragonbones set enable batch * support spine rendering in batching mode * get batcher2d instance from root * process about with type conversion * fix some code style * use material hash to merge draw batch * deal with fill z * fix dragonbones fill z * remove some code no used any more * refactoring some code * modify some code * add free memory * fix clang-tidy * delete mesh-buffer-layout in destructor * byte alignment * [ci skip][AUTO]: Automated code generating update: 88c3a7f (#12788) (#12818) Co-authored-by: cocos-robot <cocos-robot@cocos.com> * simplify (#12782) * [code] move decode32 to unpack.chunk (#12823) * [Optimize] Cache current time for audio player in minigame. (#12814) * Cache current time for minigames * Save current time as private member * Make cache time changed in callback * update cache time to abort middle state for seek * LogRemote upgrade configuration protocol (#12833) * update config * Update LogRemote.cpp * update default_skybox and sun direction (#12811) * fix submeshes have different instancing options (#12786) * [ci skip][AUTO]: Automated code generating update: 3200403 (#12786) (#12871) Co-authored-by: cocos-robot <cocos-robot@cocos.com> * spine/dragonbones support batch mode in web platform (#12847) * spine/dragonbones support batch mode in web platform * set data hash 0 in commitMiddleware * optimizate merge draw batch for middleware * keep commitIA in batcher2d * modify deprecated about commitIA * feat: support webgpu on build-engine (#12627) * feat: support webgpu * build-engine-feat: support building external asset * update * Publish @cocos/build-engine@4.4.0-webgpu.0 * fix tiled merge draw call with sprite (#12877) * fix:CC_ASSERT(!_currentApp.expired()); (#12844) application has destroyed when WebSocketServer process callback in game thread * [Bug fix] remove the player of the audio source when its clip is set to null (#12865) * remove player when the audio source's clip is set to null * fix binary format spine load crash (#12894) * wgpu: remove reinit on same object (#12799) * add i18n for skybox (#12899) * 3.6.2 fix android orientation crash (#12885) * do not cache argument in global space * add doc * add a comment for readAttachment (#12902) * If it is preview, replace overrideUuid directly (#12905) * sort the attributes (#12904) Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com> * add i18n for shadow (#12906) * update default-skybox and sun direction (#12917) * fix:WebSocket connection to 'ws://XXXX/' failed: A server must not mask any frames that it sends to the client. (#12882) * remove USE_BATCHING (#12892) * fix a native middleware blend problem (#12914) * migrated remove USE_BATCHING (#12895) * [feature] support output bullet.wasm on runtime based platform which the using of wasm api is more similar with weixin (#12881) * V3.6.2 fix particle crash (#12913) * fix native crash * revert to pointer * revert * do not use reference * if PREVIEW load cce scripts before loadProjectBundles (#12916) * If it is preview, replace overrideUuid directly * load cce scripts before loadProjectBundles * Update game.ts * Update game.ts * Update game.ts * Update game.ts * fix download url request not encode space (#12826) * Export texture info for wgpu WGPU_CI_ON (#12926) * export texture info for wgpu * missing js file * update external config Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com.com> * fix: build-engine (#12929) * richtext addChild optimization (#12928) * 1. remove rebundant invoking 2. ttf canvas texture resizes to width and height as (1,1) * remove start() and move it to onLoad() Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com> * fix animation asset on inspector preview bug (#12900) * optimize label component editing * fix animation asset on inspector preview bug * optimize i18n break words * update node-executable by env (#12930) * Fix: toDataURL is not supported for this content on iPhone 7p (#12830) * Fix: toDataURL is not supported for this content on iPhone 7p * Add srgb transform. (#12873) * add localCfg.cmake (#12932) * _loadCCEScripts will be browser-preview only (#12925) * _loadCCEScripts will be browser-preview only * add comment * a compatible way of data copy & default buffer size for uniform buffer (#12935) * a compatible way of data copy & default buffer size for uniform buffer * update external config * [fix] default scene ambient and dirlight color (#12955) * sync readme for wgpu (#12966) * [fix] specularIntensity is invalid with builtin-standard (#12971) * [native] type2writer:add FLOAT3 to Color case for compatiblity (#12962) * V3.6.2 format return null error fix (#12973) * add i18n for model (#12985) * fix potential mem leak (#12995) * [fix] camera clear flag is skybox but skybox is disabled #13589 (#12964) * [fix] shader compilation error with CC_DEVICE_SUPPORT_FLOAT_TEXTURE=0 (#13015) * fix import * sync tojs to swig about middleware and 2d module (#4) * sync tojs to swig about scene module (#5) * remove Model::getInstancedAttributeBlock Co-authored-by: Zhang mingzhen <32831993+Zhmz@users.noreply.github.com> Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com> Co-authored-by: LIUYIa <102024185+LIUYIa@users.noreply.github.com> Co-authored-by: liuyi <liuyi@cocos.com> Co-authored-by: fqamic <fqamic@vip.qq.com> Co-authored-by: minggo <nudtzxm@gmail.com> Co-authored-by: changhua <39176194+changhua0118@users.noreply.github.com> Co-authored-by: hyde zhou <zlzhou.sh@outlook.com> Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com> Co-authored-by: mmyduckx <308303735@qq.com> Co-authored-by: 徐兵 <49358166+xubing0906@users.noreply.github.com> Co-authored-by: James Chen <dumganhar@gmail.com> Co-authored-by: bofeng-song <bofeng.song@chukong-inc.com> Co-authored-by: 袁炜海 <35713518+dogodo-cc@users.noreply.github.com> Co-authored-by: zhakesi <liqiao@cocos.com> Co-authored-by: Cocos Robot <48829427+cocos-robot@users.noreply.github.com> Co-authored-by: cocos-robot <cocos-robot@cocos.com> Co-authored-by: 江战 <40414978+PatriceJiang@users.noreply.github.com> Co-authored-by: jk20012001 <jkregister@163.com> Co-authored-by: timlyeee <43355299+timlyeee@users.noreply.github.com> Co-authored-by: PP <chinese1236@qq.com> Co-authored-by: oahc09 <oahc09@gmail.com> Co-authored-by: zhangxin <59186205+chichinohaha@users.noreply.github.com> Co-authored-by: troublemaker52025 <troublemaker52025@outlook.com> Co-authored-by: CC9701 <73738313+CC9701@users.noreply.github.com> Co-authored-by: zxx43 <zxx43@hotmail.com> Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com.com> Co-authored-by: 黄森斌 <arsen2010@126.com> Co-authored-by: ycg <1670543365@qq.com> Co-authored-by: AFeiYA <386665678@qq.com> Co-authored-by: zhakesi <zhakesi@foxmail.com>
/** | ||
* @internal | ||
*/ | ||
public UpdateInstancedAttributes (attributes: Attribute[]) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Don't use capital letter as prefix.
Re: #
Changelog
Continuous Integration
This pull request:
Compatibility Check
This pull request: