@ -482,6 +482,9 @@ bool CDriverGL3::setupMaterial(CMaterial& mat)
// =====================
// =====================
switch ( matShader )
switch ( matShader )
{
{
case CMaterial : : LightMap :
// Programs are setup in multipass
return true ;
default :
default :
return setupBuiltinPrograms ( ) ;
return setupBuiltinPrograms ( ) ;
}
}
@ -668,22 +671,21 @@ void CDriverGL3::setupLightMapPass(uint pass)
const CMaterial & mat = * _CurrentMaterial ;
const CMaterial & mat = * _CurrentMaterial ;
// common colors
// common colors
static uint32 packedColorBlack = CRGBA ( 0 , 0 , 0 , 255 ) . getPacked ( ) ;
static const GLfloat glcolBlack [ 4 ] = { 0.f , 0.f , 0.f , 1.f } ;
static GLfloat glcolBlack [ 4 ] = { 0.f , 0.f , 0.f , 1.f } ;
static const GLfloat glcolWhite [ 4 ] = { 1.f , 1.f , 1.f , 1.f } ;
static uint32 packedColorWhite = CRGBA ( 255 , 255 , 255 , 255 ) . getPacked ( ) ;
static const GLfloat glcolGrey [ 4 ] = { 0.5f , 0.5f , 0.5f , 1.f } ;
static GLfloat glcolWhite [ 4 ] = { 1.f , 1.f , 1.f , 1.f } ;
static uint32 packedColorGrey = CRGBA ( 128 , 128 , 128 , 128 ) . getPacked ( ) ;
static GLfloat glcolGrey [ 4 ] = { 0.5f , 0.5f , 0.5f , 1.f } ;
// No lightmap or all blacks??, just setup "black texture" for stage 0.
// No lightmap or all blacks??, just setup "black texture" for stage 0.
if ( _NLightMaps = = 0 )
if ( _NLightMaps = = 0 )
{
{
nldebug ( " No lightmaps " ) ;
ITexture * text = mat . getTexture ( 0 ) ;
ITexture * text = mat . getTexture ( 0 ) ;
activateTexture ( 0 , text ) ;
activateTexture ( 0 , text ) ;
// setup std modulate env
// setup std modulate env
// CMaterial::CTexEnv env;
// CMaterial::CTexEnv env;
// activateTexEnvMode(0, env); // FIXME GL3
// activateTexEnvMode(0, env); // FIXME GL3: standard modulate env
// Since Lighting is disabled, as well as colorArray, must setup alpha.
// Since Lighting is disabled, as well as colorArray, must setup alpha.
// setup color to 0 => blackness. in emissive cause texture can still be lighted by dynamic light
// setup color to 0 => blackness. in emissive cause texture can still be lighted by dynamic light
@ -691,7 +693,7 @@ void CDriverGL3::setupLightMapPass(uint pass)
// FIXME GL3 LIGHTMAP
// FIXME GL3 LIGHTMAP
// Setup gen tex off
// Setup gen tex off
// setTexGenModeVP(0, TexGenDisabled); // FIXME GL3
setTexGenModeVP ( 0 , TexGenDisabled ) ;
// And disable other stages.
// And disable other stages.
for ( uint stage = 1 ; stage < IDRV_MAT_MAXTEXTURES ; stage + + )
for ( uint stage = 1 ; stage < IDRV_MAT_MAXTEXTURES ; stage + + )
@ -700,6 +702,9 @@ void CDriverGL3::setupLightMapPass(uint pass)
activateTexture ( stage , NULL ) ;
activateTexture ( stage , NULL ) ;
}
}
// Setup the programs now
setupBuiltinPrograms ( ) ;
return ;
return ;
}
}
@ -711,16 +716,15 @@ void CDriverGL3::setupLightMapPass(uint pass)
uint nstages ;
uint nstages ;
lmapId = pass * _NLightMapPerPass ; // Nb lightmaps already processed
lmapId = pass * _NLightMapPerPass ; // Nb lightmaps already processed
// N lightmaps for this pass, plus the texture.
// N lightmaps for this pass, plus the texture.
nstages = std : : min ( _NLightMapPerPass , _NLightMaps - lmapId ) + 1 ;
nstages = std : : min ( _NLightMapPerPass , _NLightMaps - lmapId ) + 1 ; // at most 4
// For LMC (lightmap 8Bit compression) compute the total AmbientColor in vertex diffuse
// For LMC (lightmap 8Bit compression) compute the total AmbientColor in vertex diffuse
// need only if standard MulADD version
// need only if standard MulADD version
{
uint32 r = 0 ;
uint32 r = 0 ;
uint32 g = 0 ;
uint32 g = 0 ;
uint32 b = 0 ;
uint32 b = 0 ;
// sum only the ambient of lightmaps that will be drawn this pass
// sum only the ambient of lightmaps that will be drawn this pass
for ( uint sa = 0 ; sa < nstages - 1 ; sa + + )
for ( uint sa = 0 ; sa < nstages - 1 ; + + sa )
{
{
uint wla = _LightMapLUT [ lmapId + sa ] ;
uint wla = _LightMapLUT [ lmapId + sa ] ;
// must mul them by their respective mapFactor too
// must mul them by their respective mapFactor too
@ -735,18 +739,17 @@ void CDriverGL3::setupLightMapPass(uint pass)
b = std : : min ( b , ( uint32 ) 255 ) ;
b = std : : min ( b , ( uint32 ) 255 ) ;
// this color will be added to the first lightmap (with help of emissive)
// this color will be added to the first lightmap (with help of emissive)
// CRGBA col((uint8)r,(uint8)g,(uint8)b,255);
CRGBA col ( ( uint8 ) r , ( uint8 ) g , ( uint8 ) b , 255 ) ;
// GLfloat glcol[4];
// convColor(col, glcol);
// Lightmap factors
// _DriverGLStates.setEmissive(col.getPacked(), glcol);
NLMISC : : CRGBAF selfIllumination ( col ) ;
// FIXME GL3 LIGHTMAP
NLMISC : : CRGBAF constant [ IDRV_MAT_MAXTEXTURES ] ;
}
// setup all stages.
// setup all stages.
for ( uint stage = 0 ; stage < IDRV_MAT_MAXTEXTURES ; stage + + )
for ( uint stage = 0 ; stage < IDRV_MAT_MAXTEXTURES ; + + stage )
{
{
// if must setup a lightmap stage .
// if must setup a lightmap stage
if ( stage < nstages - 1 )
if ( stage < nstages - 1 ) // last stage is user texture
{
{
// setup lightMap.
// setup lightMap.
uint whichLightMap = _LightMapLUT [ lmapId ] ;
uint whichLightMap = _LightMapLUT [ lmapId ] ;
@ -767,12 +770,16 @@ void CDriverGL3::setupLightMapPass(uint pass)
//==================================================
//==================================================
if ( text )
if ( text )
{
{
static CMaterial : : CTexEnv stdEnv ;
// Setup env for texture stage.
setTexGenModeVP ( stage , TexGenDisabled ) ;
{
// FIXME GL3: builtin TexEnv[stage] = TexEnvSpecialLightMap
// Here, we are sure that texEnvCombine4 or texEnvCombine3 is OK.
// nlassert(_Extensions.ATITextureEnvCombine3);
// Setup constant color with Lightmap factor.
constant [ stage ] = NLMISC : : CRGBAF ( lmapFactor ) ;
/*static CMaterial::CTexEnv stdEnv;
{
// setup constant color with Lightmap factor.
// setup constant color with Lightmap factor.
stdEnv . ConstantColor = lmapFactor ;
stdEnv . ConstantColor = lmapFactor ;
@ -786,16 +793,13 @@ void CDriverGL3::setupLightMapPass(uint pass)
// activateTexEnvColor(stage, stdEnv); // FIXME GL3
// activateTexEnvColor(stage, stdEnv); // FIXME GL3
// Setup env for texture stage.
// setTexGenModeVP(stage, TexGenDisabled); // FIXME GL3
// setup TexEnvCombine4 (ignore alpha part).
// setup TexEnvCombine4 (ignore alpha part).
/*if (_CurrentTexEnvSpecial[stage] != TexEnvSpecialLightMap)
/*if (_CurrentTexEnvSpecial[stage] != TexEnvSpecialLightMap)
{
{
// TexEnv is special.
// TexEnv is special.
_CurrentTexEnvSpecial [ stage ] = TexEnvSpecialLightMap ;
_CurrentTexEnvSpecial [ stage ] = TexEnvSpecialLightMap ;
} */ // FIXME GL3
} */ // FIXME GL3
}
/*}*/
}
}
// Next lightmap.
// Next lightmap.
@ -812,10 +816,10 @@ void CDriverGL3::setupLightMapPass(uint pass)
activateTexture ( stage , text ) ;
activateTexture ( stage , text ) ;
// setup ModulateRGB/ReplaceAlpha env. (this may disable possible COMBINE4_NV setup).
// setup ModulateRGB/ReplaceAlpha env. (this may disable possible COMBINE4_NV setup).
// activateTexEnvMode(stage, _LightMapLastStageEnv); // FIXME GL3
// activateTexEnvMode(stage, _LightMapLastStageEnv); // SHADER BUILTIN
// Setup gen tex off
// Setup gen tex off
// setTexGenModeVP(stage, TexGenDisabled); // FIXME GL3
setTexGenModeVP ( stage , TexGenDisabled ) ;
}
}
}
}
else
else
@ -894,6 +898,22 @@ void CDriverGL3::setupLightMapPass(uint pass)
// _DriverGLStates.setDiffuse(packedColorBlack, glcolBlack);
// _DriverGLStates.setDiffuse(packedColorBlack, glcolBlack);
// FIXME GL3 LIGHTMAP
// FIXME GL3 LIGHTMAP
}
}
// Setup the programs now
setupBuiltinPrograms ( ) ;
// Set constants
for ( uint stage = 0 ; stage < IDRV_MAT_MAXTEXTURES ; + + stage )
{
uint constantIdx = m_DriverPixelProgram - > getUniformIndex ( CProgramIndex : : TName ( CProgramIndex : : Constant0 + stage ) ) ;
if ( constantIdx ! = ~ 0 )
{
setUniform4f ( IDriver : : PixelProgram , constantIdx , constant [ stage ] . R , constant [ stage ] . G , constant [ stage ] . B , constant [ stage ] . A ) ;
}
}
// Set self illumination
// FIXME GL3: selfIllumination
}
}
// ***************************************************************************
// ***************************************************************************