blob: ffd233aacb6edfc74c1d04a89a6495af207b4d15 (
plain)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/*
**************************************************************************
description
--------------------
copyright : (C) 2001 by Andreas Zehender
email : zehender@kde.org
**************************************************************************
**************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
**************************************************************************/
#ifndef PMRENDERMODE_H
#define PMRENDERMODE_H
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <tqstring.h>
#include <tqptrlist.h>
#include <tqstringlist.h>
#include <tqdom.h>
/**
* Class that represents the render options for povray
*
* See povray documentation, output options.
*/
class PMRenderMode
{
public:
/**
* Sampling method for antialiasing. See povray documentation.
*/
enum AASamplingMethod { AntialiasingNonRecursive = 0, AntialiasingRecursive = 1 };
/**
* Default constructor
*/
PMRenderMode( );
/**
* Reads the attributes from the TQDomElement
*/
PMRenderMode( const TQDomElement& e );
void setDescription( const TQString& descr ) { m_description = descr; }
TQString description( ) const { return m_description; }
void setHeight( int height );
int height( ) const { return m_height; }
void setWidth( int width );
int width( ) const { return m_width; }
void setSubSection( bool on ) { m_subSection = on; }
bool subSection( ) const { return m_subSection; }
void setStartRow( double startRow );
double startRow( ) const { return m_startRow; }
void setEndRow( double endRow );
double endRow( ) const { return m_endRow; }
void setStartColumn( double startColumn );
double startColumn( ) const { return m_startColumn; }
void setEndColumn( double endColumn );
double endColumn( ) const { return m_endColumn; }
void setQuality( int quality );
int quality( ) const { return m_quality; }
void setRadiosity( bool on ) { m_radiosity = on; }
bool radiosity( ) const { return m_radiosity; }
void setAntialiasing( bool on ) { m_antialiasing = on; }
bool antialiasing( ) const { return m_antialiasing; }
void setSamplingMethod( int method );
int samplingMethod( ) const { return m_samplingMethod; }
void setAntialiasingThreshold( double t ) { m_antialiasThreshold = t; }
double antialiasingThreshold( ) const { return m_antialiasThreshold; }
void setAntialiasingJitter( bool on ) { m_antialiasJitter = on; }
bool antialiasingJitter( ) const { return m_antialiasJitter; }
void setAntialiasingJitterAmount( double amount ) { m_antialiasJitterAmount = amount; }
double antialiasingJitterAmount( ) const { return m_antialiasJitterAmount; }
void setAntialiasingDepth( int depth );
int antialiasingDepth( ) const { return m_antialiasDepth; }
void setAlpha( bool on ) { m_alpha = on; }
bool alpha( ) const { return m_alpha; }
/**
* Returns the settings as povray command line switches
*/
TQStringList commandLineSwitches( ) const;
/**
* Saves the data
*/
void serialize( TQDomElement& e ) const;
private:
void init( );
TQString m_description;
int m_height, m_width;
bool m_subSection;
double m_startRow, m_endRow, m_startColumn, m_endColumn;
int m_quality;
bool m_radiosity;
bool m_antialiasing;
int m_samplingMethod;
double m_antialiasThreshold;
bool m_antialiasJitter;
double m_antialiasJitterAmount;
int m_antialiasDepth;
bool m_alpha;
};
typedef TQPtrList<PMRenderMode> PMRenderModeList;
typedef TQPtrListIterator<PMRenderMode> PMRenderModeListIterator;
#endif
|