1 #include <Engine/Rendering/RenderObject.hpp>
3 #include <Engine/RadiumEngine.hpp>
5 #include <Engine/Data/DisplayableObject.hpp>
6 #include <Engine/Data/Material.hpp>
7 #include <Engine/Data/RenderParameters.hpp>
8 #include <Engine/OpenGL.hpp>
9 #include <Engine/Rendering/RenderObjectManager.hpp>
10 #include <Engine/Scene/Component.hpp>
14 #include <Engine/Scene/Entity.hpp>
16 #include <Core/Containers/MakeShared.hpp>
17 #include <Engine/Data/BlinnPhongMaterial.hpp>
18 #include <Engine/Data/ShaderProgram.hpp>
19 #include <Engine/Data/SimpleMaterial.hpp>
20 #include <Engine/Data/ViewingParameters.hpp>
28 const RenderObjectType& type,
35 m_lifetime { lifetime },
36 m_hasLifetime { lifetime > 0 } {}
38 RenderObject::~RenderObject() {
40 m_mesh->getAbstractGeometry().getAabbObservable().detach( m_aabbObserverIndex );
46 const RenderObjectType& type,
47 std::shared_ptr<Data::Displayable> mesh,
51 obj->setVisible(
true );
52 auto rt = Core::make_shared<RenderTechnique>( techniqueConfig );
53 obj->setRenderTechnique( rt );
59 std::lock_guard<std::mutex> lock( m_updateMutex );
61 if ( m_renderTechnique ) { m_renderTechnique->updateGL(); }
63 if ( m_mesh ) { m_mesh->updateGL(); }
68 const RenderObjectType& RenderObject::getType()
const {
72 void RenderObject::setType(
const RenderObjectType& t ) {
80 void RenderObject::setVisible(
bool visible ) {
84 void RenderObject::toggleVisible() {
85 m_visible = !m_visible;
88 bool RenderObject::isVisible()
const {
92 void RenderObject::setPickable(
bool pickable ) {
93 m_pickable = pickable;
96 void RenderObject::togglePickable() {
97 m_pickable = !m_pickable;
100 bool RenderObject::isPickable()
const {
104 void RenderObject::setXRay(
bool xray ) {
108 void RenderObject::toggleXRay() {
112 bool RenderObject::isXRay()
const {
116 void RenderObject::setTransparent(
bool transparent ) {
117 m_transparent = transparent;
120 void RenderObject::toggleTransparent() {
121 m_transparent = !m_transparent;
124 bool RenderObject::isTransparent()
const {
125 return m_transparent;
129 if ( m_material ) { m_material->setColoredByVertexAttrib( state ); }
134 m_material->setColoredByVertexAttrib( !m_material->isColoredByVertexAttrib() );
139 if ( m_material ) {
return m_material->isColoredByVertexAttrib(); }
143 bool RenderObject::isDirty()
const {
155 void RenderObject::setRenderTechnique( std::shared_ptr<RenderTechnique> technique ) {
156 CORE_ASSERT( technique,
"Passing a nullptr as render technique" );
157 m_renderTechnique = technique;
160 std::shared_ptr<const RenderTechnique> RenderObject::getRenderTechnique()
const {
161 return m_renderTechnique;
164 std::shared_ptr<RenderTechnique> RenderObject::getRenderTechnique() {
165 return m_renderTechnique;
168 void RenderObject::setMaterial( std::shared_ptr<Data::Material> material ) {
169 m_material = material;
172 std::shared_ptr<const Data::Material> RenderObject::getMaterial()
const {
176 std::shared_ptr<Data::Material> RenderObject::getMaterial() {
180 void RenderObject::setMesh( std::shared_ptr<Data::Displayable> mesh ) {
183 m_mesh->getAbstractGeometry().getAabbObservable().detach( m_aabbObserverIndex );
188 m_aabbObserverIndex = m_mesh->getAbstractGeometry().getAabbObservable().attach(
189 [
this]() { this->invalidateAabb(); } );
194 std::shared_ptr<const Data::Displayable> RenderObject::getMesh()
const {
198 const std::shared_ptr<Data::Displayable>& RenderObject::getMesh() {
202 Core::Transform RenderObject::getTransform()
const {
203 return m_component->
getEntity()->getTransform() * m_localTransform;
206 Core::Matrix4 RenderObject::getTransformAsMatrix()
const {
207 return getTransform().matrix();
210 Core::Aabb RenderObject::computeAabb() {
211 if ( !m_isAabbValid ) {
212 auto aabb = m_mesh->getAbstractGeometry().computeAabb();
213 if ( !aabb.isEmpty() ) {
216 for (
int i = 0; i < 8; ++i ) {
217 result.extend( getTransform() * aabb.corner( Core::Aabb::CornerType( i ) ) );
221 m_isAabbValid =
true;
225 m_isAabbValid =
true;
232 void RenderObject::setLocalTransform(
const Core::Transform& transform ) {
233 m_localTransform = transform;
237 void RenderObject::setLocalTransform(
const Core::Matrix4& transform ) {
238 m_localTransform = Core::Transform( transform );
242 const Core::Transform& RenderObject::getLocalTransform()
const {
243 return m_localTransform;
246 const Core::Matrix4& RenderObject::getLocalTransformAsMatrix()
const {
247 return m_localTransform.matrix();
251 if ( m_hasLifetime ) {
252 if ( --m_lifetime <= 0 ) {
253 RadiumEngine::getInstance()->getRenderObjectManager()->renderObjectExpired(
m_idx );
259 m_component->notifyRenderObjectExpired(
m_idx );
264 m_hasLifetime =
true;
271 if ( !m_visible || !shader ) {
return; }
273 Core::Matrix4 modelMatrix = getTransformAsMatrix();
274 Core::Matrix4 normalMatrix = modelMatrix.inverse().transpose();
277 shader->
setUniform(
"transform.proj", viewParams.projMatrix );
278 shader->
setUniform(
"transform.view", viewParams.viewMatrix );
279 shader->
setUniform(
"transform.model", modelMatrix );
280 shader->
setUniform(
"transform.worldNormal", normalMatrix );
281 lightParams.
bind( shader );
282 shaderParams.
bind( shader );
286 if ( viewParams.viewMatrix.determinant() < 0 ) { glFrontFace( GL_CW ); }
287 else { glFrontFace( GL_CCW ); }
288 m_mesh->render( shader );
293 Core::Utils::Index passId ) {
295 auto shader = getRenderTechnique()->getShader( passId );
296 if ( !shader ) {
return; }
298 auto paramsProvider = getRenderTechnique()->getParametersProvider( passId );
300 if ( paramsProvider !=
nullptr ) {
301 render( lightParams, viewParams, shader, paramsProvider->getParameters() );
303 else {
render( lightParams, viewParams, shader, {} ); }
307 void RenderObject::invalidateAabb() {
308 m_isAabbValid =
false;
309 m_component->invalidateAabb();
void bind(const Data::ShaderProgram *shader) const
void setUniform(const char *name, const T &value) const
Uniform setters.
void hasBeenRenderedOnce()
void render(const Data::RenderParameters &lightParams, const Data::ViewingParameters &viewParams, const Data::ShaderProgram *shader, const Data::RenderParameters &shaderParams)
bool isColoredByVertexAttrib() const
manage usage of VERTEX_COLOR attribute by the material
void toggleColoredByVertexAttrib()
manage usage of VERTEX_COLOR attribute by the material
void setLifetime(int t)
Set a lifetime to an existing RenderObject.
const std::string & getName() const
EIGEN_MAKE_ALIGNED_OPERATOR_NEW RenderObject(const std::string &name, Scene::Component *comp, const RenderObjectType &type, int lifetime=-1)
void hasExpired()
Notify component that the render object has expired.
void setColoredByVertexAttrib(bool state)
manage usage of VERTEX_COLOR attribute by the material
static RenderObject * createRenderObject(const std::string &name, Scene::Component *comp, const RenderObjectType &type, std::shared_ptr< Data::Displayable > mesh, const RenderTechnique &techniqueConfig=RenderTechnique::createDefaultRenderTechnique())
A component is an element that can be updated by a system. It is also linked to some other components...
virtual Entity * getEntity() const
Return the entity the component belongs to.
the set of viewing parameters extracted from the camera and given to the renderer