doom3-gpl
Doom 3 GPL source release
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
MaterialView.h
Go to the documentation of this file.
1 /*
2 ===========================================================================
3 
4 Doom 3 GPL Source Code
5 Copyright (C) 1999-2011 id Software LLC, a ZeniMax Media company.
6 
7 This file is part of the Doom 3 GPL Source Code (?Doom 3 Source Code?).
8 
9 Doom 3 Source Code is free software: you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation, either version 3 of the License, or
12 (at your option) any later version.
13 
14 Doom 3 Source Code is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18 
19 You should have received a copy of the GNU General Public License
20 along with Doom 3 Source Code. If not, see <http://www.gnu.org/licenses/>.
21 
22 In addition, the Doom 3 Source Code is also subject to certain additional terms. You should have received a copy of these additional terms immediately following the terms and conditions of the GNU General Public License which accompanied the Doom 3 Source Code. If not, please request a copy in writing from id Software at the address below.
23 
24 If you have questions concerning this license or the applicable additional terms, you may contact in writing id Software LLC, c/o ZeniMax Media Inc., Suite 120, Rockville, Maryland 20850 USA.
25 
26 ===========================================================================
27 */
28 #pragma once
29 
30 #include "MaterialDocManager.h"
31 
38 class MaterialView {
39 public:
47  virtual ~MaterialView(void) {};
48 
50  //Public Interface to be implemented by subclasses
52 
57  virtual void SetMaterialDocManager(MaterialDocManager* docManager) { materialDocManager = docManager; };
58 
63  virtual void MV_OnMaterialSelectionChange(MaterialDoc* pMaterial) {};
64 
69  virtual void MV_OnMaterialChange(MaterialDoc* pMaterial) {};
70 
75  virtual void MV_OnMaterialApply(MaterialDoc* pMaterial) {};
76 
81  virtual void MV_OnMaterialSaved(MaterialDoc* pMaterial) {};
82 
87  virtual void MV_OnMaterialSaveFile(const char* filename) {};
88 
93  virtual void MV_OnMaterialAdd(MaterialDoc* pMaterial) {};
94 
99  virtual void MV_OnMaterialDelete(MaterialDoc* pMaterial) {};
100 
106  virtual void MV_OnMaterialStageAdd(MaterialDoc* pMaterial, int stageNum) {};
107 
113  virtual void MV_OnMaterialStageDelete(MaterialDoc* pMaterial, int stageNum) {};
114 
121  virtual void MV_OnMaterialStageMove(MaterialDoc* pMaterial, int from, int to) {};
122 
129  virtual void MV_OnMaterialAttributeChanged(MaterialDoc* pMaterial, int stage, const char* attribName) {};
130 
131 
137  virtual void MV_OnMaterialNameChanged(MaterialDoc* pMaterial, const char* oldName) {};
138 
143  virtual void MV_OnFileReload(const char* filename) {};
144 
145 
146 protected:
148 };
virtual void MV_OnMaterialChange(MaterialDoc *pMaterial)
Called when the material has changed but not applied.
Definition: MaterialView.h:69
virtual void SetMaterialDocManager(MaterialDocManager *docManager)
Sets the material document manager for this view instance.
Definition: MaterialView.h:57
virtual void MV_OnMaterialStageDelete(MaterialDoc *pMaterial, int stageNum)
Called when a stage is deleted.
Definition: MaterialView.h:113
virtual void MV_OnMaterialApply(MaterialDoc *pMaterial)
Called when the material changes have been applied.
Definition: MaterialView.h:75
virtual void MV_OnMaterialSaveFile(const char *filename)
Called when a material file has been saved.
Definition: MaterialView.h:87
MaterialView(void)
Constructor.
Definition: MaterialView.h:43
Responsible for managing a single material that is being viewed and/or edited.
Definition: MaterialDoc.h:67
virtual void MV_OnMaterialSelectionChange(MaterialDoc *pMaterial)
Called when the selected material has changed.
Definition: MaterialView.h:63
MaterialView Interface.
Definition: MaterialView.h:38
#define NULL
Definition: Lib.h:88
virtual void MV_OnMaterialStageMove(MaterialDoc *pMaterial, int from, int to)
Called when a stage is moved.
Definition: MaterialView.h:121
virtual void MV_OnMaterialStageAdd(MaterialDoc *pMaterial, int stageNum)
Called when a stage is added.
Definition: MaterialView.h:106
virtual void MV_OnMaterialAttributeChanged(MaterialDoc *pMaterial, int stage, const char *attribName)
Called when an attribute is changed.
Definition: MaterialView.h:129
virtual void MV_OnMaterialDelete(MaterialDoc *pMaterial)
Called when a material is deleted.
Definition: MaterialView.h:99
virtual void MV_OnMaterialAdd(MaterialDoc *pMaterial)
Called when a material is added.
Definition: MaterialView.h:93
MaterialDocManager * materialDocManager
Definition: MaterialView.h:143
virtual void MV_OnFileReload(const char *filename)
Called when a file has been reloaded.
Definition: MaterialView.h:143
virtual ~MaterialView(void)
Destructor.
Definition: MaterialView.h:47
Responsible for managing the materials that are being viewed and/or edited.
virtual void MV_OnMaterialNameChanged(MaterialDoc *pMaterial, const char *oldName)
Called when the material name has changed.
Definition: MaterialView.h:137
virtual void MV_OnMaterialSaved(MaterialDoc *pMaterial)
Called when the material changes have been saved.
Definition: MaterialView.h:81