mirror of
https://github.com/bulletphysics/bullet3
synced 2025-01-08 08:30:16 +00:00
4a705d1e03
Fix uninitialized variable jointDamping/jointFriction in SDF importer Add SDF <pose> parsing in visual, inertial, collision elements. Slight improvement in TinyRender loading performance of largish meshes (30k vertices) Reduce #define MAX_SDF_BODIES to 500, due to some issue in client code, todo: figure out what the issue is. b3RobotSimAPI support SDF file loading Tiny improvement in OpenGL hardware renderer lighting, to distinguish faces without textures
80 lines
1.8 KiB
GLSL
80 lines
1.8 KiB
GLSL
#version 330
|
|
precision highp float;
|
|
|
|
|
|
layout (location = 0) in vec4 position;
|
|
layout (location = 1) in vec4 instance_position;
|
|
layout (location = 2) in vec4 instance_quaternion;
|
|
layout (location = 3) in vec2 uvcoords;
|
|
layout (location = 4) in vec3 vertexnormal;
|
|
layout (location = 5) in vec4 instance_color;
|
|
layout (location = 6) in vec3 instance_scale;
|
|
|
|
|
|
uniform mat4 ModelViewMatrix;
|
|
uniform mat4 ProjectionMatrix;
|
|
uniform vec3 lightDirIn;
|
|
|
|
out Fragment
|
|
{
|
|
vec4 color;
|
|
} fragment;
|
|
|
|
out Vert
|
|
{
|
|
vec2 texcoord;
|
|
} vert;
|
|
|
|
|
|
vec4 quatMul ( in vec4 q1, in vec4 q2 )
|
|
{
|
|
vec3 im = q1.w * q2.xyz + q1.xyz * q2.w + cross ( q1.xyz, q2.xyz );
|
|
vec4 dt = q1 * q2;
|
|
float re = dot ( dt, vec4 ( -1.0, -1.0, -1.0, 1.0 ) );
|
|
return vec4 ( im, re );
|
|
}
|
|
|
|
vec4 quatFromAxisAngle(vec4 axis, in float angle)
|
|
{
|
|
float cah = cos(angle*0.5);
|
|
float sah = sin(angle*0.5);
|
|
float d = inversesqrt(dot(axis,axis));
|
|
vec4 q = vec4(axis.x*sah*d,axis.y*sah*d,axis.z*sah*d,cah);
|
|
return q;
|
|
}
|
|
//
|
|
// vector rotation via quaternion
|
|
//
|
|
vec4 quatRotate3 ( in vec3 p, in vec4 q )
|
|
{
|
|
vec4 temp = quatMul ( q, vec4 ( p, 0.0 ) );
|
|
return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );
|
|
}
|
|
vec4 quatRotate ( in vec4 p, in vec4 q )
|
|
{
|
|
vec4 temp = quatMul ( q, p );
|
|
return quatMul ( temp, vec4 ( -q.x, -q.y, -q.z, q.w ) );
|
|
}
|
|
|
|
out vec3 lightDir,normal,ambient;
|
|
|
|
void main(void)
|
|
{
|
|
vec4 q = instance_quaternion;
|
|
ambient = vec3(0.5,.5,0.5);
|
|
|
|
vec4 worldNormal = (quatRotate3( vertexnormal,q));
|
|
normal = normalize(worldNormal).xyz;
|
|
|
|
lightDir = lightDirIn;
|
|
|
|
vec4 localcoord = quatRotate3( position.xyz*instance_scale,q);
|
|
vec4 vertexPos = ProjectionMatrix * ModelViewMatrix *(instance_position+localcoord);
|
|
|
|
gl_Position = vertexPos;
|
|
|
|
fragment.color = instance_color;
|
|
vert.texcoord = uvcoords;
|
|
}
|
|
|