132 lines
4.3 KiB
C++

/****************************************************************************
* MeshLab o o *
* A versatile mesh processing toolbox o o *
* _ O _ *
* Copyright(C) 2005 \/)\/ *
* Visual Computing Lab /\/| *
* ISTI - Italian National Research Council | *
* \ *
* All rights reserved. *
* *
* This program 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 2 of the License, or *
* (at your option) any later version. *
* *
* This program 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 (http://www.gnu.org/licenses/gpl.txt) *
* for more details. *
* *
****************************************************************************/
/****************************************************************************
History
$Log: meshedit.cpp,v $
****************************************************************************/
#include <QtGui>
#include <math.h>
#include <stdlib.h>
#include <meshlab/glarea.h>
#include "sampleedit.h"
#include <wrap/gl/pick.h>
using namespace vcg;
SampleEditPlugin::SampleEditPlugin() {
curFacePtr=0;
qFont.setFamily("Helvetica");
qFont.setPixelSize(10);
actionList << new QAction(QIcon(":/images/icon_info.png"),"Get Info", this);
foreach(QAction *editAction, actionList)
editAction->setCheckable(true);
}
QList<QAction *> SampleEditPlugin::actions() const {
return actionList;
}
const QString SampleEditPlugin::Info(QAction *action)
{
if( action->text() != tr("Get Info") ) assert (0);
return tr("Return detailed info about a picked face of the model.");
}
const PluginInfo &SampleEditPlugin::Info()
{
static PluginInfo ai;
ai.Date=tr(__DATE__);
ai.Version = tr("1.0");
ai.Author = ("Paolo Cignoni");
return ai;
}
void SampleEditPlugin::mouseReleaseEvent (QAction *,QMouseEvent * event, MeshModel &/*m*/, GLArea * gla)
{
gla->update();
cur=event->pos();
haveToPick=true;
}
void SampleEditPlugin::Decorate(QAction * /*ac*/, MeshModel &m, GLArea * gla)
{
if(haveToPick)
{
glPushMatrix();
glMultMatrix(m.cm.Tr);
vector<CMeshO::FacePointer> NewSel;
GLPickTri<CMeshO>::PickFace(cur.x(), gla->height() - cur.y(), m.cm, NewSel);
if(NewSel.size()>0)
curFacePtr=NewSel.front();
haveToPick=false;
glPopMatrix();
}
if(curFacePtr)
{
glPushMatrix();
glMultMatrix(m.cm.Tr);
glPushAttrib(GL_ENABLE_BIT | GL_CURRENT_BIT | GL_LINE_BIT | GL_DEPTH_BUFFER_BIT);
glLineWidth(2.0f);
glDepthFunc(GL_ALWAYS);
glDisable(GL_DEPTH_TEST);
glDepthMask(GL_FALSE);
glDisable(GL_LIGHTING);
glColor(Color4b::DarkRed);
drawFace(curFacePtr,m,gla);
glDepthMask(GL_TRUE);
glEnable(GL_DEPTH_TEST);
glDepthFunc(GL_LESS);
glColor(Color4b::Red);
drawFace(curFacePtr,m,gla);
glPopAttrib();
glPopMatrix();
}
}
void SampleEditPlugin::drawFace(CMeshO::FacePointer fp, MeshModel &m, GLArea * gla)
{
glBegin(GL_LINE_LOOP);
glVertex(fp->P(0));
glVertex(fp->P(1));
glVertex(fp->P(2));
glEnd();
for(int i=0;i<3;++i)
{
QString buf=QString("v%1:%2 (%3 %4 %5)").arg(i).arg(fp->V(i) - &m.cm.vert[0]).arg(fp->P(i)[0]).arg(fp->P(i)[1]).arg(fp->P(i)[2]);
gla->renderText(fp->P(i)[0], fp->P(i)[1], fp->P(i)[2], buf, qFont);
}
}
void SampleEditPlugin::StartEdit(QAction * /*mode*/, MeshModel &/*m*/, GLArea *gla )
{
gla->setCursor(QCursor(QPixmap(":/images/cur_info.png"),1,1));
}
Q_EXPORT_PLUGIN(SampleEditPlugin)