1 // materialmgr.cxx -- class to handle material properties
3 // Written by Curtis Olson, started May 1998.
5 // Copyright (C) 1998 Curtis L. Olson - curt@me.umn.edu
7 // This program is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU General Public License as
9 // published by the Free Software Foundation; either version 2 of the
10 // License, or (at your option) any later version.
12 // This program is distributed in the hope that it will be useful, but
13 // WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 // General Public License for more details.
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
28 #ifdef FG_MATH_EXCEPTION_CLASH
39 #include <Include/compiler.h>
44 #include <Debug/logstream.hxx>
45 #include <Misc/fgpath.hxx>
46 #include <Misc/fgstream.hxx>
47 #include <Main/options.hxx>
48 #include <Main/views.hxx>
49 #include <Scenery/tileentry.hxx>
51 #include "materialmgr.hxx"
52 #include "fragment.hxx"
57 // global material management class
58 fgMATERIAL_MGR material_mgr;
62 FGMaterialSlot::FGMaterialSlot ( void ) { }
66 FGMaterialSlot::~FGMaterialSlot ( void ) {
71 fgMATERIAL_MGR::fgMATERIAL_MGR ( void ) {
72 textures_loaded = false;
77 FGMaterialSlot::render_fragments()
79 int tris_rendered = current_view.get_tris_rendered();
81 // cout << "rendering " + texture_name + " = " << list_size << "\n";
86 if ( current_options.get_textures() ) {
88 if ( !m.is_loaded() ) {
89 m.load_texture( current_options.get_fg_root() );
93 xglBindTexture( GL_TEXTURE_2D, m.get_texture_id() );
94 #elif GL_EXT_texture_object
95 xglBindTextureEXT( GL_TEXTURE_2D, m.get_texture_id() );
100 xglMaterialfv (GL_FRONT, GL_AMBIENT, m.get_ambient() );
101 xglMaterialfv (GL_FRONT, GL_DIFFUSE, m.get_diffuse() );
104 FGTileEntry* last_tile_ptr = NULL;
105 frag_list_iterator current = list.begin();
106 frag_list_iterator last = list.end();
108 for ( ; current != last; ++current ) {
109 fgFRAGMENT* frag_ptr = *current;
110 tris_rendered += frag_ptr->num_faces();
111 if ( frag_ptr->tile_ptr != last_tile_ptr ) {
112 // new tile, new translate
113 last_tile_ptr = frag_ptr->tile_ptr;
114 xglLoadMatrixf( frag_ptr->tile_ptr->model_view );
117 // Woohoo!!! We finally get to draw something!
118 // printf(" display_list = %d\n", frag_ptr->display_list);
119 xglCallList( frag_ptr->display_list );
122 current_view.set_tris_rendered( tris_rendered );
126 // Load a library of material properties
128 fgMATERIAL_MGR::load_lib ( void )
130 string material_name;
132 // build the path name to the material db
133 FGPath mpath( current_options.get_fg_root() );
134 mpath.append( "materials" );
136 fg_gzifstream in( mpath.str() );
138 FG_LOG( FG_GENERAL, FG_ALERT, "Cannot open file: " << mpath.str() );
142 while ( ! in.eof() ) {
143 // printf("%s", line);
145 // strip leading white space and comments
148 // set to zero to prevent its value accidently being '{'
149 // after a failed >> operation.
152 in >> material_name >> token;
154 if ( token == '{' ) {
155 FG_LOG( FG_TERRAIN, FG_INFO,
156 " Loading material " << material_name );
160 // if ( current_options.get_textures() ) {
161 // m.load_texture( current_options.get_fg_root() );
164 FGMaterialSlot m_slot;
166 material_mgr.material_map[material_name] = m_slot;
170 if ( current_options.get_textures() ) {
171 textures_loaded = true;
178 // Initialize the transient list of fragments for each material property
180 fgMATERIAL_MGR::init_transient_material_lists( void )
182 iterator last = end();
183 for ( iterator it = begin(); it != last; ++it ) {
184 (*it).second.init_sort_list();
190 fgMATERIAL_MGR::find( const string& material, FGMaterialSlot*& mtl_ptr )
192 iterator it = material_map.find( material );
194 mtl_ptr = &((*it).second);
203 fgMATERIAL_MGR::~fgMATERIAL_MGR ( void ) {
208 fgMATERIAL_MGR::render_fragments()
210 current_view.set_tris_rendered( 0 );
212 iterator last = end();
213 for ( iterator current = begin(); current != last; ++current ) {
214 (*current).second.render_fragments();