Replacing ARB shaders: Difference between revisions

From The DarkMod Wiki
Jump to navigationJump to search
Added transparency hacks.
Added entry for the old bloom shaders.
Line 130: Line 130:
|-
|-
|rotoedge.vfp
|rotoedge.vfp
|Postprocessing
|Postprocess
|OK (2019.09.14)
|OK (2019.09.14)
|rotoedge.?s
|rotoedge.?s
Line 150: Line 150:
Look at lights and check how they change if you modify <tt>r_postprocess_*</tt> cvars.
Look at lights and check how they change if you modify <tt>r_postprocess_*</tt> cvars.
Verify that candle flames become blurry if you increase "bloom".
Verify that candle flames become blurry if you increase "bloom".
|-
|afxadd.vfp
afxblend.vfp
afxblend2.vfp
afxmodulate.vfp
afxweight.vfp
blurx????.vfp
blury????.vfp
|Postprocess
|DEAD (2019.11.27)
|*.?s
|Were used for Bloom before the current postprocessing appeared ([http://forums.thedarkmod.com/index.php?/topic/20169-the-history-of-bloom/ reference]).
Referenced in <tt>tdm_bloom.mtr</tt> and <tt>tdm_bloom_afx.mtr</tt>, but those materials not used anywhere.


|-
|-

Revision as of 17:06, 26 November 2019

This table should summarize the current state for every ARB shader.

Filename Type Status Replacement Testing instructions & Comments
heatHazeWithDepth.vfp Material OK (2019.05.26) heatHazeWithDepth.?s map test/glass

everything behind glass should be warped as you strafe along it

heatHazeWithAlphaDepth.vfp Material OK (2019.09.15) heatHazeWithAlphaDepth.?s Volta 2 Cauldron / setviewpos -880 390 -2700 45 80 15.

The underwater stones are darkened with increasing layers of water on top of them (link). This FM has its own copy of ARB shader. Three more FMs have a copy, but don't use their materials with this shader.

heatHaze.vfp Material OK (2019.09.14) heatHaze.?s Accountant1 / setviewpos -2020 -2570 -125 20 130 0

Rain drops cause waves, which warp the picture of the ground.

heatHazeWithMask.vfp Material OK (2019.09.14) heatHazeWithMask.?s A Night To Remember / setviewpos 4500 -1500 -1210 -90 0 0 (noclip)

When looking up from the bloody water, the ceiling is distorted: that's this shader working.

HeatHazeWithMaskAndDepth.vfp Material OK (2019.09.15) HeatHazeWithMaskAndDepth.?s Used by water_clear material, which is almost everywhere.

For instance, in Accountant1 in sewers at setviewpos -2150 -1720 -445 45 -180 0, water surface distorts floor.

heatHazeWithMaskAndBlur.vfp Material OK (2019.09.15) heatHazeWithMaskAndBlur.?s Currently used only in material water_blurred.

A Night To Remember / setviewpos 6370 -1500 -1350 50 30. Look closer into pot: carrots are not only warped, but also blurred.

heatHazeWithMaskAndVertex.vfp Material DEAD (2019.09.15) heatHazeWithMaskAndVertex.?s Only used in legacy textures/sfx/vpring3 material, which is only used in as a part of caco_lightninghit particle in Requiem FM.

However, the mentioned particle is not referenced in that FM, and is not even loaded.

ambientEnvironment.vfp Material DEAD (2019.09.14) ambientEnvironment.?s Not used anywhere in TDM 2.0+. Was used for new ambient lighting, enabled under tdm_ambient_method 2. Still present in all materials under if (global5==2).

See the original thread and probably disclaimer in wiki article.

ambientEnvVertexBlend.vfp Material DEAD (2019.09.14) ambientEnvVertexBlend.?s A rare special case of ambientEnvironment (link)

Mentioned in St. Alban's Cathedral and NHAT, but seems to be as dead as the ambientEnvironment.vfp.

fresnel.vfp Material OK (2019.09.14) fresnel.?s Accountant1 / setviewpos -2260 -2030 -130 30 -150 0 (better enable lantern)

This puddle is rendered with this shader (no idea about its effect). It seems to be the only usage across all FMs.

metaball.vfp Material/FM Needs REPACK!!! metaball.?s In the Black / setviewpos 4800 3350 600 30 -90 0.

You should see on the TV screen: bright yellow spots on blue background; moving, merging, and splitting. If the screen looks uniform without any spots, then it is broken.

soft_particle.vfp Ambient (particles) OK (2019.09.14) soft_particle.?s Set r_useSoftParticles 1 and check e.g. fire.

Start NewJob, go to setviewpos 390 -1440 45 45 22 0 (noclip). Soft particles remove the blocky quadrilateral edges from the piece of wood.

environment.vfp Ambient OK (2019.05.26) environment.?s map test/glass

fake yellow reflections should be visible on the windows

bumpyEnvironment.vfp Ambient OK (2019.05.27) bumpyEnvironment.?s PD2: All the Way Up / setviewpos 4700 -250 -250 / link

Potions should look properly: see t_useGLSL 0, r_uniformTransforms 0 for reference Be sure to check that fake reflection texture is oriented the same way.

rotoedge.vfp Postprocess OK (2019.09.14) rotoedge.?s This is optional/test postprocess shader (reference).

Enabled by g_testPostProcess textures/postprocess/rotoedge on any map. WS3 and WS4 missions have custom version of the material, but don't use it anywhere.

cookMath_pass1.vfp

cookMath_pass2.vfp brightPass_opt.vfp blurx.vfp blury.vfp finalScenePass_opt.vfp

Postprocess Not working (2019.11.25) {name}.?s Set r_postprocess 1 or enable postprocessing in video settings in menu.

Look at lights and check how they change if you modify r_postprocess_* cvars. Verify that candle flames become blurry if you increase "bloom".

afxadd.vfp

afxblend.vfp afxblend2.vfp afxmodulate.vfp afxweight.vfp blurx????.vfp blury????.vfp

Postprocess DEAD (2019.11.27) *.?s Were used for Bloom before the current postprocessing appeared (reference).

Referenced in tdm_bloom.mtr and tdm_bloom_afx.mtr, but those materials not used anywhere.

transparency_hack.vfp

transparent_hack.vfp

Material TODO *.?s Referenced in some materials
(fixed pipeline) Designed for use in the 'old stage' routine (draw_common.cpp) but at some point became the 'default' shader for GUI's, etc OK (2019.05.26) oldStage.?s Check any map (e.g. test/glass) + main menu
frob.vfp Material TODO frob_arb.?s Referenced in test_frobhilight.mtr.
(extra material stages) Replacement for material stage frob highlight. The ARB2 version does not seem to be used anywhere? WIP (2019.05.26) frob.?s Any map +r_newFrob 1
(legacy gl texgen's) Replacement for deprecated texgen code. Material stages TG_SKYBOX_CUBE/TG_WOBBLESKY_CUBE Stable in 2.07 cubemap.?s (insert map name here - Hidden Hands 1?)


(legacy gl texgen's) Replacement for deprecated texgen code. Light material "fogLight" Stable in 2.07 fog.?s (insert map name here - Heart of Lone Salvation?)


(legacy gl texgen's) Replacement for deprecated texgen code. Light material "blendLight" Stable in 2.07 blend.?s (insert map name here - Closemouthed Shadows?)


shadow.vp ARB2 to GLSL manual conversion Stable in 2.07 stencilshadow.?s (insert map name here - Closemouthed Shadows?)


ambientInteraction.vfp/ambient_cubic_light.vfp ARB2 to GLSL manual conversion Stable in 2.07 ambientInteraction.?s (insert map name here - Closemouthed Shadows?)
test_direct.vfp/interaction_direct.vfp/cubic_light_point.vfp/cubic_light_proj.vfp/test_cubic_light_point.vfp/test_cubic_light_proj.vfp ARB2 to GLSL manual conversion Stable in 2.07 interaction.?s (insert map name here - Closemouthed Shadows?)
(fixed pipeline) DepthPass OK (2019.05.27) depthAlpha.?s Check any map (e.g. test/glass).

Used for depth prepass, so if it uses incompatible vertex transform, everything would depth-fight like crazy.

test.vfp

interaction.vfp

Unused (?) ARB2 shaders


List of shader Types:

  • Material: shader filename is referenced in a stage of stock material definition.
Currently, each of these shaders exists in both ARB and GLSL version, but ARB version is used only if r_useGLSL is disabled.
  • FM: shader supplied or overrided by a particular FM --- most likely, specified in material definition.
  • Ambient: shader is loaded directly by C++ code and used during rendering, independent of any light source.
  • Interaction: shader is loaded directly by C++ code and used during rendering, in a light-surface interaction.
  • Postprocessing: shader used for full-screen effects after main rendering is over.


This post explains different modes for testing. In order to set OK Status to a shader, please check that it works properly with following settings:

  • r_useGLSL 1
  • r_forceGlslPrograms 1 (2019.09.14: already removed)
  • r_uniformTransforms 0 and 1 (both cases)

Also set the date when you checked it.


Replacement should specify which files contain the equivalent or superseding code in GLSL. If the replacing code is active only with some settings, write those settings under filename.


Testing instructions must explain how to properly test this shader to ensure that replacement works correctly. Write exact FM/map, coordinates, settings, what to see/expect, etc.