forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vtkX3DExporterXMLWriter.h
88 lines (65 loc) · 2.41 KB
/
vtkX3DExporterXMLWriter.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/*=========================================================================
Program: Visualization Toolkit
Module: vtkX3DExporterXMLWriter.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 vtkX3DExporterXMLWriter - X3D Exporter XML Writer
// .SECTION Description
// vtkX3DExporterXMLWriter
#ifndef __vtkX3DExporterXMLWriter_h
#define __vtkX3DExporterXMLWriter_h
#include "vtkIOExportModule.h" // For export macro
#include "vtkX3DExporterWriter.h"
class vtkX3DExporterXMLNodeInfoStack;
class VTKIOEXPORT_EXPORT vtkX3DExporterXMLWriter : public vtkX3DExporterWriter
{
public:
static vtkX3DExporterXMLWriter *New();
vtkTypeMacro(vtkX3DExporterXMLWriter, vtkX3DExporterWriter);
void PrintSelf(ostream& os, vtkIndent indent);
virtual void CloseFile();
virtual int OpenFile(const char* file);
virtual void Flush();
virtual int OpenStream();
void StartDocument();
void EndDocument();
// Elements
void StartNode(int elementID);
void EndNode();
// Attributes
// SFString / MFString
void SetField(int attributeID, const char*, bool mfstring = true);
// SFInt32
void SetField(int attributeID, int);
// SFFloat
void SetField(int attributeID, float);
// SFDouble
void SetField(int attributeID, double);
// SFBool
void SetField(int attributeID, bool);
// For MFxxx attributes
void SetField(int attributeID, int type, const double* a);
void SetField(int attributeID, int type, vtkDataArray* a);
void SetField(int attributeID, const double* values, size_t size);
// MFInt32, SFIMAGE
void SetField(int attributeID, const int* values, size_t size, bool image = false);
protected:
vtkX3DExporterXMLWriter();
~vtkX3DExporterXMLWriter();
private:
const char* GetNewline() { return "\n"; };
void AddDepth();
void SubDepth();
std::string ActTab;
int Depth;
ostream *OutputStream;
vtkX3DExporterXMLNodeInfoStack* InfoStack;
vtkX3DExporterXMLWriter(const vtkX3DExporterXMLWriter&); // Not implemented.
void operator=(const vtkX3DExporterXMLWriter&); // Not implemented.
};
#endif