File: glarea.h

package info (click to toggle)
meshlab 1.3.2%2Bdfsg1-4
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 21,096 kB
  • ctags: 33,630
  • sloc: cpp: 224,813; ansic: 8,170; xml: 119; makefile: 80
file content (71 lines) | stat: -rw-r--r-- 1,495 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#ifndef CG_RENDERAREA_H
#define CG_RENDERAREA_H

#include <iostream>

#include <QtOpenGL/QGLWidget>

#include <vcg/space/box3.h>
#include <wrap/gui/trackball.h>
#include <vcg/complex/algorithms/create/ball_pivoting.h>
#include "cmesh.h"


//#include "mls_surface.h"
//#include "advancing.h"

using namespace tri;
using namespace trimesh;
class GLArea : public QGLWidget {
    Q_OBJECT

public:               
                  
    GLArea(QWidget *parent = 0);
    bool smooth;
   
public slots:         
    
    bool loadModel(const QString &file);
    void addFace();
    void add10Faces();
    void add100Faces();
    void add1000Faces();
    void addAll();
    void setTot(int n) { tot = n; }
    void addTot();
    
    void open();
    void save();
    void setRadius(double _radius) {
      radius = _radius;
    }
    void viewSmooth(bool on);

protected:
    int tot;      
          
    float radius;
    vcg::Box3f box;
    CMesh mesh;
//    Pivot<CMesh> *pivot;
    Pivot<CMesh> *pivot;
    vcg::Trackball trackball;

    void init(QString file, float radius);          
    void draw();
             

    void initializeGL();
    void resizeGL(int w, int h);
    void paintGL();

    void wheelEvent(QWheelEvent *e);
    void mouseMoveEvent(QMouseEvent *e);
    void mousePressEvent(QMouseEvent *e);
    void mouseReleaseEvent(QMouseEvent *e);        
    void keyReleaseEvent ( QKeyEvent * e );

};

#endif