forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathvtkMCubesWriter.h
66 lines (49 loc) · 2.1 KB
/
vtkMCubesWriter.h
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
/*=========================================================================
Program: Visualization Toolkit
Module: vtkMCubesWriter.h
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.
=========================================================================*/
// .NAME vtkMCubesWriter - write binary marching cubes file
// .SECTION Description
// vtkMCubesWriter is a polydata writer that writes binary marching cubes
// files. (Marching cubes is an isosurfacing technique that generates many
// triangles.) The binary format is supported by W. Lorensen's marching cubes
// program (and the vtkSliceCubes object). Each triangle is represented by
// three records, with each record consisting of six single precision
// floating point numbers representing the a triangle vertex coordinate and
// vertex normal.
// .SECTION Caveats
// Binary files are written in sun/hp/sgi (i.e., Big Endian) form.
// .SECTION See Also
// vtkMarchingCubes vtkSliceCubes vtkMCubesReader
#ifndef __vtkMCubesWriter_h
#define __vtkMCubesWriter_h
#include "vtkPolyDataWriter.h"
class VTK_IO_EXPORT vtkMCubesWriter : public vtkPolyDataWriter
{
public:
static vtkMCubesWriter *New();
vtkTypeMacro(vtkMCubesWriter,vtkPolyDataWriter);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Set/get file name of marching cubes limits file.
vtkSetStringMacro(LimitsFileName);
vtkGetStringMacro(LimitsFileName);
protected:
vtkMCubesWriter();
~vtkMCubesWriter();
void WriteData();
void WriteMCubes(FILE *fp, vtkPoints *pts, vtkDataArray *normals,
vtkCellArray *polys);
void WriteLimits(FILE *fp, double *bounds);
char *LimitsFileName;
private:
vtkMCubesWriter(const vtkMCubesWriter&); // Not implemented.
void operator=(const vtkMCubesWriter&); // Not implemented.
};
#endif