summaryrefslogtreecommitdiff
path: root/inc/VrmlData_Appearance.hxx
blob: 295d9f55f8108a605b2df206109d143997edaa75 (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
// File:      VrmlData_Appearance.hxx
// Created:   25.05.06 15:30:58
// Author:    Alexander GRIGORIEV
// Copyright: Open Cascade 2006


#ifndef VrmlData_Appearance_HeaderFile
#define VrmlData_Appearance_HeaderFile

#include <VrmlData_Material.hxx>
#include <VrmlData_Texture.hxx>
#include <VrmlData_TextureTransform.hxx>

/**
 *  Implementation of the Appearance node type
 */
class VrmlData_Appearance : public VrmlData_Node
{
 public:
  // ---------- PUBLIC METHODS ----------

  /**
   * Empty constructor
   */
  inline VrmlData_Appearance () {}

  /**
   * Constructor
   */
  inline VrmlData_Appearance (const VrmlData_Scene& theScene,
                              const char * theName)
    : VrmlData_Node (theScene, theName) {}

  /**
   * Query the Material
   */
  inline const Handle(VrmlData_Material)&
                Material        () const        { return myMaterial; }

  /**
   * Query the Texture
   */
  inline const Handle(VrmlData_Texture)&
                Texture         () const        { return myTexture; }

  /**
   * Query the TextureTransform
   */
  inline const Handle(VrmlData_TextureTransform)&
                TextureTransform () const       { return myTTransform; }

  /**
   * Set the Material
   */
  inline void   SetMaterial     (const Handle(VrmlData_Material)& theMat)
  { myMaterial = theMat; }

  /**
   * Set the Texture
   */
  inline void   SetTexture      (const Handle(VrmlData_Texture)& theTexture)
  { myTexture = theTexture; }

  /**
   * Set the Texture Transform
   */
  inline void   SetTextureTransform
                                (const Handle(VrmlData_TextureTransform)& theTT)
  { myTTransform = theTT; }

  /**
   * Create a copy of this node.
   * If the parameter is null, a new copied node is created. Otherwise new node
   * is not created, but rather the given one is modified.<p>
   */
  Standard_EXPORT virtual Handle(VrmlData_Node)
                                Clone       (const Handle(VrmlData_Node)&)const;
  /**
   * Read the node from input stream.
   */
  Standard_EXPORT virtual VrmlData_ErrorStatus
                                Read        (VrmlData_InBuffer& theBuffer);

  /**
   * Write the Node from input stream.
   */
  Standard_EXPORT virtual VrmlData_ErrorStatus
                                Write       (const char * thePrefix) const;

  /**
   * Returns True if the node is default, so that it should not be written.
   */
  Standard_EXPORT virtual Standard_Boolean
                                IsDefault       () const;

 protected:
  // ---------- PROTECTED METHODS ----------



 private:
  // ---------- PRIVATE FIELDS ----------

  Handle(VrmlData_Material)             myMaterial;
  Handle(VrmlData_Texture)              myTexture;
  Handle(VrmlData_TextureTransform)     myTTransform;

 public:
// Declaration of CASCADE RTTI
DEFINE_STANDARD_RTTI (VrmlData_Appearance)
};

// Definition of HANDLE object using Standard_DefineHandle.hxx
DEFINE_STANDARD_HANDLE (VrmlData_Appearance, VrmlData_Node)

#endif