/* ========================================================================= * * * * OpenMesh * * Copyright (c) 2001-2015, RWTH-Aachen University * * Department of Computer Graphics and Multimedia * * All rights reserved. * * www.openmesh.org * * * *---------------------------------------------------------------------------* * This file is part of OpenMesh. * *---------------------------------------------------------------------------* * * * Redistribution and use in source and binary forms, with or without * * modification, are permitted provided that the following conditions * * are met: * * * * 1. Redistributions of source code must retain the above copyright notice, * * this list of conditions and the following disclaimer. * * * * 2. Redistributions in binary form must reproduce the above copyright * * notice, this list of conditions and the following disclaimer in the * * documentation and/or other materials provided with the distribution. * * * * 3. Neither the name of the copyright holder nor the names of its * * contributors may be used to endorse or promote products derived from * * this software without specific prior written permission. * * * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A * * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER * * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * * * ========================================================================= */ /*===========================================================================*\ * * * $Revision$ * * $Date$ * * * \*===========================================================================*/ #pragma once //== INCLUDES ================================================================= #include #include #include #include #include #include #include #include #include //== FORWARDS ================================================================= class QImage; //== CLASS DEFINITION ========================================================= template class MeshViewerWidgetT : public QGLViewerWidget { public: typedef M Mesh; typedef OpenMesh::StripifierT MyStripifier; public: /// default constructor MeshViewerWidgetT(QWidget* _parent=0) : QGLViewerWidget(_parent), f_strips_(false), tex_id_(0), tex_mode_(GL_MODULATE), strips_(mesh_), use_color_(true), show_vnormals_(false), show_fnormals_(false) { add_draw_mode("Points"); add_draw_mode("Hidden-Line"); #if defined(OM_USE_OSG) && OM_USE_OSG add_draw_mode("OpenSG Indices"); #endif } /// destructor ~MeshViewerWidgetT() {} public: /// open mesh virtual bool open_mesh(const char* _filename, OpenMesh::IO::Options _opt); /// load texture virtual bool open_texture( const char *_filename ); bool set_texture( QImage& _texsrc ); void enable_strips(); void disable_strips(); Mesh& mesh() { return mesh_; } const Mesh& mesh() const { return mesh_; } protected: /// inherited drawing method virtual void draw_scene(const std::string& _draw_mode); protected: /// draw the mesh virtual void draw_openmesh(const std::string& _drawmode); void glVertex( const typename Mesh::VertexHandle _vh ) { glVertex3fv( &mesh_.point( _vh )[0] ); } void glVertex( const typename Mesh::Point& _p ) { glVertex3fv( &_p[0] ); } void glNormal( const typename Mesh::VertexHandle _vh ) { glNormal3fv( &mesh_.normal( _vh )[0] ); } void glTexCoord( const typename Mesh::VertexHandle _vh ) { glTexCoord2fv( &mesh_.texcoord(_vh)[0] ); } void glColor( const typename Mesh::VertexHandle _vh ) { glColor3ubv( &mesh_.color(_vh)[0] ); } // face properties void glNormal( const typename Mesh::FaceHandle _fh ) { glNormal3fv( &mesh_.normal( _fh )[0] ); } void glColor( const typename Mesh::FaceHandle _fh ) { glColor3ubv( &mesh_.color(_fh)[0] ); } void glMaterial( const typename Mesh::FaceHandle _fh, int _f=GL_FRONT_AND_BACK, int _m=GL_DIFFUSE ) { OpenMesh::Vec3f c=OpenMesh::color_cast(mesh_.color(_fh)); OpenMesh::Vec4f m( c[0], c[1], c[2], 1.0f ); glMaterialfv(_f, _m, &m[0]); } protected: // Strip support void compute_strips(void) { if (f_strips_) { strips_.clear(); strips_.stripify(); } } protected: // inherited virtual void keyPressEvent( QKeyEvent* _event); protected: bool f_strips_; // enable/disable strip usage GLuint tex_id_; GLint tex_mode_; OpenMesh::IO::Options opt_; // mesh file contained texcoords? Mesh mesh_; MyStripifier strips_; bool use_color_; bool show_vnormals_; bool show_fnormals_; float normal_scale_; OpenMesh::FPropHandleT< typename Mesh::Point > fp_normal_base_; }; //============================================================================= #if defined(OM_INCLUDE_TEMPLATES) && !defined(OPENMESHAPPS_MESHVIEWERWIDGET_CC) # define OPENMESH_MESHVIEWERWIDGET_TEMPLATES # include "MeshViewerWidgetT.cc" #endif //=============================================================================