File: surface.fs

package info (click to toggle)
pymol 3.1.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 74,084 kB
  • sloc: cpp: 482,660; python: 89,328; ansic: 29,512; javascript: 6,792; sh: 84; makefile: 25
file content (58 lines) | stat: -rw-r--r-- 1,355 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#include webgl_header.fs

varying vec3 packed_data_0 ;
varying float fog;
varying vec2 bgTextureLookup;

#ifdef PURE_OPENGL_ES_2
varying vec4 COLOR;
#else
// using the built-in allows to use glShadeModel
#define COLOR gl_Color
#endif

#define NORMAL normalize(packed_data_0.xyz)

uniform bool lighting_enabled;
uniform bool two_sided_lighting_enabled;
uniform vec4 interior_color;
uniform bool use_interior_color;

#include anaglyph_header.fs
#include compute_fog_color.fs
#include compute_color_for_light.fs

void main()
{
  if (isPicking){
    gl_FragColor = COLOR; // no lighting
  } else {
    // WARNING: !gl_FrontFacing does not work on Intel (bug)
    bool is_interior = gl_FrontFacing ? false : true;
    vec3 normal = NORMAL;
    if (use_interior_color && is_interior) {
      // ray_interior_color
      gl_FragColor = vec4(interior_color.rgb, COLOR.a);
    } else {
      // back faces
      if (is_interior) {
        if (two_sided_lighting_enabled) {
          normal = -normal;
        } else {
          // disable all except ambient light (intended? ray tracing differs!)
          normal = vec3(0.);
        }
      }

      vec4 color = ApplyColorEffects(COLOR, gl_FragCoord.z);

      // lights
      color = ApplyLighting(color, normal);

      // fog
      gl_FragColor = ApplyFog(color, fog);
    }
    PostLightingEffects();
  }
}