mirror of
https://github.com/JulianGro/overte.git
synced 2025-07-10 19:57:41 +02:00
fix some bugs in models
This commit is contained in:
parent
f3fb39574f
commit
0ae7411bf0
2 changed files with 124 additions and 74 deletions
|
@ -57,10 +57,10 @@ void ModelTreeRenderer::render(RenderMode renderMode) {
|
||||||
|
|
||||||
const FBXGeometry* ModelTreeRenderer::getGeometryForModel(const ModelItem& modelItem) {
|
const FBXGeometry* ModelTreeRenderer::getGeometryForModel(const ModelItem& modelItem) {
|
||||||
const FBXGeometry* result = NULL;
|
const FBXGeometry* result = NULL;
|
||||||
|
|
||||||
Model* model = getModel(modelItem);
|
Model* model = getModel(modelItem);
|
||||||
if (model) {
|
if (model) {
|
||||||
result = &model->getGeometry()->getFBXGeometry();
|
result = &model->getGeometry()->getFBXGeometry();
|
||||||
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -72,6 +72,14 @@ Model* ModelTreeRenderer::getModel(const ModelItem& modelItem) {
|
||||||
if (_knownModelsItemModels.find(modelItem.getID()) != _knownModelsItemModels.end()) {
|
if (_knownModelsItemModels.find(modelItem.getID()) != _knownModelsItemModels.end()) {
|
||||||
model = _knownModelsItemModels[modelItem.getID()];
|
model = _knownModelsItemModels[modelItem.getID()];
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
// Make sure we only create new models on the thread that owns the ModelTreeRenderer
|
||||||
|
if (QThread::currentThread() != thread()) {
|
||||||
|
QMetaObject::invokeMethod(this, "getModel", Qt::BlockingQueuedConnection,
|
||||||
|
Q_RETURN_ARG(Model*, model), Q_ARG(const ModelItem&, modelItem));
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
model = new Model();
|
model = new Model();
|
||||||
model->init();
|
model->init();
|
||||||
model->setURL(QUrl(modelItem.getModelURL()));
|
model->setURL(QUrl(modelItem.getModelURL()));
|
||||||
|
@ -81,6 +89,13 @@ Model* ModelTreeRenderer::getModel(const ModelItem& modelItem) {
|
||||||
if (_unknownModelsItemModels.find(modelItem.getCreatorTokenID()) != _unknownModelsItemModels.end()) {
|
if (_unknownModelsItemModels.find(modelItem.getCreatorTokenID()) != _unknownModelsItemModels.end()) {
|
||||||
model = _unknownModelsItemModels[modelItem.getCreatorTokenID()];
|
model = _unknownModelsItemModels[modelItem.getCreatorTokenID()];
|
||||||
} else {
|
} else {
|
||||||
|
// Make sure we only create new models on the thread that owns the ModelTreeRenderer
|
||||||
|
if (QThread::currentThread() != thread()) {
|
||||||
|
QMetaObject::invokeMethod(this, "getModel", Qt::BlockingQueuedConnection,
|
||||||
|
Q_RETURN_ARG(Model*, model), Q_ARG(const ModelItem&, modelItem));
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
model = new Model();
|
model = new Model();
|
||||||
model->init();
|
model->init();
|
||||||
model->setURL(QUrl(modelItem.getModelURL()));
|
model->setURL(QUrl(modelItem.getModelURL()));
|
||||||
|
@ -187,10 +202,12 @@ void ModelTreeRenderer::renderElement(OctreeElement* element, RenderArgs* args)
|
||||||
|
|
||||||
if (drawAsModel) {
|
if (drawAsModel) {
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
|
{
|
||||||
const float alpha = 1.0f;
|
const float alpha = 1.0f;
|
||||||
|
|
||||||
Model* model = getModel(modelItem);
|
Model* model = getModel(modelItem);
|
||||||
|
|
||||||
|
if (model) {
|
||||||
model->setScaleToFit(true, radius * 2.0f);
|
model->setScaleToFit(true, radius * 2.0f);
|
||||||
model->setSnapModelToCenter(true);
|
model->setSnapModelToCenter(true);
|
||||||
|
|
||||||
|
@ -223,9 +240,28 @@ void ModelTreeRenderer::renderElement(OctreeElement* element, RenderArgs* args)
|
||||||
|
|
||||||
if (modelItem.getGlowLevel() > 0.0f) {
|
if (modelItem.getGlowLevel() > 0.0f) {
|
||||||
Glower glower(modelItem.getGlowLevel());
|
Glower glower(modelItem.getGlowLevel());
|
||||||
|
|
||||||
|
if (model->isActive()) {
|
||||||
model->render(alpha, modelRenderMode);
|
model->render(alpha, modelRenderMode);
|
||||||
} else {
|
} else {
|
||||||
|
// if we couldn't get a model, then just draw a sphere
|
||||||
|
glColor3ub(modelItem.getColor()[RED_INDEX],modelItem.getColor()[GREEN_INDEX],modelItem.getColor()[BLUE_INDEX]);
|
||||||
|
glPushMatrix();
|
||||||
|
glTranslatef(position.x, position.y, position.z);
|
||||||
|
glutSolidSphere(radius, 15, 15);
|
||||||
|
glPopMatrix();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (model->isActive()) {
|
||||||
model->render(alpha, modelRenderMode);
|
model->render(alpha, modelRenderMode);
|
||||||
|
} else {
|
||||||
|
// if we couldn't get a model, then just draw a sphere
|
||||||
|
glColor3ub(modelItem.getColor()[RED_INDEX],modelItem.getColor()[GREEN_INDEX],modelItem.getColor()[BLUE_INDEX]);
|
||||||
|
glPushMatrix();
|
||||||
|
glTranslatef(position.x, position.y, position.z);
|
||||||
|
glutSolidSphere(radius, 15, 15);
|
||||||
|
glPopMatrix();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isShadowMode && displayModelBounds) {
|
if (!isShadowMode && displayModelBounds) {
|
||||||
|
@ -269,10 +305,19 @@ void ModelTreeRenderer::renderElement(OctreeElement* element, RenderArgs* args)
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// if we couldn't get a model, then just draw a sphere
|
||||||
|
glColor3ub(modelItem.getColor()[RED_INDEX],modelItem.getColor()[GREEN_INDEX],modelItem.getColor()[BLUE_INDEX]);
|
||||||
|
glPushMatrix();
|
||||||
|
glTranslatef(position.x, position.y, position.z);
|
||||||
|
glutSolidSphere(radius, 15, 15);
|
||||||
|
glPopMatrix();
|
||||||
|
}
|
||||||
|
}
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
} else {
|
} else {
|
||||||
glColor3ub(modelItem.getColor()[RED_INDEX],modelItem.getColor()[GREEN_INDEX],modelItem.getColor()[BLUE_INDEX]);
|
//glColor3ub(modelItem.getColor()[RED_INDEX],modelItem.getColor()[GREEN_INDEX],modelItem.getColor()[BLUE_INDEX]);
|
||||||
|
glColor3f(1.0f, 0.0f, 0.0f);
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
glTranslatef(position.x, position.y, position.z);
|
glTranslatef(position.x, position.y, position.z);
|
||||||
glutSolidSphere(radius, 15, 15);
|
glutSolidSphere(radius, 15, 15);
|
||||||
|
|
|
@ -186,6 +186,11 @@ bool ModelTreeElement::findDetailedRayIntersection(const glm::vec3& origin, cons
|
||||||
if (fbxGeometry && fbxGeometry->meshExtents.isValid()) {
|
if (fbxGeometry && fbxGeometry->meshExtents.isValid()) {
|
||||||
Extents extents = fbxGeometry->meshExtents;
|
Extents extents = fbxGeometry->meshExtents;
|
||||||
|
|
||||||
|
// NOTE: If the model has a bad mesh, then extents will be 0,0,0 & 0,0,0
|
||||||
|
if (extents.minimum == extents.maximum && extents.minimum == glm::vec3(0,0,0)) {
|
||||||
|
extents.maximum = glm::vec3(1.0f,1.0f,1.0f); // in this case we will simulate the unit cube
|
||||||
|
}
|
||||||
|
|
||||||
// NOTE: these extents are model space, so we need to scale and center them accordingly
|
// NOTE: these extents are model space, so we need to scale and center them accordingly
|
||||||
// size is our "target size in world space"
|
// size is our "target size in world space"
|
||||||
// we need to set our model scale so that the extents of the mesh, fit in a cube that size...
|
// we need to set our model scale so that the extents of the mesh, fit in a cube that size...
|
||||||
|
|
Loading…
Reference in a new issue