Commit 2c0eb14f authored by Alexander Alekhin's avatar Alexander Alekhin

Merge pull request #1548 from paroj:ovisup

parents d0998725 faf82d88
...@@ -23,7 +23,11 @@ enum SceneSettings ...@@ -23,7 +23,11 @@ enum SceneSettings
/// allow the user to control the camera. /// allow the user to control the camera.
SCENE_INTERACTIVE = 2, SCENE_INTERACTIVE = 2,
/// draw coordinate system crosses for debugging /// draw coordinate system crosses for debugging
SCENE_SHOW_CS_CROSS = 4 SCENE_SHOW_CS_CROSS = 4,
/// @ref WindowScene::getScreenshot returns images as CV_32FC4 instead of CV_8UC3
SCENE_RENDER_FLOAT = 8,
/// Apply anti-aliasing. The first window determines the setting for all windows.
SCENE_AA = 16
}; };
enum MaterialProperty enum MaterialProperty
...@@ -178,7 +182,7 @@ CV_EXPORTS_W void addResourceLocation(const String& path); ...@@ -178,7 +182,7 @@ CV_EXPORTS_W void addResourceLocation(const String& path);
* @param flags a combination of @ref SceneSettings * @param flags a combination of @ref SceneSettings
*/ */
CV_EXPORTS_W Ptr<WindowScene> createWindow(const String& title, const Size& size, CV_EXPORTS_W Ptr<WindowScene> createWindow(const String& title, const Size& size,
int flags = SCENE_INTERACTIVE); int flags = SCENE_INTERACTIVE | SCENE_AA);
/** /**
* update all windows and wait for keyboard event * update all windows and wait for keyboard event
...@@ -200,6 +204,14 @@ CV_EXPORTS_W void setMaterialProperty(const String& name, int prop, const Scalar ...@@ -200,6 +204,14 @@ CV_EXPORTS_W void setMaterialProperty(const String& name, int prop, const Scalar
/// @overload /// @overload
CV_EXPORTS_W void setMaterialProperty(const String& name, int prop, const String& value); CV_EXPORTS_W void setMaterialProperty(const String& name, int prop, const String& value);
/**
* set the shader property of a material to the given value
* @param name material name
* @param prop property name
* @param value the value
*/
CV_EXPORTS_W void setMaterialProperty(const String& name, const String& prop, const Scalar& value);
/** /**
* create a 2D plane, X right, Y down, Z up * create a 2D plane, X right, Y down, Z up
* *
......
...@@ -144,10 +144,11 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp ...@@ -144,10 +144,11 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp
uint32_t w; uint32_t w;
uint32_t h; uint32_t h;
int key_pressed; int key_pressed;
int flags;
Application(const Ogre::String& _title, const Size& sz) Application(const Ogre::String& _title, const Size& sz, int _flags)
: OgreBites::ApplicationContext("ovis", false), sceneMgr(NULL), title(_title), w(sz.width), : OgreBites::ApplicationContext("ovis", false), sceneMgr(NULL), title(_title), w(sz.width),
h(sz.height), key_pressed(-1) h(sz.height), key_pressed(-1), flags(_flags)
{ {
logMgr.reset(new LogManager()); logMgr.reset(new LogManager());
logMgr->createLog("ovis.log", true, true, true); logMgr->createLog("ovis.log", true, true, true);
...@@ -183,7 +184,10 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp ...@@ -183,7 +184,10 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp
_h = h; _h = h;
_name = title; _name = title;
} }
if (flags & SCENE_AA)
miscParams["FSAA"] = "4"; miscParams["FSAA"] = "4";
miscParams["vsync"] = "true"; miscParams["vsync"] = "true";
OgreBites::NativeWindowPair ret = OgreBites::NativeWindowPair ret =
...@@ -233,6 +237,8 @@ class WindowSceneImpl : public WindowScene ...@@ -233,6 +237,8 @@ class WindowSceneImpl : public WindowScene
Ptr<OgreBites::CameraMan> camman; Ptr<OgreBites::CameraMan> camman;
Ptr<Rectangle2D> bgplane; Ptr<Rectangle2D> bgplane;
Ogre::RenderTarget* frameSrc;
public: public:
WindowSceneImpl(Ptr<Application> app, const String& _title, const Size& sz, int flags) WindowSceneImpl(Ptr<Application> app, const String& _title, const Size& sz, int flags)
: title(_title), root(app->getRoot()) : title(_title), root(app->getRoot())
...@@ -289,6 +295,18 @@ public: ...@@ -289,6 +295,18 @@ public:
} }
rWin->addViewport(cam); rWin->addViewport(cam);
frameSrc = rWin;
if (flags & SCENE_RENDER_FLOAT)
{
// also render into an offscreen texture
// currently this draws everything twice, but we spare the float->byte conversion for display
TexturePtr tex = TextureManager::getSingleton().createManual(
title + "_rt", RESOURCEGROUP_NAME, TEX_TYPE_2D, sz.width, sz.height, 0, PF_FLOAT32_RGBA,
TU_RENDERTARGET);
frameSrc = tex->getBuffer()->getRenderTarget();
frameSrc->addViewport(cam);
}
} }
void setBackground(InputArray image) void setBackground(InputArray image)
...@@ -421,11 +439,17 @@ public: ...@@ -421,11 +439,17 @@ public:
void getScreenshot(OutputArray frame) void getScreenshot(OutputArray frame)
{ {
frame.create(rWin->getHeight(), rWin->getWidth(), CV_8UC3); PixelFormat src_type = frameSrc->suggestPixelFormat();
int dst_type = src_type == PF_BYTE_RGB ? CV_8UC3 : CV_32FC4;
frame.create(frameSrc->getHeight(), frameSrc->getWidth(), dst_type);
Mat out = frame.getMat(); Mat out = frame.getMat();
PixelBox pb(rWin->getWidth(), rWin->getHeight(), 1, PF_BYTE_BGR, out.ptr()); PixelBox pb(frameSrc->getWidth(), frameSrc->getHeight(), 1, src_type, out.ptr());
rWin->copyContentsToMemory(pb, pb); frameSrc->copyContentsToMemory(pb, pb);
// convert to OpenCV channel order
cvtColor(out, out, dst_type == CV_8UC3 ? COLOR_RGB2BGR : COLOR_RGBA2BGRA);
} }
void fixCameraYawAxis(bool useFixed, InputArray _up) void fixCameraYawAxis(bool useFixed, InputArray _up)
...@@ -519,7 +543,7 @@ Ptr<WindowScene> createWindow(const String& title, const Size& size, int flags) ...@@ -519,7 +543,7 @@ Ptr<WindowScene> createWindow(const String& title, const Size& size, int flags)
{ {
if (!_app) if (!_app)
{ {
_app = makePtr<Application>(title.c_str(), size); _app = makePtr<Application>(title.c_str(), size, flags);
_app->initApp(); _app->initApp();
} }
...@@ -591,5 +615,60 @@ void setMaterialProperty(const String& name, int prop, const String& value) ...@@ -591,5 +615,60 @@ void setMaterialProperty(const String& name, int prop, const String& value)
rpass->getTextureUnitStates()[0]->setTextureName(value); rpass->getTextureUnitStates()[0]->setTextureName(value);
} }
static bool setShaderProperty(const GpuProgramParametersSharedPtr& params, const String& prop,
const Scalar& value)
{
const GpuConstantDefinition* def = params->_findNamedConstantDefinition(prop, false);
if(!def)
return false;
Vec4f valf = value;
switch(def->constType)
{
case GCT_FLOAT1:
params->setNamedConstant(prop, valf[0]);
return true;
case GCT_FLOAT2:
params->setNamedConstant(prop, Vector2(valf.val));
return true;
case GCT_FLOAT3:
params->setNamedConstant(prop, Vector3(valf.val));
return true;
case GCT_FLOAT4:
params->setNamedConstant(prop, Vector4(valf.val));
return true;
default:
CV_Error(Error::StsBadArg, "currently only float[1-4] uniforms are supported");
return false;
}
}
void setMaterialProperty(const String& name, const String& prop, const Scalar& value)
{
CV_Assert(_app);
MaterialPtr mat = MaterialManager::getSingleton().getByName(name, RESOURCEGROUP_NAME);
CV_Assert(mat);
Pass* rpass = mat->getTechniques()[0]->getPasses()[0];
bool set = false;
if(rpass->hasGpuProgram(GPT_VERTEX_PROGRAM))
{
GpuProgramParametersSharedPtr params = rpass->getVertexProgramParameters();
set = setShaderProperty(params, prop, value);
}
if(rpass->hasGpuProgram(GPT_FRAGMENT_PROGRAM))
{
GpuProgramParametersSharedPtr params = rpass->getFragmentProgramParameters();
set = set || setShaderProperty(params, prop, value);
}
if(!set)
CV_Error_(Error::StsBadArg, ("shader parameter named '%s' not found", prop.c_str()));
}
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment