Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
2c0eb14f
Commit
2c0eb14f
authored
Feb 11, 2018
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1548 from paroj:ovisup
parents
d0998725
faf82d88
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
99 additions
and
8 deletions
+99
-8
ovis.hpp
modules/ovis/include/opencv2/ovis.hpp
+14
-2
ovis.cpp
modules/ovis/src/ovis.cpp
+85
-6
No files found.
modules/ovis/include/opencv2/ovis.hpp
View file @
2c0eb14f
...
@@ -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
*
*
...
...
modules/ovis/src/ovis.cpp
View file @
2c0eb14f
...
@@ -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
()));
}
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment