Three.js, das zu tun, ist eine Möglichkeit, ein GLSL Fragment-Shader zu verwenden, die das Fragment Farbe ändert, wenn das Fragment in der Nähe einer Kante des Dreiecks. Hier ist der GLSL-Shader, den ich verwende. Als Eingabe werden die baryzentrischen Koordinaten des Fragments im Dreieck und eine Kantenmaske verwendet, die für jede Kante auswählt, ob sie gezeichnet werden soll oder nicht. (Rem: Ich hatte es mit der Kompatibilität Profil aus Gründen der Abwärtskompatibilitätsgründen zu verwenden, wenn Sie das nicht tun wollen, kann es leicht angepasst werden):
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";
Vielleicht ein benutzerdefinierter Shader? – Shomz
können Sie weiter erklären? Wie kann jemand Shadermaterial für diesen Zweck verwenden? – mrapsogos
Sie können Ihre eigenen Shader definieren, also können Sie es versuchen: https://aerotwist.com/tutorials/an-introduction-to-shaders-part-1/ Wenn nicht, können Sie immer eine Drahtgitterstruktur mit einem Solid verwenden Hintergrund. – Shomz