0 votes

When generating a mesh using Mesh.add_surface(format,Vector3Array), I can generate the mesh correctly. I can add it as a resource to a MeshInstance node. The mesh displays correctly, except for how it interacts with lighting.

The MeshInstance does not interact with external lighting whatsoever. It does not diffract, it does not scatter uniformly. The only color seen is the emission color.

If an imported OBJ mesh is used instead, the problem is gone and the MeshInstance interacts with light correctly.

If the Mesh.regen_normalmaps() function is used, the problem persists. Only emission is seen.

If the mesh is saved as a resource using ResourceSaver.save and added to another MishInstance, the problem persists. Only emission is seen.

In the attached image, you can see four MeshInstance nodes. A cube, demonstrating the correct behavior of the external light. Next: Black paraboloid as saved from Mesh.addsurface and assigned to a MeshInstance. Its emission color is set to black. Next: Red paraboloid, as assigned to a MeshInstance at compile time using self.setmesh. Its emission color is set to red. Next: Greed paraboloid, an attempt to use SurfaceTool (which is not a solution, as it is not parallelizable for efficiency). For SurfaceTool, both with and without generate_normals have the incorrect behavior.

My question is this: What am I doing wrong? How can I programatically add a locally generated mesh to the scene and have light diffuse and diffract correctly (not in a serial manner, as in SurfaceTool)? Is it something to do with normals? Thank you very much for reading; I am enjoying Godot a lot.

in Engine by (56 points)


The input to add_surface should be the primitive type and an Array of arrays of varying types (the vertex array should be a Vector3Array, the color array should be a ColorArray etc., check the Mesh documentation). Does Godot give you any errors? What does surface_get_format() print for your surface? Does flipping your normals do anything?

Thanks for your attention!

In clarification of the first point you raise, I should explicitly copy some of my code:
var mesh=Mesh.new()
var array = Array()
VERTEX] = vertices
mesh.addsurface(Mesh.PRIMITIVETRIANGLES, array)
where ARRAY_MAX is 9 and vertices is a Vector3Array.

In response to whether Godot gives me any errors, the answer is no. No errors are displayed in the output, nor in the debug.

In response to what surfacegetformat() gives, the answer is integer 1, or ARRAYFORMATVERTEX according to the Mesh documentation.

In response to what flipping normals does, here I need to betray my ignorance. I haven't specified normals. Would it be as simple as doing
array[Mesh.ARRAYNORMAL] = normals
surface(Mesh.PRIMITIVE_TRIANGLES, array)

1 Answer

0 votes
Best answer

The comment by mollusca basically had the answer: Normals are required to render correctly. The code to do this is

    var array = Array()
array.resize(ARRAY_MAX)#this is 9
array[Mesh.ARRAY_VERTEX] = vertices#Vector3Array
array[Mesh.ARRAY_NORMAL] = normals#Vector3Array

mesh.add_surface(Mesh.PRIMITIVE_TRIANGLES, array)
by (56 points)

Can I update the array size and reposition the vertices on the fly, without recreating the mesh or the array? Thanks.

Welcome to Godot Engine Q&A, where you can ask questions and receive answers from other members of the community.

Please make sure to read Frequently asked questions and How to use this Q&A? before posting your first questions.
Social login is currently unavailable. If you've previously logged in with a Facebook or GitHub account, use the I forgot my password link in the login box to set a password for your account. If you still can't access your account, send an email to [email protected] with your username.