mirror of
https://github.com/TorqueGameEngines/Torque3D.git
synced 2026-04-29 00:05:40 +00:00
Added support for uniforms, textures and samplers.
This commit is contained in:
parent
5019478aad
commit
74138342d1
7 changed files with 235 additions and 9 deletions
|
|
@ -206,25 +206,104 @@ void CustomFeatureHLSL::setTexData(Material::StageData &stageDat,
|
||||||
Con::executef(mOwner, "setTextureData");
|
Con::executef(mOwner, "setTextureData");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CustomFeatureHLSL::addUniform(String name, String type, String defaultValue, U32 arraySize)
|
||||||
|
{
|
||||||
|
//do the var/arg fetching here
|
||||||
|
Var *newVar = (Var*)LangElement::find(name.c_str());
|
||||||
|
if (!newVar)
|
||||||
|
{
|
||||||
|
VarHolder newVarHolder(name, type, "");
|
||||||
|
newVarHolder.arraySize = arraySize;
|
||||||
|
newVarHolder.sampler = false;
|
||||||
|
newVarHolder.uniform = true;
|
||||||
|
newVarHolder.constSortPos = cspPrimitive;
|
||||||
|
|
||||||
|
mVars.push_back(newVarHolder);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CustomFeatureHLSL::addSampler(String name, String type, U32 arraySize)
|
||||||
|
{
|
||||||
|
//do the var/arg fetching here
|
||||||
|
Var *newVar = (Var*)LangElement::find(name.c_str());
|
||||||
|
if (!newVar)
|
||||||
|
{
|
||||||
|
//As far as I know, it's always SamplerState regardless of the texture's type
|
||||||
|
VarHolder newVarHolder(name, "SamplerState", "");
|
||||||
|
newVarHolder.arraySize = arraySize;
|
||||||
|
newVarHolder.sampler = true;
|
||||||
|
newVarHolder.uniform = true;
|
||||||
|
newVarHolder.constNum = Var::getTexUnitNum(); // used as texture unit num here
|
||||||
|
|
||||||
|
mVars.push_back(newVarHolder);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CustomFeatureHLSL::addTexture(String name, String type, String samplerState, U32 arraySize)
|
||||||
|
{
|
||||||
|
//do the var/arg fetching here
|
||||||
|
Var *newVar = (Var*)LangElement::find(name.c_str());
|
||||||
|
if (!newVar)
|
||||||
|
{
|
||||||
|
//go find our sampler state var
|
||||||
|
U32 constNum = 0;
|
||||||
|
|
||||||
|
Var *samplerStateVar = (Var*)LangElement::find(samplerState.c_str());
|
||||||
|
if (!samplerStateVar)
|
||||||
|
{
|
||||||
|
//check our holder vars
|
||||||
|
bool foundHolder = false;
|
||||||
|
for (U32 v = 0; v < mVars.size(); v++)
|
||||||
|
{
|
||||||
|
if (mVars[v].varName == samplerState)
|
||||||
|
{
|
||||||
|
constNum = mVars[v].constNum;
|
||||||
|
foundHolder = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!foundHolder)
|
||||||
|
{
|
||||||
|
Con::errorf("CustomShaderFeature::addTexture: Unable to find texture's sampler state!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
constNum = samplerStateVar->constNum;
|
||||||
|
}
|
||||||
|
|
||||||
|
VarHolder newVarHolder(name, type, "");
|
||||||
|
newVarHolder.arraySize = arraySize;
|
||||||
|
newVarHolder.texture = true;
|
||||||
|
newVarHolder.uniform = true;
|
||||||
|
newVarHolder.constNum = constNum; // used as texture unit num here
|
||||||
|
|
||||||
|
mVars.push_back(newVarHolder);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void CustomFeatureHLSL::addVariable(String name, String type, String defaultValue)
|
void CustomFeatureHLSL::addVariable(String name, String type, String defaultValue)
|
||||||
{
|
{
|
||||||
//do the var/arg fetching here
|
//do the var/arg fetching here
|
||||||
Var *newVar = (Var*)LangElement::find(name.c_str());
|
Var *newVar = (Var*)LangElement::find(name.c_str());
|
||||||
if (!newVar)
|
if (!newVar)
|
||||||
{
|
{
|
||||||
newVar = new Var(name, type);
|
|
||||||
LangElement *newVarDecl = new DecOp(newVar);
|
|
||||||
|
|
||||||
if (!defaultValue.isEmpty())
|
if (!defaultValue.isEmpty())
|
||||||
{
|
{
|
||||||
char declareStatement[128];
|
char declareStatement[128];
|
||||||
dSprintf(declareStatement, 128, " @ = %s;\n", defaultValue.c_str());
|
dSprintf(declareStatement, 128, " @ = %s;\n", defaultValue.c_str());
|
||||||
|
|
||||||
|
newVar = new Var(name, type);
|
||||||
|
LangElement *newVarDecl = new DecOp(newVar);
|
||||||
meta->addStatement(new GenOp(declareStatement, newVarDecl));
|
meta->addStatement(new GenOp(declareStatement, newVarDecl));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
meta->addStatement(new GenOp(" @;\n", newVarDecl));
|
VarHolder newVarHolder(name, type, defaultValue);
|
||||||
|
|
||||||
|
mVars.push_back(newVarHolder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -233,6 +312,7 @@ void CustomFeatureHLSL::writeLine(String format, S32 argc, ConsoleValueRef *argv
|
||||||
{
|
{
|
||||||
//do the var/arg fetching here
|
//do the var/arg fetching here
|
||||||
Vector<Var*> varList;
|
Vector<Var*> varList;
|
||||||
|
bool declarationStatement = false;
|
||||||
|
|
||||||
for (U32 i = 0; i < argc; i++)
|
for (U32 i = 0; i < argc; i++)
|
||||||
{
|
{
|
||||||
|
|
@ -240,9 +320,43 @@ void CustomFeatureHLSL::writeLine(String format, S32 argc, ConsoleValueRef *argv
|
||||||
Var *newVar = (Var*)LangElement::find(varName.c_str());
|
Var *newVar = (Var*)LangElement::find(varName.c_str());
|
||||||
if (!newVar)
|
if (!newVar)
|
||||||
{
|
{
|
||||||
//couldn't find that variable, bail out
|
//ok, check our existing var holders, see if we just haven't utilized it yet
|
||||||
Con::errorf("CustomShaderFeature::writeLine: unable to find variable %s, meaning it was not declared before being used!", argv[i].getStringValue());
|
for (U32 v = 0; v < mVars.size(); v++)
|
||||||
return;
|
{
|
||||||
|
if (mVars[v].varName == varName)
|
||||||
|
{
|
||||||
|
Var* newDeclVar = new Var(mVars[v].varName, mVars[v].type);
|
||||||
|
|
||||||
|
newDeclVar->arraySize = mVars[v].arraySize;
|
||||||
|
newDeclVar->uniform = mVars[v].uniform;
|
||||||
|
newDeclVar->sampler = mVars[v].sampler;
|
||||||
|
newDeclVar->texture = mVars[v].texture;
|
||||||
|
newDeclVar->constNum = mVars[v].constNum;
|
||||||
|
newDeclVar->constSortPos = mVars[v].constSortPos;
|
||||||
|
|
||||||
|
if (!newDeclVar->uniform)
|
||||||
|
{
|
||||||
|
LangElement *newVarDecl = new DecOp(newDeclVar);
|
||||||
|
newVar = (Var*)newVarDecl;
|
||||||
|
|
||||||
|
declarationStatement = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
newVar = newDeclVar;
|
||||||
|
}
|
||||||
|
|
||||||
|
mVars.erase(v);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!newVar)
|
||||||
|
{
|
||||||
|
//couldn't find that variable, bail out
|
||||||
|
Con::errorf("CustomShaderFeature::writeLine: unable to find variable %s, meaning it was not declared before being used!", argv[i].getStringValue());
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
varList.push_back(newVar);
|
varList.push_back(newVar);
|
||||||
|
|
|
||||||
|
|
@ -27,6 +27,42 @@ class CustomFeatureHLSL : public ShaderFeatureHLSL
|
||||||
{
|
{
|
||||||
friend class CustomShaderFeatureData;
|
friend class CustomShaderFeatureData;
|
||||||
|
|
||||||
|
struct VarHolder
|
||||||
|
{
|
||||||
|
String varName;
|
||||||
|
String defaultValue;
|
||||||
|
String type;
|
||||||
|
bool uniform;
|
||||||
|
bool sampler;
|
||||||
|
bool texture;
|
||||||
|
U32 constNum;
|
||||||
|
ConstantSortPosition constSortPos;
|
||||||
|
U32 arraySize;
|
||||||
|
|
||||||
|
VarHolder() :
|
||||||
|
varName(""),
|
||||||
|
type(""),
|
||||||
|
defaultValue(""),
|
||||||
|
uniform(false),
|
||||||
|
sampler(false),
|
||||||
|
texture(false),
|
||||||
|
constNum(0),
|
||||||
|
arraySize(0),
|
||||||
|
constSortPos(cspUninit)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
VarHolder(String _varName,String _type, String _defaultValue) :
|
||||||
|
uniform(false), sampler(false), texture(false), constNum(0), arraySize(0), constSortPos(cspUninit)
|
||||||
|
{
|
||||||
|
varName = _varName;
|
||||||
|
type = _type;
|
||||||
|
defaultValue = _defaultValue;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Vector<VarHolder> mVars;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CustomShaderFeatureData* mOwner;
|
CustomShaderFeatureData* mOwner;
|
||||||
|
|
||||||
|
|
@ -64,6 +100,9 @@ public:
|
||||||
return mOwner->getName();
|
return mOwner->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void addUniform(String name, String type, String defaultValue, U32 arraySize = 0);
|
||||||
void addVariable(String name, String type, String defaultValue);
|
void addVariable(String name, String type, String defaultValue);
|
||||||
|
void addSampler(String name, String type, U32 arraySize = 0);
|
||||||
|
void addTexture(String name, String type, String samplerState, U32 arraySize);
|
||||||
void writeLine(String format, S32 argc, ConsoleValueRef *argv);
|
void writeLine(String format, S32 argc, ConsoleValueRef *argv);
|
||||||
};
|
};
|
||||||
|
|
@ -89,6 +89,21 @@ void CustomShaderFeatureData::addVariable(String name, String type, String defau
|
||||||
mFeatureHLSL->addVariable(name, type, defaultValue);
|
mFeatureHLSL->addVariable(name, type, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CustomShaderFeatureData::addUniform(String name, String type, String defaultValue, U32 arraySize)
|
||||||
|
{
|
||||||
|
mFeatureHLSL->addUniform(name, type, defaultValue, arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CustomShaderFeatureData::addSampler(String name, String type, U32 arraySize)
|
||||||
|
{
|
||||||
|
mFeatureHLSL->addSampler(name, type, arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CustomShaderFeatureData::addTexture(String name, String type, String samplerState, U32 arraySize)
|
||||||
|
{
|
||||||
|
mFeatureHLSL->addTexture(name, type, samplerState, arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
void CustomShaderFeatureData::writeLine(String format, S32 argc, ConsoleValueRef *argv)
|
void CustomShaderFeatureData::writeLine(String format, S32 argc, ConsoleValueRef *argv)
|
||||||
{
|
{
|
||||||
/*mOnObject = onObject;
|
/*mOnObject = onObject;
|
||||||
|
|
@ -136,6 +151,21 @@ DefineEngineMethod(CustomShaderFeatureData, addVariable, void, (String name, Str
|
||||||
object->addVariable(name, type, defaultValue);
|
object->addVariable(name, type, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DefineEngineMethod(CustomShaderFeatureData, addUniform, void, (String name, String type, String defaultValue, U32 arraySize), ("", "", "", 0), "")
|
||||||
|
{
|
||||||
|
object->addUniform(name, type, defaultValue, arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
|
DefineEngineMethod(CustomShaderFeatureData, addSampler, void, (String name, U32 arraySize), ("", 0), "")
|
||||||
|
{
|
||||||
|
object->addSampler(name, "", arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
|
DefineEngineMethod(CustomShaderFeatureData, addTexture, void, (String name, String type, String samplerState, U32 arraySize), ("", "", 0), "")
|
||||||
|
{
|
||||||
|
object->addTexture(name, type, samplerState, arraySize);
|
||||||
|
}
|
||||||
|
|
||||||
ConsoleMethod(CustomShaderFeatureData, writeLine, void, 3, 0, "( string format, string args... ) Dynamically call a method on an object.\n"
|
ConsoleMethod(CustomShaderFeatureData, writeLine, void, 3, 0, "( string format, string args... ) Dynamically call a method on an object.\n"
|
||||||
"@param method Name of method to call.\n"
|
"@param method Name of method to call.\n"
|
||||||
"@param args Zero or more arguments for the method.\n"
|
"@param args Zero or more arguments for the method.\n"
|
||||||
|
|
|
||||||
|
|
@ -59,6 +59,10 @@ public:
|
||||||
|
|
||||||
//shadergen setup
|
//shadergen setup
|
||||||
void addVariable(String name, String type, String defaultValue);
|
void addVariable(String name, String type, String defaultValue);
|
||||||
|
void addUniform(String name, String type, String defaultValue, U32 arraySize);
|
||||||
|
void addSampler(String name, String type, U32 arraySize);
|
||||||
|
void addTexture(String name, String type, String samplerState, U32 arraySize);
|
||||||
|
|
||||||
void writeLine(String format, S32 argc, ConsoleValueRef *argv);
|
void writeLine(String format, S32 argc, ConsoleValueRef *argv);
|
||||||
|
|
||||||
//shader generation
|
//shader generation
|
||||||
|
|
|
||||||
|
|
@ -112,6 +112,7 @@ Var::Var( const char *inName, const char *inType )
|
||||||
sampler = false;
|
sampler = false;
|
||||||
texCoordNum = 0;
|
texCoordNum = 0;
|
||||||
constSortPos = cspUninit;
|
constSortPos = cspUninit;
|
||||||
|
constNum = 0;
|
||||||
arraySize = 1;
|
arraySize = 1;
|
||||||
texture = false;
|
texture = false;
|
||||||
rank = 0;
|
rank = 0;
|
||||||
|
|
|
||||||
|
|
@ -285,6 +285,31 @@ void ShaderGen::_processVertFeatures( Vector<GFXShaderMacro> ¯os, bool macro
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Handle if we have any custom features
|
||||||
|
if (!mCustomFeaturesData.empty())
|
||||||
|
{
|
||||||
|
for (U32 i = 0; i < mCustomFeaturesData.size(); ++i)
|
||||||
|
{
|
||||||
|
mCustomFeaturesData[i]->mFeatureHLSL->processVert(mComponents, mFeatureData);
|
||||||
|
|
||||||
|
String line = String::ToString(" // %s\r\n", mCustomFeaturesData[i]->mFeatureHLSL->getName().c_str());
|
||||||
|
mOutput->addStatement(new GenOp(line));
|
||||||
|
|
||||||
|
if (mCustomFeaturesData[i]->mFeatureHLSL->getOutput())
|
||||||
|
mOutput->addStatement(mCustomFeaturesData[i]->mFeatureHLSL->getOutput());
|
||||||
|
//ShaderFeatureHLSL feature = mCustomFeaturesData[i]->mHLSLFeature;
|
||||||
|
//feature->setProcessIndex(index);
|
||||||
|
|
||||||
|
/*feature->processPixMacros(macros, mFeatureData);
|
||||||
|
|
||||||
|
feature->setInstancingFormat(&mInstancingFormat);
|
||||||
|
feature->processPix(mComponents, mFeatureData);*/
|
||||||
|
|
||||||
|
mCustomFeaturesData[i]->mFeatureHLSL->reset();
|
||||||
|
mOutput->addStatement(new GenOp(" \r\n"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ShaderConnector *connect = dynamic_cast<ShaderConnector *>( mComponents[C_CONNECTOR] );
|
ShaderConnector *connect = dynamic_cast<ShaderConnector *>( mComponents[C_CONNECTOR] );
|
||||||
connect->sortVars();
|
connect->sortVars();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -50,19 +50,32 @@ singleton Material(cube_GridMaterial)
|
||||||
mapTo = "GridMaterial";
|
mapTo = "GridMaterial";
|
||||||
|
|
||||||
CustomShaderFeature[0] = FlatColorFeature;
|
CustomShaderFeature[0] = FlatColorFeature;
|
||||||
|
CustomShaderFeatureUniforms[FlatColorFeature,0] = "TestFloat";
|
||||||
};
|
};
|
||||||
|
|
||||||
//--- cube.dae MATERIALS END ---
|
//--- cube.dae MATERIALS END ---
|
||||||
|
|
||||||
//Voodoo!
|
//Voodoo!
|
||||||
function FlatColorFeature::processVert(%this)
|
function FlatColorFeature::processVertHLSL(%this)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function FlatColorFeature::processPixelHLSL(%this)
|
function FlatColorFeature::processPixelHLSL(%this)
|
||||||
{
|
{
|
||||||
%this.writeLine(" float bobsyeruncle = 15.915;");
|
%this.addUniform("strudel", "float2");
|
||||||
|
%this.addSampler("strudelMap");
|
||||||
|
%this.addTexture("strudelTex", "Texture2D", "strudelMap");
|
||||||
|
|
||||||
|
%this.addVariable("bobsyeruncle", "float", 15.915);
|
||||||
|
%this.addVariable("chimmychanga", "float");
|
||||||
|
|
||||||
|
%this.writeLine(" @ = @ * 2;", "chimmychanga", "bobsyeruncle");
|
||||||
|
%this.writeLine(" @ *= @.x;", "bobsyeruncle", "strudel");
|
||||||
|
%this.writeLine(" @ *= @.y;", "chimmychanga", "strudel");
|
||||||
|
|
||||||
|
%this.addVariable("sprangle", "float4");
|
||||||
|
%this.writeLine(" @ = @.Sample(@,@);", "sprangle", "strudelTex", "strudelMap", "strudel");
|
||||||
}
|
}
|
||||||
|
|
||||||
function FlatColorFeature::setTextureResources(%this)
|
function FlatColorFeature::setTextureResources(%this)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue