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
3ae0e125
Commit
3ae0e125
authored
Nov 29, 2019
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2364 from paroj:ovisup
parents
c9514b80
8f2b705d
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
17 additions
and
19 deletions
+17
-19
ovis.hpp
modules/ovis/include/opencv2/ovis.hpp
+1
-0
ovis.cpp
modules/ovis/src/ovis.cpp
+16
-19
No files found.
modules/ovis/include/opencv2/ovis.hpp
View file @
3ae0e125
...
...
@@ -36,6 +36,7 @@ enum MaterialProperty
MATERIAL_LINE_WIDTH
,
MATERIAL_OPACITY
,
MATERIAL_EMISSIVE
,
MATERIAL_DIFFUSE
,
MATERIAL_TEXTURE0
,
MATERIAL_TEXTURE
=
MATERIAL_TEXTURE0
,
MATERIAL_TEXTURE1
,
...
...
modules/ovis/src/ovis.cpp
View file @
3ae0e125
...
...
@@ -171,6 +171,14 @@ static SceneNode& _getSceneNode(SceneManager* sceneMgr, const String& name)
return
*
mo
->
getParentSceneNode
();
}
static
ColourValue
convertColor
(
const
Scalar
&
val
)
{
// BGR 0..255 (uchar) to RGB 0..1
ColourValue
ret
=
ColourValue
(
val
[
2
],
val
[
1
],
val
[
0
])
/
255
;
ret
.
saturate
();
return
ret
;
}
struct
Application
:
public
OgreBites
::
ApplicationContext
,
public
OgreBites
::
InputListener
{
Ptr
<
LogManager
>
logMgr
;
...
...
@@ -335,11 +343,7 @@ public:
{
camman
.
reset
(
new
OgreBites
::
CameraMan
(
camNode
));
camman
->
setStyle
(
OgreBites
::
CS_ORBIT
);
#if OGRE_VERSION >= ((1 << 16) | (11 << 8) | 5)
camman
->
setFixedYaw
(
false
);
#else
camNode
->
setFixedYawAxis
(
true
,
Vector3
::
NEGATIVE_UNIT_Y
);
// OpenCV +Y in Ogre CS
#endif
}
if
(
!
app
->
sceneMgr
)
...
...
@@ -512,10 +516,7 @@ public:
{
// hide background plane
bgplane
->
setVisible
(
false
);
// BGRA as uchar
ColourValue
_color
=
ColourValue
(
color
[
2
],
color
[
1
],
color
[
0
],
color
[
3
])
/
255
;
rWin
->
getViewport
(
0
)
->
setBackgroundColour
(
_color
);
rWin
->
getViewport
(
0
)
->
setBackgroundColour
(
convertColor
(
color
));
}
void
createEntity
(
const
String
&
name
,
const
String
&
meshname
,
InputArray
tvec
,
InputArray
rot
)
CV_OVERRIDE
...
...
@@ -579,7 +580,6 @@ public:
const
Scalar
&
specularColour
)
CV_OVERRIDE
{
Light
*
light
=
sceneMgr
->
createLight
(
name
);
light
->
setDirection
(
Vector3
::
NEGATIVE_UNIT_Z
);
// convert to BGR
light
->
setDiffuseColour
(
ColourValue
(
diffuseColour
[
2
],
diffuseColour
[
1
],
diffuseColour
[
0
]));
light
->
setSpecularColour
(
ColourValue
(
specularColour
[
2
],
specularColour
[
1
],
specularColour
[
0
]));
...
...
@@ -838,9 +838,7 @@ public:
void
fixCameraYawAxis
(
bool
useFixed
,
InputArray
_up
)
CV_OVERRIDE
{
#if OGRE_VERSION >= ((1 << 16) | (11 << 8) | 5)
if
(
camman
)
camman
->
setFixedYaw
(
useFixed
);
#endif
Vector3
up
=
Vector3
::
NEGATIVE_UNIT_Y
;
if
(
!
_up
.
empty
())
...
...
@@ -977,8 +975,8 @@ void setMaterialProperty(const String& name, int prop, const Scalar& val)
CV_Assert
(
mat
);
Pass
*
rpass
=
mat
->
getTechniques
()[
0
]
->
getPasses
()[
0
];
ColourValue
col
;
ColourValue
col
;
switch
(
prop
)
{
case
MATERIAL_POINT_SIZE
:
...
...
@@ -991,17 +989,16 @@ void setMaterialProperty(const String& name, int prop, const Scalar& val)
rpass
->
setSceneBlending
(
SBT_TRANSPARENT_ALPHA
);
rpass
->
setDepthWriteEnabled
(
false
);
break
;
case
MATERIAL_DIFFUSE
:
col
=
convertColor
(
val
);
col
.
a
=
rpass
->
getDiffuse
().
a
;
rpass
->
setDiffuse
(
col
);
break
;
case
MATERIAL_EMISSIVE
:
col
=
ColourValue
(
val
[
2
],
val
[
1
],
val
[
0
])
/
255
;
// BGR as uchar
col
.
saturate
();
rpass
->
setEmissive
(
col
);
rpass
->
setEmissive
(
convertColor
(
val
));
break
;
case
MATERIAL_LINE_WIDTH
:
#if OGRE_VERSION >= ((1 << 16) | (11 << 8) | 2)
rpass
->
setLineWidth
(
val
[
0
]);
#else
CV_Error
(
Error
::
StsError
,
"needs OGRE 1.11.2+ for this"
);
#endif
break
;
default
:
CV_Error
(
Error
::
StsBadArg
,
"invalid or non Scalar property"
);
...
...
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