本文整理汇总了C++中IAction::DoTask方法的典型用法代码示例。如果您正苦于以下问题:C++ IAction::DoTask方法的具体用法?C++ IAction::DoTask怎么用?C++ IAction::DoTask使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IAction
的用法示例。
在下文中一共展示了IAction::DoTask方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
//.........这里部分代码省略.........
IFileFormat* format = NULL;
std::string formatString = outputFormatFileArg.getValue();
if (formatString == "TGA")
{
format = new TGAFile;
}
else if (formatString == "DDS")
{
format = new DDSFile;
}
else if (formatString == "PNG")
{
format = new PNGFile;
}
else
{
printf("Error: Wrong output format!\n");
return 0;
}
int outputWidth = inputTex->m_width;
int outputHeight = inputTex->m_height;
IAction* action = NULL;
std::string actionString = actionLable.getValue();
if (actionString == "cube2sphere")
{
outputWidth *= 4;
outputHeight *= 4;
CubeMap2Sphere* cube2s = new CubeMap2Sphere;
cube2s->m_doNotRemoveOuterAreas = doNotRemoveOuterAreaFlag.getValue();
action = cube2s;
}
else if (actionString == "sphere2cube")
{
outputWidth /= 4;
outputHeight /= 4;
action = new Sphere2CubeMap;
}
else if (actionString == "blurCubemap")
{
BlurCubemap* blur = new BlurCubemap;
blur->m_blurQuality = blurQualityArg.getValue();
blur->m_blurRadius = blurRadiusArg.getValue();
action = blur;
}
else if (actionString == "fastBlurCubemap")
{
FastBlurCubemap* blur = new FastBlurCubemap;
blur->m_blurRadius = blurRadiusArg.getValue();
action = blur;
}
else if (actionString == "convert")
{
action = new DummyAction;
}
else
{
printf("Error: Wrong action!\n");
return 0;
}
outputTex->m_width = outputWidthArg.isSet() ? outputWidthArg.getValue() : outputWidth;
outputTex->m_height = outputHeightArg.isSet() ? outputHeightArg.getValue() : outputHeight;
action->DoTask(*inputTex, *outputTex);
if ( outputFileArg.isSet() )
{
int face = 0;
if(outputTex->m_cubemap)
{
face = faceToWriteArg.getValue();
face = face > 5 ? 5 : face;
face = face < 0 ? 0 : face;
}
outputTex->SaveToFile(outputFileArg.getValue().c_str(), format, face);
}
else if ( outputMultiFileArg.isSet() )
{
if(!outputTex->m_cubemap)
{
printf("Error: Can't output not a cube map to a sequence of files.\n");
return 0;
}
std::vector<std::string> files = outputMultiFileArg.getValue();
if(files.size() != 6)
{
printf("Error: You should specify exactly six output files.\n");
return 0;
}
int face = 0;
for(std::vector<std::string>::iterator it = files.begin(); it != files.end(); ++it)
{
outputTex->SaveToFile(it->c_str(), format, face);
face++;
}
}
return 0;
}