Files
ResInsight/Fwk/VizFwk/Tests/SnippetsBasis/snipMultiRenderingEffectOverride.cpp
sigurdp bbebebadd5 Added complete VizFwk
Added the complete VizFwk from the ResInsight branch in Perforce as of
changelist 190.
2013-11-01 08:49:42 +01:00

257 lines
8.1 KiB
C++

//##################################################################################################
//
// Custom Visualization Core library
// Copyright (C) 2011-2013 Ceetron AS
//
// This library may be used under the terms of either the GNU General Public License or
// the GNU Lesser General Public License as follows:
//
// GNU General Public License Usage
// This library is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This library is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.
//
// See the GNU General Public License at <<http://www.gnu.org/licenses/gpl.html>>
// for more details.
//
// GNU Lesser General Public License Usage
// This library is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation; either version 2.1 of the License, or
// (at your option) any later version.
//
// This library is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.
//
// See the GNU Lesser General Public License at <<http://www.gnu.org/licenses/lgpl-2.1.html>>
// for more details.
//
//##################################################################################################
#include "cvfLibCore.h"
#include "cvfLibRender.h"
#include "cvfLibViewing.h"
#include "snipMultiRenderingEffectOverride.h"
#include "cvfuInputEvents.h"
#include "cvfuPartCompoundGenerator.h"
namespace snip {
const unsigned int redBit = 0x00000001;
const unsigned int greenBit = 0x00000002;
const unsigned int blueBit = 0x00000004;
const unsigned int yellowBit= 0x00000008;
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
bool MultiRenderingEffectOverride::onInitialize()
{
PartCompoundGenerator gen;
gen.setPartDistribution(Vec3i(5, 5, 5));
gen.setNumEffects(1);
gen.useRandomEffectAssignment(false);
gen.setExtent(Vec3f(3,3,3));
gen.setOrigin(Vec3f(-1.5f, -1.5f, -1.5f));
Collection<Part> parts;
gen.generateSpheres(20, 20, &parts);
ref<Effect> e1 = new Effect;
ref<Effect> e2 = new Effect;
ref<Effect> e3 = new Effect;
ref<Effect> e4 = new Effect;
e1->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::PURE_RED));
e2->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::PURE_GREEN));
e3->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::PURE_BLUE));
e4->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::PURE_YELLOW));
Collection<Effect> effs;
effs.push_back(e1.p());
effs.push_back(e2.p());
effs.push_back(e3.p());
effs.push_back(e4.p());
size_t numEffects = effs.size();
ref<ModelBasicList> myModel = new ModelBasicList;
size_t i;
for (i = 0; i < parts.size(); i++)
{
Part* part = parts[i].p();
size_t effectIdx = i % numEffects;
Effect* e = effs.at(effectIdx);
part->setEffect(e);
unsigned int mask = 0xffffffff;
if (effectIdx == 0) mask = redBit;
else if (effectIdx == 1) mask = greenBit;
else if (effectIdx == 2) mask = blueBit;
else if (effectIdx == 3) mask = yellowBit;
part->setEnableMask(mask);
myModel->addPart(part);
}
myModel->updateBoundingBoxesRecursive();
m_renderSequence->rendering(0)->scene()->addModel(myModel.p());
BoundingBox bb = myModel->boundingBox();
if (bb.isValid())
{
m_camera->fitView(bb, Vec3d::Y_AXIS, Vec3d::Z_AXIS);
}
return true;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void MultiRenderingEffectOverride::toggleOverrideEffectInMainRendering()
{
Rendering* mainRendering = m_renderSequence->firstRendering();
if (!mainRendering) return;
if (m_eff1.isNull())
{
m_eff1 = new Effect;
m_eff1->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::POLISHED_COPPER));
}
if (mainRendering->effectOverride())
{
mainRendering->setEffectOverride(NULL);
}
else
{
mainRendering->setEffectOverride(m_eff1.p());
}
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void MultiRenderingEffectOverride::setupRendering2WithOverrideEffect()
{
if (m_eff2.isNull())
{
m_eff2 = new Effect;
m_eff2->setRenderState(new RenderStatePolygonMode(RenderStatePolygonMode::LINE));
m_eff2->setRenderState(new RenderStateMaterial_FF(RenderStateMaterial_FF::PURE_MAGENTA));
RenderStatePolygonOffset* po = new RenderStatePolygonOffset;
po->configureLineNegativeOffset();
m_eff2->setRenderState(po);
}
if (m_rendering2.isNull())
{
m_rendering2 = new Rendering;
m_rendering2->setCamera(m_camera.p());
m_rendering2->setEffectOverride(m_eff2.p());
m_rendering2->setScene(m_renderSequence->rendering(0)->scene());
m_rendering2->setClearMode(Viewport::DO_NOT_CLEAR);
}
m_renderSequence->removeRendering(m_rendering2.p());
m_renderSequence->addRendering(m_rendering2.p());
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void MultiRenderingEffectOverride::onKeyPressEvent(KeyEvent* keyEvent)
{
Key key = keyEvent->key();
Rendering* rendering = m_renderSequence->renderingCount() > 0 ? m_renderSequence->rendering(0) : 0;
Scene* scene = rendering ? rendering->scene() : NULL;
if (!scene) return;
Model* model = scene->modelCount() > 0 ? scene->model(0) : NULL;
if (!model) return;
unsigned int partEnableMask = model->partEnableMask();
unsigned int newPartEnableMask = partEnableMask;
switch (key)
{
case Key_0: newPartEnableMask = 0x00000000; break;
case Key_9: newPartEnableMask = 0xffffffff; break;
case Key_1: newPartEnableMask = toggleBit(partEnableMask, redBit); break;
case Key_2: newPartEnableMask = toggleBit(partEnableMask, greenBit); break;
case Key_3: newPartEnableMask = toggleBit(partEnableMask, blueBit); break;
case Key_4: newPartEnableMask = toggleBit(partEnableMask, yellowBit); break;
default: break;
}
if (newPartEnableMask != partEnableMask)
{
Trace::show("Mask set to 0x%08x", newPartEnableMask);
model->setPartEnableMask(newPartEnableMask);
}
if (key == Key_P)
{
toggleOverrideEffectInMainRendering();
}
if (key == Key_O)
{
if (m_renderSequence->renderingCount() == 1)
{
setupRendering2WithOverrideEffect();
}
else
{
m_renderSequence->removeRendering(m_rendering2.p());
}
}
keyEvent->setRequestedAction(REDRAW);
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
unsigned int MultiRenderingEffectOverride::toggleBit(unsigned int bitfield, unsigned int toggleBit)
{
if (bitfield & toggleBit)
{
bitfield &= ~toggleBit;
}
else
{
bitfield |= toggleBit;
}
return bitfield;
}
} // namespace snip