3 Copyright (C) 2010 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 #ifndef IRRLICHTWRAPPER_HEADER
21 #define IRRLICHTWRAPPER_HEADER
24 #include "common_irrlicht.h"
29 #include <jmutexautolock.h>
33 A thread-safe texture pointer cache.
35 This is used so that irrlicht doesn't get called from many
36 threads, because texture pointers have to be handled in
46 assert(m_mutex.IsInitialized());
49 void set(std::string name, video::ITexture *texture)
54 JMutexAutoLock lock(m_mutex);
56 m_textures[name] = texture;
59 video::ITexture* get(std::string name)
61 JMutexAutoLock lock(m_mutex);
63 core::map<std::string, video::ITexture*>::Node *n;
64 n = m_textures.find(name);
73 core::map<std::string, video::ITexture*> m_textures;
80 Returns a new texture which can be based on the original.
81 Shall not modify or delete the original texture.
83 virtual video::ITexture * make(video::ITexture *original,
84 const char *newname, video::IVideoDriver* driver) = 0;
87 struct CrackTextureMod: public TextureMod
89 CrackTextureMod(u16 a_progression)
91 progression = a_progression;
94 virtual video::ITexture * make(video::ITexture *original,
95 const char *newname, video::IVideoDriver* driver);
101 A class for specifying a requested texture
109 TextureSpec(const std::string &a_name, const std::string &a_path,
119 bool operator==(const TextureSpec &other)
121 return name == other.name;
123 // An unique name for the texture. Usually the same as the path.
124 // Note that names and paths reside the same namespace.
126 // This is the path of the base texture
128 // Modification to do to the base texture
129 // NOTE: This is deleted by the one who processes the request
134 A thread-safe wrapper for irrlicht, to be accessed from
135 background worker threads.
137 Queues tasks to be done in the main thread.
140 class IrrlichtWrapper
144 These are called from the main thread
146 IrrlichtWrapper(IrrlichtDevice *device);
152 These are called from other threads
155 // Not exactly thread-safe but this needs to be fast.
156 // getTimer()->getRealTime() only reads one variable anyway.
159 return m_device->getTimer()->getRealTime();
162 video::ITexture* getTexture(TextureSpec spec);
163 video::ITexture* getTexture(const std::string &path);
167 Non-thread-safe variants of stuff, for internal use
169 video::ITexture* getTextureDirect(TextureSpec spec);
175 threadid_t m_main_thread;
177 JMutex m_device_mutex;
178 IrrlichtDevice *m_device;
180 TextureCache m_texturecache;
182 RequestQueue<TextureSpec, video::ITexture*, u8, u8> m_get_texture_queue;