surface_render.cpp 12.3 KB
Newer Older
Pierre Kraemer's avatar
Pierre Kraemer committed
1 2 3
#include "surface_render.h"

#include "mapHandler.h"
4
#include "slot_debug.h"
Pierre Kraemer's avatar
Pierre Kraemer committed
5 6 7 8 9 10 11

namespace CGoGN
{

namespace SCHNApps
{

Pierre Kraemer's avatar
Pierre Kraemer committed
12
bool Surface_Render_Plugin::enable()
Pierre Kraemer's avatar
Pierre Kraemer committed
13
{
14
	//	magic line that init static variables of GenericMap in the plugins
15
	GenericMap::copyAllStatics(m_schnapps->getStaticPointers());
16

Pierre Kraemer's avatar
Pierre Kraemer committed
17 18
	m_dockTab = new Surface_Render_DockTab(m_schnapps, this);
	m_schnapps->addPluginDockTab(this, m_dockTab, "Surface_Render");
Pierre Kraemer's avatar
Pierre Kraemer committed
19 20 21 22 23

	m_flatShader = new CGoGN::Utils::ShaderFlat();
	m_flatShader->setAmbiant(CGoGN::Geom::Vec4f(0.2f, 0.2f, 0.2f, 0.1f));
	m_flatShader->setExplode(1.0f);

Pierre Kraemer's avatar
Pierre Kraemer committed
24 25 26 27 28 29
	m_phongShader = new CGoGN::Utils::ShaderPhong();
	m_phongShader->setAmbiant(CGoGN::Geom::Vec4f(0.2f, 0.2f, 0.2f, 0.1f));
	m_phongShader->setSpecular(CGoGN::Geom::Vec4f(0.9f, 0.9f, 0.9f, 1.0f));
	m_phongShader->setShininess(80.0f);

	m_colorPerVertexShader = new CGoGN::Utils::ShaderColorPerVertex();
Pierre Kraemer's avatar
Pierre Kraemer committed
30 31 32 33 34 35 36

	m_simpleColorShader = new CGoGN::Utils::ShaderSimpleColor();

	m_pointSprite = new CGoGN::Utils::PointSprite();

	registerShader(m_flatShader);
	registerShader(m_phongShader);
Pierre Kraemer's avatar
Pierre Kraemer committed
37
	registerShader(m_colorPerVertexShader);
Pierre Kraemer's avatar
Pierre Kraemer committed
38 39 40 41 42 43 44
	registerShader(m_simpleColorShader);
	registerShader(m_pointSprite);

	connect(m_schnapps, SIGNAL(selectedViewChanged(View*, View*)), this, SLOT(selectedViewChanged(View*, View*)));
	connect(m_schnapps, SIGNAL(selectedMapChanged(MapHandlerGen*, MapHandlerGen*)), this, SLOT(selectedMapChanged(MapHandlerGen*, MapHandlerGen*)));
	connect(m_schnapps, SIGNAL(mapAdded(MapHandlerGen*)), this, SLOT(mapAdded(MapHandlerGen*)));
	connect(m_schnapps, SIGNAL(mapRemoved(MapHandlerGen*)), this, SLOT(mapRemoved(MapHandlerGen*)));
45
	connect(m_schnapps, SIGNAL(schnappsClosing()), this, SLOT(schnappsClosing()));
Pierre Kraemer's avatar
Pierre Kraemer committed
46 47 48 49 50 51 52 53 54

	foreach(MapHandlerGen* map, m_schnapps->getMapSet().values())
		mapAdded(map);

	m_dockTab->updateMapParameters();

	return true;
}

Pierre Kraemer's avatar
Pierre Kraemer committed
55
void Surface_Render_Plugin::disable()
Pierre Kraemer's avatar
Pierre Kraemer committed
56 57 58 59 60 61
{
	delete m_flatShader;
	delete m_phongShader;
	delete m_simpleColorShader;
	delete m_pointSprite;

62 63 64 65
	disconnect(m_schnapps, SIGNAL(selectedViewChanged(View*, View*)), this, SLOT(selectedViewChanged(View*, View*)));
	disconnect(m_schnapps, SIGNAL(selectedMapChanged(MapHandlerGen*, MapHandlerGen*)), this, SLOT(selectedMapChanged(MapHandlerGen*, MapHandlerGen*)));
	disconnect(m_schnapps, SIGNAL(mapAdded(MapHandlerGen*)), this, SLOT(mapAdded(MapHandlerGen*)));
	disconnect(m_schnapps, SIGNAL(mapRemoved(MapHandlerGen*)), this, SLOT(mapRemoved(MapHandlerGen*)));
66
	disconnect(m_schnapps, SIGNAL(schnappsClosing()), this, SLOT(schnappsClosing()));
67

Pierre Kraemer's avatar
Pierre Kraemer committed
68 69 70 71
	foreach(MapHandlerGen* map, m_schnapps->getMapSet().values())
		mapRemoved(map);
}

Pierre Kraemer's avatar
Pierre Kraemer committed
72
void Surface_Render_Plugin::drawMap(View* view, MapHandlerGen* map)
Pierre Kraemer's avatar
Pierre Kraemer committed
73
{
74 75
	const MapParameters& p = h_viewParameterSet[view][map];
	if(p.positionVBO)
Pierre Kraemer's avatar
Pierre Kraemer committed
76
	{
sylvain thery's avatar
sylvain thery committed
77 78 79 80 81 82 83 84 85
        if(p.renderFaces)
        {
            glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
            glEnable(GL_LIGHTING);
            glEnable(GL_POLYGON_OFFSET_FILL);
            glPolygonOffset(1.0f, 1.0f);
            switch(p.faceStyle)
            {
                case MapParameters::FLAT :
Pierre Kraemer's avatar
Pierre Kraemer committed
86 87 88 89 90 91 92 93 94 95 96 97
					if(p.colorVBO)
					{
						m_colorPerVertexShader->setAttributePosition(p.positionVBO);
						m_colorPerVertexShader->setAttributeColor(p.colorVBO);
						map->draw(m_colorPerVertexShader, CGoGN::Algo::Render::GL2::TRIANGLES);
					}
					else
					{
						m_flatShader->setAttributePosition(p.positionVBO);
						m_flatShader->setDiffuse(p.diffuseColor);
						map->draw(m_flatShader, CGoGN::Algo::Render::GL2::TRIANGLES);
					}
sylvain thery's avatar
sylvain thery committed
98 99 100 101 102 103 104 105 106 107 108 109 110
                    break;
                case MapParameters::PHONG :
                    if(p.normalVBO != NULL)
                    {
                        m_phongShader->setAttributePosition(p.positionVBO);
                        m_phongShader->setAttributeNormal(p.normalVBO);
                        m_phongShader->setDiffuse(p.diffuseColor);
                        map->draw(m_phongShader, CGoGN::Algo::Render::GL2::TRIANGLES);
                    }
                    break;
            }
            glDisable(GL_POLYGON_OFFSET_FILL);
        }
Pierre Kraemer's avatar
Pierre Kraemer committed
111 112

		if(p.renderVertices)
Pierre Kraemer's avatar
Pierre Kraemer committed
113
		{
114 115
			m_pointSprite->setSize(map->getBBdiagSize() / 200.0f * p.verticesScaleFactor);
			m_pointSprite->setAttributePosition(p.positionVBO);
116
			m_pointSprite->setColor(p.vertexColor);
117 118
			map->draw(m_pointSprite, CGoGN::Algo::Render::GL2::POINTS);
		}
Pierre Kraemer's avatar
Pierre Kraemer committed
119

120 121 122 123
		if(p.renderEdges)
		{
			glLineWidth(1.0f);
			m_simpleColorShader->setAttributePosition(p.positionVBO);
124
			m_simpleColorShader->setColor(p.simpleColor);
125 126
			map->draw(m_simpleColorShader, CGoGN::Algo::Render::GL2::LINES);
		}
sylvain thery's avatar
sylvain thery committed
127

128 129 130 131 132 133 134 135
		if(p.renderBoundary)
		{
			glLineWidth(5.0f);
			CGoGN::Geom::Vec4f c(0.8f, 0.8f, 0.1f, 1.0f);
			m_simpleColorShader->setColor(c);
			m_simpleColorShader->setAttributePosition(p.positionVBO);
			map->draw(m_simpleColorShader, CGoGN::Algo::Render::GL2::BOUNDARY);
		}
Pierre Kraemer's avatar
Pierre Kraemer committed
136 137 138 139 140 141 142
	}
}





Pierre Kraemer's avatar
Pierre Kraemer committed
143
void Surface_Render_Plugin::selectedViewChanged(View *prev, View *cur)
Pierre Kraemer's avatar
Pierre Kraemer committed
144
{
145
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
146 147 148
	m_dockTab->updateMapParameters();
}

Pierre Kraemer's avatar
Pierre Kraemer committed
149
void Surface_Render_Plugin::selectedMapChanged(MapHandlerGen *prev, MapHandlerGen *cur)
Pierre Kraemer's avatar
Pierre Kraemer committed
150
{
151
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
152 153 154
	m_dockTab->updateMapParameters();
}

Pierre Kraemer's avatar
Pierre Kraemer committed
155
void Surface_Render_Plugin::mapAdded(MapHandlerGen *map)
Pierre Kraemer's avatar
Pierre Kraemer committed
156
{
157
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
158 159 160 161
	connect(map, SIGNAL(vboAdded(Utils::VBO*)), this, SLOT(vboAdded(Utils::VBO*)));
	connect(map, SIGNAL(vboRemoved(Utils::VBO*)), this, SLOT(vboRemoved(Utils::VBO*)));
}

Pierre Kraemer's avatar
Pierre Kraemer committed
162
void Surface_Render_Plugin::mapRemoved(MapHandlerGen *map)
Pierre Kraemer's avatar
Pierre Kraemer committed
163
{
164
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
165 166 167 168 169 170 171 172
	disconnect(map, SIGNAL(vboAdded(Utils::VBO*)), this, SLOT(vboAdded(Utils::VBO*)));
	disconnect(map, SIGNAL(vboRemoved(Utils::VBO*)), this, SLOT(vboRemoved(Utils::VBO*)));
}





Pierre Kraemer's avatar
Pierre Kraemer committed
173
void Surface_Render_Plugin::vboAdded(Utils::VBO *vbo)
Pierre Kraemer's avatar
Pierre Kraemer committed
174
{
175
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
176 177 178 179 180 181 182 183
	MapHandlerGen* map = static_cast<MapHandlerGen*>(QObject::sender());

	if(map == m_schnapps->getSelectedMap())
	{
		if(vbo->dataSize() == 3)
		{
			m_dockTab->addPositionVBO(QString::fromStdString(vbo->name()));
			m_dockTab->addNormalVBO(QString::fromStdString(vbo->name()));
Pierre Kraemer's avatar
Pierre Kraemer committed
184
			m_dockTab->addColorVBO(QString::fromStdString(vbo->name()));
Pierre Kraemer's avatar
Pierre Kraemer committed
185 186 187 188
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
189
void Surface_Render_Plugin::vboRemoved(Utils::VBO *vbo)
Pierre Kraemer's avatar
Pierre Kraemer committed
190
{
191
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
192 193 194 195 196 197 198 199
	MapHandlerGen* map = static_cast<MapHandlerGen*>(QObject::sender());

	if(map == m_schnapps->getSelectedMap())
	{
		if(vbo->dataSize() == 3)
		{
			m_dockTab->removePositionVBO(QString::fromStdString(vbo->name()));
			m_dockTab->removeNormalVBO(QString::fromStdString(vbo->name()));
Pierre Kraemer's avatar
Pierre Kraemer committed
200
			m_dockTab->removeColorVBO(QString::fromStdString(vbo->name()));
Pierre Kraemer's avatar
Pierre Kraemer committed
201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221
		}
	}

	QSet<View*> viewsToUpdate;

	QHash<View*, QHash<MapHandlerGen*, MapParameters> >::iterator i;
	for (i = h_viewParameterSet.begin(); i != h_viewParameterSet.end(); ++i)
	{
		View* view = i.key();
		QHash<MapHandlerGen*, MapParameters>& viewParamSet = i.value();
		MapParameters& mapParam = viewParamSet[map];
		if(mapParam.positionVBO == vbo)
		{
			mapParam.positionVBO = NULL;
			if(view->isLinkedToMap(map)) viewsToUpdate.insert(view);
		}
		if(mapParam.normalVBO == vbo)
		{
			mapParam.normalVBO = NULL;
			if(view->isLinkedToMap(map)) viewsToUpdate.insert(view);
		}
Pierre Kraemer's avatar
Pierre Kraemer committed
222 223 224 225 226
		if(mapParam.colorVBO == vbo)
		{
			mapParam.colorVBO = NULL;
			if(view->isLinkedToMap(map)) viewsToUpdate.insert(view);
		}
Pierre Kraemer's avatar
Pierre Kraemer committed
227 228 229 230 231 232 233 234 235 236
	}

	foreach(View* v, viewsToUpdate)
		v->updateGL();
}





Pierre Kraemer's avatar
Pierre Kraemer committed
237
void Surface_Render_Plugin::changePositionVBO(const QString& view, const QString& map, const QString& vbo)
Pierre Kraemer's avatar
Pierre Kraemer committed
238
{
239
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
240 241 242 243 244 245 246 247 248 249 250 251 252 253
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		Utils::VBO* vbuf = m->getVBO(vbo);
		h_viewParameterSet[v][m].positionVBO = vbuf;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
254
void Surface_Render_Plugin::changeNormalVBO(const QString& view, const QString& map, const QString& vbo)
Pierre Kraemer's avatar
Pierre Kraemer committed
255
{
256
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
257 258 259 260 261 262 263 264 265 266
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		Utils::VBO* vbuf = m->getVBO(vbo);
		h_viewParameterSet[v][m].normalVBO = vbuf;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
Pierre Kraemer's avatar
Pierre Kraemer committed
267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283
		}
	}
}

void Surface_Render_Plugin::changeColorVBO(const QString& view, const QString& map, const QString& vbo)
{
	DEBUG_SLOT();
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		Utils::VBO* vbuf = m->getVBO(vbo);
		h_viewParameterSet[v][m].colorVBO = vbuf;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
Pierre Kraemer's avatar
Pierre Kraemer committed
284 285 286 287
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
288
void Surface_Render_Plugin::changeRenderVertices(const QString& view, const QString& map, bool b)
Pierre Kraemer's avatar
Pierre Kraemer committed
289
{
290
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
291 292 293 294 295 296 297 298 299 300 301 302 303
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].renderVertices = b;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
304
void Surface_Render_Plugin::changeVerticesScaleFactor(const QString& view, const QString& map, float f)
Pierre Kraemer's avatar
Pierre Kraemer committed
305
{
306
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
307 308 309 310 311 312 313 314 315 316 317 318 319
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].verticesScaleFactor = f;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
320
void Surface_Render_Plugin::changeRenderEdges(const QString& view, const QString& map, bool b)
Pierre Kraemer's avatar
Pierre Kraemer committed
321
{
322
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
323 324 325 326 327 328 329 330 331 332 333 334 335
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].renderEdges = b;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

Pierre Kraemer's avatar
Pierre Kraemer committed
336
void Surface_Render_Plugin::changeRenderFaces(const QString& view, const QString& map, bool b)
Pierre Kraemer's avatar
Pierre Kraemer committed
337
{
338
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
339 340 341 342 343 344 345 346 347 348 349 350 351
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].renderFaces = b;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

Sylvain Thery's avatar
Sylvain Thery committed
352
void Surface_Render_Plugin::changeFacesStyle(const QString& view, const QString& map, int iStyle)
Pierre Kraemer's avatar
Pierre Kraemer committed
353
{
Sylvain Thery's avatar
Sylvain Thery committed
354
	MapParameters::FaceShadingStyle style = MapParameters::FaceShadingStyle(iStyle);
355
	DEBUG_SLOT();
Pierre Kraemer's avatar
Pierre Kraemer committed
356 357 358 359 360 361 362 363 364 365 366 367 368
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].faceStyle = style;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

369 370
void Surface_Render_Plugin::changeRenderBoundary(const QString& view, const QString& map, bool b)
{
371
	DEBUG_SLOT();
372 373 374 375 376 377 378 379 380 381 382 383 384
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].renderBoundary = b;
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

385 386
void Surface_Render_Plugin::changeFaceColor(const QString& view, const QString& map, float r, float g, float b)
{
387
	DEBUG_SLOT();
388 389 390 391 392 393 394 395 396 397 398 399 400 401 402
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].diffuseColor = Geom::Vec4f(r,g,b,0);
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

void Surface_Render_Plugin::changeEdgeColor(const QString& view, const QString& map, float r, float g, float b)
{
403
	DEBUG_SLOT();
404 405 406 407 408 409 410 411 412 413 414 415 416 417 418
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].simpleColor = Geom::Vec4f(r,g,b,0);
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}

void Surface_Render_Plugin::changeVertexColor(const QString& view, const QString& map, float r, float g, float b)
{
419
	DEBUG_SLOT();
420 421 422 423 424 425 426 427 428 429 430 431 432 433
	View* v = m_schnapps->getView(view);
	MapHandlerGen* m = m_schnapps->getMap(map);
	if(v && m)
	{
		h_viewParameterSet[v][m].vertexColor = Geom::Vec4f(r,g,b,0);
		if(v->isSelectedView())
		{
			if(v->isLinkedToMap(m))	v->updateGL();
			if(m->isSelectedMap()) m_dockTab->updateMapParameters();
		}
	}
}


Sylvain Thery's avatar
Sylvain Thery committed
434

435
void Surface_Render_Plugin::schnappsClosing()
Sylvain Thery's avatar
Sylvain Thery committed
436 437 438
{
	m_dockTab->m_colorDial->close();
}
Sylvain Thery's avatar
Sylvain Thery committed
439 440 441 442 443
#if CGOGN_QT_DESIRED_VERSION == 5
	Q_PLUGIN_METADATA(IID "CGoGN.SCHNapps.Plugin")
#else
	Q_EXPORT_PLUGIN2(Surface_Render_Plugin, Surface_Render_Plugin)
#endif
Sylvain Thery's avatar
Sylvain Thery committed
444

Pierre Kraemer's avatar
Pierre Kraemer committed
445 446 447 448

} // namespace SCHNApps

} // namespace CGoGN