changeset 942:27df980045b5 draft

FB mode is working again on Mac OS X.
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 31 Jul 2010 18:37:10 +0900
parents fc6cfaae6de7
children 6dca1f2fb3b9
files Renderer/Engine/SceneGraph.cc Renderer/Engine/SceneGraph.h Renderer/Engine/texture.h Renderer/Engine/viewerGL.cc
diffstat 4 files changed, 13 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/Renderer/Engine/SceneGraph.cc	Sat Jul 31 17:50:38 2010 +0900
+++ b/Renderer/Engine/SceneGraph.cc	Sat Jul 31 18:37:10 2010 +0900
@@ -215,7 +215,6 @@
     flag_drawable = 1;
     sgid = -1;
     gid = -1;
-    gl_tex = NULL;
 
     frame = 0;
 }
@@ -465,7 +464,7 @@
         texture_image = converted;
     }
 
-    this->gl_tex = SDL_GL_LoadTexture(texture_image);
+    // this->gl_tex = SDL_GL_LoadTexture(texture_image);
     return texture_image;
 }
 
@@ -507,6 +506,7 @@
                 list[id].pixels_orig = (Uint32*)texture_image->pixels;
                 list[id].pixels = tapestry;
                 list[id].scale_max = scale;
+                list[id].texture_image = texture_image;
 
                 return id;
     }
@@ -552,6 +552,7 @@
       texture_info.pixels_orig = list[texture_id].pixels_orig;
       texture_info.pixels = list[texture_id].pixels;
       texture_info.scale_max = list[texture_id].scale_max;
+      texture_info.texture_image = list[texture_id].texture_image;
 
 }
 
--- a/Renderer/Engine/SceneGraph.h	Sat Jul 31 17:50:38 2010 +0900
+++ b/Renderer/Engine/SceneGraph.h	Sat Jul 31 18:37:10 2010 +0900
@@ -70,9 +70,6 @@
     // Group ID
     int gid;
 
-    // GL ID
-    GLuint gl_tex;
-
     // 関数ポインタ
     move_func move;
     collision_func collision;
--- a/Renderer/Engine/texture.h	Sat Jul 31 17:50:38 2010 +0900
+++ b/Renderer/Engine/texture.h	Sat Jul 31 18:37:10 2010 +0900
@@ -4,8 +4,9 @@
 #include <SDL.h>
 #include <SDL_opengl.h>
 
-int power_of_two(int input);
-GLuint SDL_GL_LoadTexture(SDL_Surface *surface);
+extern int power_of_two(int input);
+extern GLuint SDL_GL_LoadTexture(SDL_Surface *surface);
+
 
 typedef struct texture_list {
     int t_w;
@@ -13,7 +14,9 @@
     uint32 *pixels_orig;
     uint32 *pixels;
     int scale_max;
-    int pad[3]; // 12
+    SDL_Surface *texture_image;
+    GLuint gl_tex;
+    int pad[1]; // 12
 
 } texture_list, *texture_list_ptr ; // 20 + pad(12) = 32
 
--- a/Renderer/Engine/viewerGL.cc	Sat Jul 31 17:50:38 2010 +0900
+++ b/Renderer/Engine/viewerGL.cc	Sat Jul 31 18:37:10 2010 +0900
@@ -198,7 +198,10 @@
 
   while (sg) {
     if (sg->flag_drawable) {
-      texture = sg->gl_tex;
+      if (!sg->texture_info.gl_tex) {
+	 sg->texture_info.gl_tex = SDL_GL_LoadTexture(sg->texture_info.texture_image);
+      }
+      texture = sg->texture_info.gl_tex;
       glBindTexture(GL_TEXTURE_2D, texture);
 
       glEnable(GL_TEXTURE_2D);