File: vtkOpenGLModelViewProjectionMonitor.cxx

package info (click to toggle)
vtk6 6.3.0%2Bdfsg2-8.1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 118,972 kB
  • sloc: cpp: 1,442,790; ansic: 113,395; python: 72,383; tcl: 46,998; xml: 8,119; yacc: 4,525; java: 4,239; perl: 3,108; lex: 1,694; sh: 1,093; asm: 154; makefile: 68; objc: 17
file content (88 lines) | stat: -rw-r--r-- 3,290 bytes parent folder | download | duplicates (7)
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*=========================================================================

  Program:   Visualization Toolkit
  Module:    vtkOpenGLModelViewProjectionMonitor

  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.

     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/
#include "vtkOpenGLModelViewProjectionMonitor.h"
#include "vtkObjectFactory.h"
#include "vtkgl.h"
#include <cstring>
#include <cmath>

//-----------------------------------------------------------------------------
vtkStandardNewMacro(vtkOpenGLModelViewProjectionMonitor)

//-----------------------------------------------------------------------------
void vtkOpenGLModelViewProjectionMonitor::Initialize()
{
  memset(this->Projection,0,16*sizeof(float));
  memset(this->ModelView,0,16*sizeof(float));
}

//-----------------------------------------------------------------------------
#define vtkOpenGLModelViewProjectionMonitorSetVectorMacro(_name, _n) \
void vtkOpenGLModelViewProjectionMonitor::Set##_name(float *val)     \
{                                                    \
  int changed = 0;                                   \
  for (int i=0; i<_n; ++i)                           \
    {                                                \
    if ( fabs( val[i] - this->_name[i] ) > 1e-5f )   \
      {                                              \
      changed=1;                                     \
      this->_name[i] = val[i];                       \
      }                                              \
    }                                                \
  if ( changed )                                     \
    {                                                \
    this->UpTime += 1;                               \
    }                                                \
}
vtkOpenGLModelViewProjectionMonitorSetVectorMacro(Projection, 16)
vtkOpenGLModelViewProjectionMonitorSetVectorMacro(ModelView, 16)

//-----------------------------------------------------------------------------
void vtkOpenGLModelViewProjectionMonitor::Update()
{
  GLfloat matrix[16];
  glGetFloatv(GL_PROJECTION_MATRIX, matrix);
  this->SetProjection(matrix);

  glGetFloatv(GL_MODELVIEW_MATRIX,  matrix);
  this->SetModelView(matrix);
}

//-----------------------------------------------------------------------------
bool vtkOpenGLModelViewProjectionMonitor::StateChanged()
{
  long long oldUpTime = this->UpTime;
  this->Update();
  return (this->UpTime != oldUpTime);
}

//-----------------------------------------------------------------------------
void vtkOpenGLModelViewProjectionMonitor::PrintSelf(ostream &os, vtkIndent indent)
{
  this->Superclass::PrintSelf(os,indent);
  os << indent << "Projection=";
  for (int q=0; q<16; ++q)
    {
    os << this->Projection[q] << " ";
    }
  os << endl;
  os << indent << "ModelView=";
  for (int q=0; q<16; ++q)
    {
    os << this->ModelView[q] << " ";
    }
  os << endl;
  os << indent << "UpTime=" << this->UpTime << endl;
}