fix normals and uv on 3d models
This commit is contained in:
parent
8e337db1e5
commit
5af7d0a2e0
|
@ -336,13 +336,13 @@ function process()
|
||||||
|
|
||||||
render.set_camera();
|
render.set_camera();
|
||||||
|
|
||||||
os.sprite_pipe();
|
/*os.sprite_pipe();
|
||||||
allsprites.forEach(function(x) {
|
allsprites.forEach(function(x) {
|
||||||
render.set_sprite_tex(x.texture);
|
render.set_sprite_tex(x.texture);
|
||||||
x.draw(x.go);
|
x.draw(x.go);
|
||||||
render.sprite_flush();
|
render.sprite_flush();
|
||||||
});
|
});
|
||||||
render.sprite_flush();
|
render.sprite_flush();*/
|
||||||
render.emitters(); // blits emitters
|
render.emitters(); // blits emitters
|
||||||
prosperon.draw(); // draw calls
|
prosperon.draw(); // draw calls
|
||||||
debug.draw(); // calls needed debugs
|
debug.draw(); // calls needed debugs
|
||||||
|
|
|
@ -90,15 +90,42 @@ unsigned short pack_short_tex(float c) { return c * USHRT_MAX; }
|
||||||
|
|
||||||
uint32_t pack_int10_n2(float *norm)
|
uint32_t pack_int10_n2(float *norm)
|
||||||
{
|
{
|
||||||
uint32_t ni[3];
|
/*float x = norm[0];
|
||||||
|
float y = norm[1];
|
||||||
|
float z = norm[2];
|
||||||
|
const uint32_t xs = x < 0;
|
||||||
|
const uint32_t ys = y < 0;
|
||||||
|
const uint32_t zs = z < 0;
|
||||||
|
uint32_t vi =
|
||||||
|
zs << 29 | ((uint32_t)(z * 511 + (zs << 9)) & 511) << 20 |
|
||||||
|
ys << 19 | ((uint32_t)(y * 511 + (ys << 9)) & 511) << 10 |
|
||||||
|
xs << 9 | ((uint32_t)(x * 511 + (xs << 9)) & 511);
|
||||||
|
return vi;
|
||||||
|
int16_t ni[3];
|
||||||
|
printf("accessing norm %g,%g,%g\n", norm[0], norm[1], norm[2]);
|
||||||
|
|
||||||
|
for (int i = 0; i < 3; i++)
|
||||||
|
ni[i] = (int16_t)(norm[i]*512.0f);
|
||||||
|
|
||||||
|
uint32_t combined = (((uint32_t)ni[2]) << 20) | (((uint32_t)ni[1]) << 10) | ((uint32_t)ni[0]);
|
||||||
|
return combined;
|
||||||
|
uint32_t ni[3];
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
ni[i] = fabs(norm[i]) * 511.0 + 0.5;
|
ni[i] = fabs(norm[i]) * 511.0 + 0.5;
|
||||||
ni[i] = (ni[i] > 511) ? 511 : ni[i];
|
ni[i] = (ni[i] > 511) ? 511 : ni[i];
|
||||||
ni[i] = ( norm[i] < 0.0 ) ? -ni[i] : ni[i];
|
ni[i] = ( norm[i] < 0.0 ) ? -ni[i] : ni[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
return (ni[0] & 0x3FF) | ( (ni[1] & 0x3FF) << 10) | ( (ni[2] & 0x3FF) << 20) | ( (0 & 0x3) << 30);
|
return (ni[0] | ( (ni[1]) << 10) | ( (ni[2] << 20) | ( (0 & 0x3) << 30)));*/
|
||||||
|
|
||||||
|
// Pack the floats into a 32-bit unsigned integer
|
||||||
|
uint32_t packedValue = 0;
|
||||||
|
packedValue |= (uint32_t)((int32_t)(norm[0] * 0x1ff) & 0x3ff) << 20;
|
||||||
|
packedValue |= (uint32_t)((int32_t)(norm[1] * 0x1ff) & 0x3ff) << 10;
|
||||||
|
packedValue |= (uint32_t)((int32_t)(norm[2] * 0x1ff) & 0x3ff);
|
||||||
|
//packedValue |= (uint32_t)((int32_t)(0 * 0x1ff) & 0x3ff) >> 8;
|
||||||
|
|
||||||
|
return packedValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void mesh_add_material(mesh *mesh, cgltf_material *mat)
|
void mesh_add_material(mesh *mesh, cgltf_material *mat)
|
||||||
|
@ -122,25 +149,27 @@ sg_buffer texcoord_floats(float *f, int verts, int comp)
|
||||||
{
|
{
|
||||||
int n = verts*comp;
|
int n = verts*comp;
|
||||||
unsigned short packed[n];
|
unsigned short packed[n];
|
||||||
for (int i = 0, v = 0; i < n; i++)
|
for (int i = 0; i < n; i++)
|
||||||
packed[i] = pack_short_tex(f[i]);
|
packed[i] = pack_short_tex(f[i]);
|
||||||
|
|
||||||
return sg_make_buffer(&(sg_buffer_desc){
|
return sg_make_buffer(&(sg_buffer_desc){
|
||||||
.data.ptr = packed,
|
.data = SG_RANGE(packed),
|
||||||
.data.size = sizeof(unsigned short) * verts,
|
|
||||||
.label = "tex coord vert buffer",
|
.label = "tex coord vert buffer",
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
sg_buffer normal_floats(float *f, int verts, int comp)
|
sg_buffer normal_floats(float *f, int verts, int comp)
|
||||||
{
|
{
|
||||||
|
return sg_make_buffer(&(sg_buffer_desc){
|
||||||
|
.data.ptr = f,
|
||||||
|
.data.size = sizeof(*f)*verts*comp
|
||||||
|
});
|
||||||
uint32_t packed_norms[verts];
|
uint32_t packed_norms[verts];
|
||||||
for (int v = 0, i = 0; v < verts; v++, i+= comp)
|
for (int v = 0, i = 0; v < verts; v++, i+= comp)
|
||||||
packed_norms[v] = pack_int10_n2(f+i);
|
packed_norms[v] = pack_int10_n2(f+i);
|
||||||
|
|
||||||
return sg_make_buffer(&(sg_buffer_desc){
|
return sg_make_buffer(&(sg_buffer_desc){
|
||||||
.data.ptr = packed_norms,
|
.data = SG_RANGE(packed_norms),
|
||||||
.data.size = sizeof(uint32_t) * verts,
|
|
||||||
.label = "normal vert buffer",
|
.label = "normal vert buffer",
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -207,6 +236,7 @@ void mesh_add_primitive(mesh *mesh, cgltf_primitive *prim)
|
||||||
|
|
||||||
case cgltf_attribute_type_normal:
|
case cgltf_attribute_type_normal:
|
||||||
has_norm = 1;
|
has_norm = 1;
|
||||||
|
YughInfo("Found normals.");
|
||||||
mesh->bind.vertex_buffers[2] = normal_floats(vs, verts, comp);
|
mesh->bind.vertex_buffers[2] = normal_floats(vs, verts, comp);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -223,7 +253,10 @@ void mesh_add_primitive(mesh *mesh, cgltf_primitive *prim)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case cgltf_attribute_type_texcoord:
|
case cgltf_attribute_type_texcoord:
|
||||||
mesh->bind.vertex_buffers[1] = texcoord_floats(vs, verts, comp);
|
mesh->bind.vertex_buffers[1] = texcoord_floats(vs, verts, comp); /*sg_make_buffer(&(sg_buffer_desc){
|
||||||
|
.data.ptr = vs,
|
||||||
|
.data.size=sizeof(*vs)*verts*comp
|
||||||
|
});*/
|
||||||
break;
|
break;
|
||||||
case cgltf_attribute_type_invalid:
|
case cgltf_attribute_type_invalid:
|
||||||
YughWarn("Invalid type.");
|
YughWarn("Invalid type.");
|
||||||
|
@ -237,6 +270,7 @@ void mesh_add_primitive(mesh *mesh, cgltf_primitive *prim)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!has_norm) {
|
if (!has_norm) {
|
||||||
|
YughInfo("Making normals.");
|
||||||
cgltf_attribute *pa = get_attr_type(prim, cgltf_attribute_type_position);
|
cgltf_attribute *pa = get_attr_type(prim, cgltf_attribute_type_position);
|
||||||
int n = cgltf_accessor_unpack_floats(pa->data, NULL,0);
|
int n = cgltf_accessor_unpack_floats(pa->data, NULL,0);
|
||||||
int comp = 3;
|
int comp = 3;
|
||||||
|
|
|
@ -78,7 +78,6 @@ void sprite_initialize() {
|
||||||
.attrs = {
|
.attrs = {
|
||||||
[0].format = SG_VERTEXFORMAT_FLOAT2
|
[0].format = SG_VERTEXFORMAT_FLOAT2
|
||||||
},
|
},
|
||||||
.buffers[1].step_func = SG_VERTEXSTEP_PER_INSTANCE
|
|
||||||
},
|
},
|
||||||
.primitive_type = SG_PRIMITIVETYPE_TRIANGLE_STRIP,
|
.primitive_type = SG_PRIMITIVETYPE_TRIANGLE_STRIP,
|
||||||
.label = "sprite pipeline",
|
.label = "sprite pipeline",
|
||||||
|
@ -110,6 +109,7 @@ void sprite_pipe()
|
||||||
{
|
{
|
||||||
sg_apply_pipeline(pip_sprite);
|
sg_apply_pipeline(pip_sprite);
|
||||||
sg_apply_uniforms(SG_SHADERSTAGE_VS, SLOT_vp, SG_RANGE_REF(useproj));
|
sg_apply_uniforms(SG_SHADERSTAGE_VS, SLOT_vp, SG_RANGE_REF(useproj));
|
||||||
|
sg_apply_bindings(&bind_sprite);
|
||||||
}
|
}
|
||||||
|
|
||||||
void tex_draw(HMM_Mat3 m, struct rect r, struct rgba color, int wrap, HMM_Vec2 wrapoffset, HMM_Vec2 wrapscale, struct rgba emissive) {
|
void tex_draw(HMM_Mat3 m, struct rect r, struct rgba color, int wrap, HMM_Vec2 wrapoffset, HMM_Vec2 wrapscale, struct rgba emissive) {
|
||||||
|
@ -171,10 +171,7 @@ void sprite_draw(struct sprite *sprite, gameobject *go) {
|
||||||
spv.size = sprite->spritesize;
|
spv.size = sprite->spritesize;
|
||||||
spv.offset = sprite->spriteoffset;
|
spv.offset = sprite->spriteoffset;
|
||||||
spv.model = HMM_MulM4(m,sm);
|
spv.model = HMM_MulM4(m,sm);
|
||||||
sg_apply_pipeline(pip_sprite);
|
|
||||||
sg_apply_uniforms(SG_SHADERSTAGE_VS, SLOT_sprite, SG_RANGE_REF(spv));
|
sg_apply_uniforms(SG_SHADERSTAGE_VS, SLOT_sprite, SG_RANGE_REF(spv));
|
||||||
sg_apply_uniforms(SG_SHADERSTAGE_VS, SLOT_vp, SG_RANGE_REF(useproj));
|
|
||||||
sg_apply_bindings(&bind_sprite);
|
|
||||||
sg_draw(0,4,1);
|
sg_draw(0,4,1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
|
||||||
@vs vsg3
|
@vs vsg3
|
||||||
// Shared set between most vertex shaders
|
// Shared set between most vertex shaders
|
||||||
uniform ViewUniforms {
|
uniform ViewUniforms {
|
||||||
|
|
|
@ -24,8 +24,11 @@ uniform sprite {
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
texcoords = spriteoff + spritesize*vertex;
|
texcoords = vertex;
|
||||||
gl_Position = proj * vec4(vertex, 0, 1.0);
|
texcoords.y = 1 - texcoords.y;
|
||||||
|
gl_Position = proj * model * vec4(vertex, 0, 1.0);
|
||||||
|
fcolor = vcolor;
|
||||||
|
femissive = vemissive;
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
@vs vs
|
@vs vs
|
||||||
in vec3 a_pos;
|
in vec3 a_pos;
|
||||||
in vec2 a_tex_coords;
|
in vec2 a_tex_coords;
|
||||||
in vec3 a_norm;
|
in vec4 a_norm;
|
||||||
|
|
||||||
out vec2 tex_coords;
|
out vec2 tex_coords;
|
||||||
out vec3 normal;
|
out vec3 normal;
|
||||||
|
@ -12,9 +12,9 @@ uniform mat4 model;
|
||||||
};
|
};
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
gl_Position = vp * vec4(vec3(model * vec4(a_pos,1.0)), 1.0);
|
gl_Position = vp * model * vec4(a_pos,1.0);
|
||||||
tex_coords = a_tex_coords;
|
tex_coords = a_tex_coords;
|
||||||
normal = a_norm;
|
normal = a_norm.xyz;
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ uniform sampler smp;
|
||||||
void main() {
|
void main() {
|
||||||
vec3 lightDir = normalize(vec3(0.5f, 0.5f, 1.0f));
|
vec3 lightDir = normalize(vec3(0.5f, 0.5f, 1.0f));
|
||||||
float diff = max(dot(normal, lightDir), 0.0f);
|
float diff = max(dot(normal, lightDir), 0.0f);
|
||||||
color = texture(sampler2D(diffuse,smp),tex_coords);
|
color = texture(sampler2D(diffuse,smp),tex_coords)*diff;
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue