OGRE  1.9
Object-Oriented Graphics Rendering Engine
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
OgreMaterialManager.h
Go to the documentation of this file.
1 /*
2 -----------------------------------------------------------------------------
3 This source file is part of OGRE
4  (Object-oriented Graphics Rendering Engine)
5 For the latest info, see http://www.ogre3d.org/
6 
7 Copyright (c) 2000-2014 Torus Knot Software Ltd
8 
9 Permission is hereby granted, free of charge, to any person obtaining a copy
10 of this software and associated documentation files (the "Software"), to deal
11 in the Software without restriction, including without limitation the rights
12 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13 copies of the Software, and to permit persons to whom the Software is
14 furnished to do so, subject to the following conditions:
15 
16 The above copyright notice and this permission notice shall be included in
17 all copies or substantial portions of the Software.
18 
19 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 THE SOFTWARE.
26 -----------------------------------------------------------------------------
27 */
28 #ifndef __MATERIALMANAGER_H__
29 #define __MATERIALMANAGER_H__
30 
31 #include "OgrePrerequisites.h"
32 
33 #include "OgreSingleton.h"
34 #include "OgreResourceManager.h"
35 #include "OgreMaterial.h"
36 #include "OgreStringVector.h"
37 #include "OgreMaterialSerializer.h"
38 #include "OgreHeaderPrefix.h"
39 
40 namespace Ogre {
41 
42 
64  class _OgreExport MaterialManager : public ResourceManager, public Singleton<MaterialManager>
65  {
66  public:
70  class Listener
71  {
72  public:
74  virtual ~Listener() { }
104  virtual Technique* handleSchemeNotFound(unsigned short schemeIndex,
105  const String& schemeName, Material* originalMaterial, unsigned short lodIndex,
106  const Renderable* rend) = 0;
107 
108  };
109 
110  protected:
111 
120 
123 
125  unsigned int mDefaultMaxAniso;
130 
132  Resource* createImpl(const String& name, ResourceHandle handle,
133  const String& group, bool isManual, ManualResourceLoader* loader,
134  const NameValuePairList* params);
135 
143  unsigned short mActiveSchemeIndex;
144 
149 
150  public:
153 
156  MaterialPtr create (const String& name, const String& group,
157  bool isManual = false, ManualResourceLoader* loader = 0,
158  const NameValuePairList* createParams = 0);
159 
162  MaterialPtr getByName(const String& name, const String& groupName = ResourceGroupManager::AUTODETECT_RESOURCE_GROUP_NAME);
163 
166  MaterialManager();
167 
170  virtual ~MaterialManager();
171 
174  void initialise(void);
175 
178  void parseScript(DataStreamPtr& stream, const String& groupName);
179 
180 
187  virtual void setDefaultTextureFiltering(TextureFilterOptions fo);
192  virtual void setDefaultTextureFiltering(FilterType ftype, FilterOptions opts);
197  virtual void setDefaultTextureFiltering(FilterOptions minFilter, FilterOptions magFilter, FilterOptions mipFilter);
198 
200  virtual FilterOptions getDefaultTextureFiltering(FilterType ftype) const;
201 
208  void setDefaultAnisotropy(unsigned int maxAniso);
210  unsigned int getDefaultAnisotropy() const;
211 
242  virtual MaterialPtr getDefaultSettings(void) const { return mDefaultSettings; }
243 
247  virtual unsigned short _getSchemeIndex(const String& name);
251  virtual const String& _getSchemeName(unsigned short index);
255  virtual unsigned short _getActiveSchemeIndex(void) const;
256 
260  virtual const String& getActiveScheme(void) const;
261 
265  virtual void setActiveScheme(const String& schemeName);
266 
271  virtual void addListener(Listener* l, const Ogre::String& schemeName = StringUtil::BLANK);
272 
277  virtual void removeListener(Listener* l, const Ogre::String& schemeName = StringUtil::BLANK);
278 
280  virtual Technique* _arbitrateMissingTechniqueForActiveScheme(
281  Material* mat, unsigned short lodIndex, const Renderable* rend);
282 
298  static MaterialManager& getSingleton(void);
314  static MaterialManager* getSingletonPtr(void);
315 
316  };
320 }
321 
322 #include "OgreHeaderSuffix.h"
323 
324 #endif
#define _OgreExport
Definition: OgrePlatform.h:260
Listener on any general material events.
String mActiveSchemeName
Current material scheme.
#define OGRE_THREAD_POINTER(T, var)
map< String, String >::type NameValuePairList
Name / value parameter pair (first = name, second = value)
Definition: OgreCommon.h:550
Template class for creating single-instance global classes.
Definition: OgreSingleton.h:64
static String AUTODETECT_RESOURCE_GROUP_NAME
Special resource group name which causes resource group to be automatically determined based on searc...
map< String, ListenerList >::type ListenerMap
Class encapsulates rendering properties of an object.
Definition: OgreMaterial.h:88
FilterType
Definition: OgreCommon.h:90
Interface describing a manual resource loader.
Definition: OgreResource.h:514
FilterOptions mDefaultMipFilter
Default Texture filtering - mipmapping.
map< String, unsigned short >::type SchemeMap
Scheme name -> index. Never shrinks! Should be pretty static anyway.
Class representing an approach to rendering this particular Material.
Definition: OgreTechnique.h:53
MaterialPtr mDefaultSettings
Default settings.
FilterOptions mDefaultMinFilter
Default Texture filtering - minification.
Abstract class defining the interface all renderable objects must implement.
Class for managing Material settings for Ogre.
Class for serializing Materials to / from a .material script.
unsigned short mActiveSchemeIndex
Current material scheme.
FilterOptions mDefaultCompare
Default Texture filtering - comparison.
unsigned int mDefaultMaxAniso
Default Texture anisotropy.
FilterOptions mDefaultMagFilter
Default Texture filtering - magnification.
Abstract class representing a loadable resource (e.g.
Definition: OgreResource.h:79
unsigned long long int ResourceHandle
Definition: OgreResource.h:41
static const String BLANK
Constant blank string, useful for returning by ref where local does not exist.
Definition: OgreString.h:196
virtual ~Listener()
Virtual destructor needed as class has virtual methods.
Defines a generic resource handler.
_StringBase String
static String DEFAULT_SCHEME_NAME
Default material scheme.
list< Listener * >::type ListenerList
The list of per-scheme (and general) material listeners.
SchemeMap mSchemes
List of material schemes.
FilterOptions
Filtering options for textures / mipmaps.
Definition: OgreCommon.h:100
CompareFunction mDefaultCompareFunction
CompareFunction
Comparison functions used for the depth/stencil buffer operations and others.
Definition: OgreCommon.h:64
virtual MaterialPtr getDefaultSettings(void) const
Returns a pointer to the default Material settings.
TextureFilterOptions
High-level filtering options providing shortcuts to settings the minification, magnification and mip ...
Definition: OgreCommon.h:78