Is my code causing a bug?

Mesh mesh = new Mesh();

Material material = h.GetComponent<Renderer>().sharedMaterial;

Transform t = h.transform;

mesh.SetVertices(verticesout);
mesh.SetTriangles(Triangles, 0, true);
mesh.RecalculateNormals();

RenderParams rp = new RenderParams(material);

Matrix4x4 matrix = Matrix4x4.TRS(t.position, t.transform.rotation, t.transform.lossyScale);

Graphics.RenderMesh(rp, mesh, 0, matrix);

I’m making a lot of meshes and I get a error.

Resource ID out of range in SetResource: 1082400 (max is 1048575)

Unity is slow to quit.

I don’t know if I am doing something incorrectly.

Do you destroy the meshes after you don’t need them anymore?

hello,

First: make sure you don’t create an infinite loop creation, always have a way out.

Second: The number of instances or meshes created affect the game’s playback performance, resulting in mild or severe freezes. I recommend doing gradual parts or with coroutines.

Third: Do a test without attributing the materials, as this can reveal whether the poor performance or error is linked to the manipulation of many materials and textures and with this it may be thought that you could use the same shared material in other items that use the same type, to reduce creation processes and items in memory;

Fourth: Whenever you create something, especially multiple ones, always store it somewhere so you can manipulate it. That said, after creating a certain amount of instantiations, it is recommended to destroy the inactive ones or those that are far away, in the case if you play the game with instantiation according to saved data.

I hope I have shed some light on ideas.

I was not destroying the meshes I made.

Now I’ve made every mesh I could possibly need in a list and increment it after each mesh is referenced.

Then I mesh clear.

Thanks.

1 Like