File: FieldDisplacementMapData.cxx

package info (click to toggle)
paraview 4.0.1-1~bpo70%2B1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy-backports
  • size: 526,572 kB
  • sloc: cpp: 2,284,430; ansic: 816,374; python: 239,936; xml: 70,162; tcl: 48,295; fortran: 39,116; yacc: 5,466; java: 3,518; perl: 3,107; lex: 1,620; sh: 1,555; makefile: 932; asm: 471; pascal: 228
file content (81 lines) | stat: -rw-r--r-- 2,436 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
72
73
74
75
76
77
78
79
80
81
/*
   ____    _ __           ____               __    ____
  / __/___(_) /  ___ ____/ __ \__ _____ ___ / /_  /  _/__  ____
 _\ \/ __/ / _ \/ -_) __/ /_/ / // / -_|_-</ __/ _/ // _ \/ __/
/___/\__/_/_.__/\__/_/  \___\_\_,_/\__/___/\__/ /___/_//_/\__(_)

Copyright 2012 SciberQuest Inc.
*/
#include "FieldDisplacementMapData.h"

#include "TerminationCondition.h"
#include "vtkDataSet.h"
#include "vtkPointData.h"

//-----------------------------------------------------------------------------
FieldDisplacementMapData::FieldDisplacementMapData()
        :
    Displacement(0),
    FwdDisplacement(0),
    BwdDisplacement(0)
{
  this->Displacement=vtkFloatArray::New();
  this->Displacement->SetName("displacement");
  this->Displacement->SetNumberOfComponents(3);

  this->FwdDisplacement=vtkFloatArray::New();
  this->FwdDisplacement->SetName("fwd-displacement-map");
  this->FwdDisplacement->SetNumberOfComponents(3);

  this->BwdDisplacement=vtkFloatArray::New();
  this->BwdDisplacement->SetName("bwd-displacement-map");
  this->BwdDisplacement->SetNumberOfComponents(3);
}

//-----------------------------------------------------------------------------
FieldDisplacementMapData::~FieldDisplacementMapData()
{
  this->Displacement->Delete();
  this->FwdDisplacement->Delete();
  this->BwdDisplacement->Delete();
}

//-----------------------------------------------------------------------------
void FieldDisplacementMapData::SetOutput(vtkDataSet *o)
{
  o->GetPointData()->AddArray(this->Displacement);
  o->GetPointData()->AddArray(this->FwdDisplacement);
  o->GetPointData()->AddArray(this->BwdDisplacement);
}

//-----------------------------------------------------------------------------
int FieldDisplacementMapData::SyncScalars()
{
  vtkIdType nLines=this->Lines.size();
  vtkIdType lastLineId=this->Displacement->GetNumberOfTuples();

  float *pDisplacement
    = this->Displacement->WritePointer(3*lastLineId,3*nLines);

  float *pFwdDisplacement
    = this->FwdDisplacement->WritePointer(3*lastLineId,3*nLines);

  float *pBwdDisplacement
    = this->BwdDisplacement->WritePointer(3*lastLineId,3*nLines);

  for (vtkIdType i=0; i<nLines; ++i)
    {
    FieldLine *line=this->Lines[i];

    line->GetDisplacement(pDisplacement);
    pDisplacement+=3;

    line->GetForwardEndPoint(pFwdDisplacement);
    pFwdDisplacement+=3;

    line->GetBackwardEndPoint(pBwdDisplacement);
    pBwdDisplacement+=3;
    }

  return 1;
}