Per fare questo, una possibilità è quella di utilizzare uno shader frammento GLSL che cambia il colore frammento quando il frammento è vicino un bordo del triangolo. Ecco lo shader GLSL che sto usando. Come input, prende le coordinate baricentriche del frammento nel triangolo e una maschera di bordo che seleziona per ogni spigolo se deve essere disegnata o meno. (Rimozione: ho dovuto usare con il profilo di compatibilità per ragioni di compatibilità all'indietro, se non si vuole fare questo, può facilmente essere adattato):
const char* fshader_source =
"#version 150 compatibility \n"
"flat in float diffuse; \n"
"flat in float specular; \n"
"flat in vec3 edge_mask; \n"
"in vec2 bary; \n"
"uniform float mesh_width = 1.0 ; \n"
"uniform vec3 mesh_color = vec3(0.0, 0.0, 0.0) ; \n"
"uniform bool lighting = true ; \n"
"out vec4 frag_color ; \n"
"float edge_factor(){ \n"
" vec3 bary3 = vec3(bary.x, bary.y, 1.0-bary.x-bary.y) ; \n"
" vec3 d = fwidth(bary3); \n"
" vec3 a3 = smoothstep(vec3(0.0,0.0,0.0), d*mesh_width, bary3); \n"
" a3 = vec3(1.0, 1.0, 1.0) - edge_mask + edge_mask*a3; \n"
" return min(min(a3.x, a3.y), a3.z); \n"
"} \n"
"void main() { \n"
" float s = (lighting && gl_FrontFacing) ? 1.0 : -1.0 ; \n"
" vec4 Kdiff = gl_FrontFacing ? \n"
" gl_FrontMaterial.diffuse : gl_BackMaterial.diffuse ; \n"
" float sdiffuse = s * diffuse ; \n"
" vec4 result = vec4(0.1, 0.1, 0.1, 1.0); \n"
" if(sdiffuse > 0.0) { \n"
" result += sdiffuse*Kdiff + \n"
" specular*gl_FrontMaterial.specular; \n"
" } \n"
" frag_color = (mesh_width != 0.0) ? \n"
" mix(vec4(mesh_color,1.0),result,edge_factor()) : \n"
" result ; \n"
"} \n";
Forse uno shader personalizzato? – Shomz
puoi spiegare ulteriormente? Come può qualcuno usare il materiale shader per questo scopo? – mrapsogos
Puoi definire i tuoi shader, quindi potresti provare con questo: https://aerotwist.com/tutorials/an-introduction-to-shaders-part-1/ In caso contrario, puoi sempre usare una trama wireframe con un solido sfondo. – Shomz