change mesh example
This commit is contained in:
parent
fe4f6b2b99
commit
47d60bcd14
5
Makefile
5
Makefile
@ -3,8 +3,9 @@ TYPE = ps-exe
|
|||||||
|
|
||||||
SRCS = primdrawGT-db-abs.c \
|
SRCS = primdrawGT-db-abs.c \
|
||||||
../common/crt0/crt0.s \
|
../common/crt0/crt0.s \
|
||||||
TIM/cube.tim \
|
#~ TIM/cube.tim \
|
||||||
TIM/bousai.tim \
|
#~ TIM/bousai.tim \
|
||||||
|
TIM/home.tim \
|
||||||
|
|
||||||
CPPFLAGS += -I../psyq/include
|
CPPFLAGS += -I../psyq/include
|
||||||
LDFLAGS += -L../psyq/lib
|
LDFLAGS += -L../psyq/lib
|
||||||
|
@ -21,18 +21,34 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
filename_ext = ".c";
|
filename_ext = ".c";
|
||||||
|
|
||||||
def execute(self, context):
|
def execute(self, context):
|
||||||
|
import bmesh
|
||||||
|
|
||||||
|
def triangulate_object(obj): # Stolen from here : https://blender.stackexchange.com/questions/45698/triangulate-mesh-in-python/45722#45722
|
||||||
|
me = obj.data
|
||||||
|
# Get a BMesh representation
|
||||||
|
bm = bmesh.new()
|
||||||
|
bm.from_mesh(me)
|
||||||
|
bmesh.ops.triangulate(bm, faces=bm.faces[:], quad_method=0, ngon_method=0)
|
||||||
|
# Finish up, write the bmesh back to the mesh
|
||||||
|
bm.to_mesh(me)
|
||||||
|
bm.free()
|
||||||
|
|
||||||
# Leave edit mode to avoid errors
|
# Leave edit mode to avoid errors
|
||||||
bpy.ops.object.mode_set(mode='OBJECT')
|
bpy.ops.object.mode_set(mode='OBJECT')
|
||||||
|
|
||||||
scale = 20
|
# triangulate objects of type mesh
|
||||||
|
for m in range(len(bpy.data.objects)):
|
||||||
|
if bpy.data.objects[m].type == 'MESH':
|
||||||
|
triangulate_object(bpy.data.objects[m])
|
||||||
|
|
||||||
|
scale = 120
|
||||||
f = open(os.path.normpath(self.filepath),"w+")
|
f = open(os.path.normpath(self.filepath),"w+")
|
||||||
|
|
||||||
# write typedef struct
|
# write typedef struct
|
||||||
f.write("typedef struct { \n"+
|
f.write("typedef struct { \n"+
|
||||||
"\tTMESH * tmesh;\n" +
|
"\tTMESH * tmesh;\n" +
|
||||||
"\tTIM_IMAGE * tim; \n" +
|
|
||||||
"\tint * index;\n" +
|
"\tint * index;\n" +
|
||||||
|
"\tTIM_IMAGE * tim; \n" +
|
||||||
"\tu_long * tim_data;\n"
|
"\tu_long * tim_data;\n"
|
||||||
"\t} MESH;\n\n")
|
"\t} MESH;\n\n")
|
||||||
|
|
||||||
@ -70,9 +86,9 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
# get image size x, y
|
# get image size x, y
|
||||||
# print(bpy.data.meshes[0].uv_textures[0].data[0].image.size[0]) # x
|
# print(bpy.data.meshes[0].uv_textures[0].data[0].image.size[0]) # x
|
||||||
# print(bpy.data.meshes[0].uv_textures[0].data[0].image.size[1]) # y
|
# print(bpy.data.meshes[0].uv_textures[0].data[0].image.size[1]) # y
|
||||||
if len(m.uv_textures) != 0:
|
if m.uv_textures[0].data[0].image != None:
|
||||||
f.write("SVECTOR "+"model"+m.name+"_uv[] = {\n")
|
f.write("SVECTOR "+"model"+m.name+"_uv[] = {\n")
|
||||||
texture_image = m.uv_textures[l].data[0].image
|
texture_image = m.uv_textures[0].data[0].image
|
||||||
tex_width = texture_image.size[0]
|
tex_width = texture_image.size[0]
|
||||||
tex_height = texture_image.size[1]
|
tex_height = texture_image.size[1]
|
||||||
uv_layer = m.uv_layers[0].data
|
uv_layer = m.uv_layers[0].data
|
||||||
@ -91,7 +107,7 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
f.write("CVECTOR "+"model"+m.name+"_color[] = {\n")
|
f.write("CVECTOR "+"model"+m.name+"_color[] = {\n")
|
||||||
# If vertex colors exist, use them
|
# If vertex colors exist, use them
|
||||||
if len(m.vertex_colors) != 0:
|
if len(m.vertex_colors) != 0:
|
||||||
colors = m.vertex_colors["Col"].data
|
colors = m.vertex_colors[0].data
|
||||||
for i in range(len(colors)):
|
for i in range(len(colors)):
|
||||||
f.write("\t"+str(int(colors[i].color.r*255))+","+str(int(colors[i].color.g*255))+","+str(int(colors[i].color.b*255))+", 0")
|
f.write("\t"+str(int(colors[i].color.r*255))+","+str(int(colors[i].color.g*255))+","+str(int(colors[i].color.b*255))+", 0")
|
||||||
if i != len(colors) - 1:
|
if i != len(colors) - 1:
|
||||||
@ -123,10 +139,12 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
f.write("TMESH "+"model"+m.name+" = {\n")
|
f.write("TMESH "+"model"+m.name+" = {\n")
|
||||||
f.write("\t"+"model"+m.name+"_mesh, \n")
|
f.write("\t"+"model"+m.name+"_mesh, \n")
|
||||||
f.write("\t"+"model"+m.name+"_normal,\n")
|
f.write("\t"+"model"+m.name+"_normal,\n")
|
||||||
if len(m.uv_textures) != 0:
|
|
||||||
|
if m.uv_textures[0].data[0].image != None:
|
||||||
f.write("\t"+"model"+m.name+"_uv,\n")
|
f.write("\t"+"model"+m.name+"_uv,\n")
|
||||||
else:
|
else:
|
||||||
f.write("\t0,\n")
|
f.write("\t0,\n")
|
||||||
|
|
||||||
f.write("\t"+"model"+m.name+"_color, \n")
|
f.write("\t"+"model"+m.name+"_color, \n")
|
||||||
|
|
||||||
# According to libgte.h, TMESH.len should be # of vertices. Meh...
|
# According to libgte.h, TMESH.len should be # of vertices. Meh...
|
||||||
@ -135,9 +153,10 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
|
|
||||||
# write texture binary name and declare TIM_IMAGE
|
# write texture binary name and declare TIM_IMAGE
|
||||||
# by default, load the file from the TIM folder
|
# by default, load the file from the TIM folder
|
||||||
if len(m.uv_textures) != 0:
|
# ~ if len(m.uv_textures) != 0:
|
||||||
|
if m.uv_textures[0].data[0].image != None:
|
||||||
tex_name = texture_image.name
|
tex_name = texture_image.name
|
||||||
prefix = str.partition(tex_name, ".")[0]
|
prefix = str.partition(tex_name, ".")[0].replace('-','_')
|
||||||
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_start[];\n")
|
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_start[];\n")
|
||||||
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_end[];\n")
|
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_end[];\n")
|
||||||
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_length;\n\n")
|
f.write("extern unsigned long "+"_binary_TIM_" + prefix + "_tim_length;\n\n")
|
||||||
@ -145,9 +164,15 @@ class ExportMyFormat(bpy.types.Operator, ExportHelper):
|
|||||||
|
|
||||||
f.write("MESH mesh"+m.name+" = {\n")
|
f.write("MESH mesh"+m.name+" = {\n")
|
||||||
f.write("\t&model"+ m.name +",\n")
|
f.write("\t&model"+ m.name +",\n")
|
||||||
f.write("\t&tim_"+ prefix + ",\n")
|
|
||||||
f.write("\tmodel" + m.name + "_index,\n")
|
f.write("\tmodel" + m.name + "_index,\n")
|
||||||
f.write("\t_binary_TIM_" + prefix + "_tim_start\n")
|
|
||||||
|
if m.uv_textures[0].data[0].image != None:
|
||||||
|
f.write("\t&tim_"+ prefix + ",\n")
|
||||||
|
f.write("\t_binary_TIM_" + prefix + "_tim_start\n")
|
||||||
|
else:
|
||||||
|
f.write("0,\n" +
|
||||||
|
"0,\n")
|
||||||
|
|
||||||
f.write("};\n\n")
|
f.write("};\n\n")
|
||||||
|
|
||||||
f.write("MESH * meshes[" + str(len(bpy.data.meshes)) + "] = {\n")
|
f.write("MESH * meshes[" + str(len(bpy.data.meshes)) + "] = {\n")
|
||||||
|
12
primdrawGT.c
12
primdrawGT.c
@ -36,9 +36,9 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
// Sample vector model
|
// Sample vector model
|
||||||
#include "cube.c"
|
#include "coridor.c"
|
||||||
|
|
||||||
#define VMODE 1
|
#define VMODE 0
|
||||||
#define HAS_TEX 0
|
#define HAS_TEX 0
|
||||||
|
|
||||||
#define SCREENXRES 320
|
#define SCREENXRES 320
|
||||||
@ -87,7 +87,7 @@ void init(){
|
|||||||
// Initialize and setup the GTE
|
// Initialize and setup the GTE
|
||||||
InitGeom();
|
InitGeom();
|
||||||
SetGeomOffset(CENTERX, CENTERY); // x, y offset
|
SetGeomOffset(CENTERX, CENTERY); // x, y offset
|
||||||
SetGeomScreen(CENTERX); // Distance between eye and screen
|
SetGeomScreen(CENTERX*2); // Distance between eye and screen
|
||||||
|
|
||||||
// Set the display and draw environments
|
// Set the display and draw environments
|
||||||
SetDefDispEnv(&disp[0], 0, 0 , SCREENXRES, SCREENYRES);
|
SetDefDispEnv(&disp[0], 0, 0 , SCREENXRES, SCREENYRES);
|
||||||
@ -164,7 +164,7 @@ int main() {
|
|||||||
|
|
||||||
|
|
||||||
SVECTOR Rotate={ 0 }; // Rotation coordinates
|
SVECTOR Rotate={ 0 }; // Rotation coordinates
|
||||||
VECTOR Trans={ 0, 0, CENTERX, 0 }; // Translation coordinates
|
VECTOR Trans={ 0, 0, CENTERX*2, 0 }; // Translation coordinates
|
||||||
// Scaling coordinates
|
// Scaling coordinates
|
||||||
VECTOR Scale={ ONE, ONE, ONE, 0 }; // ONE == 4096
|
VECTOR Scale={ ONE, ONE, ONE, 0 }; // ONE == 4096
|
||||||
MATRIX Matrix={0}; // Matrix data for the GTE
|
MATRIX Matrix={0}; // Matrix data for the GTE
|
||||||
@ -262,7 +262,7 @@ int main() {
|
|||||||
setRGB0(poly, meshes[k]->tmesh->c[i].r , meshes[k]->tmesh->c[i].g , meshes[k]->tmesh->c[i].b);
|
setRGB0(poly, meshes[k]->tmesh->c[i].r , meshes[k]->tmesh->c[i].g , meshes[k]->tmesh->c[i].b);
|
||||||
setRGB1(poly, meshes[k]->tmesh->c[i+1].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+1].b);
|
setRGB1(poly, meshes[k]->tmesh->c[i+1].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+1].b);
|
||||||
setRGB2(poly, meshes[k]->tmesh->c[i+2].r, meshes[k]->tmesh->c[i+2].g, meshes[k]->tmesh->c[i+2].b);
|
setRGB2(poly, meshes[k]->tmesh->c[i+2].r, meshes[k]->tmesh->c[i+2].g, meshes[k]->tmesh->c[i+2].b);
|
||||||
|
|
||||||
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
||||||
meshes[k]->tim->prect->x,
|
meshes[k]->tim->prect->x,
|
||||||
meshes[k]->tim->prect->y
|
meshes[k]->tim->prect->y
|
||||||
@ -320,7 +320,7 @@ int main() {
|
|||||||
//~ FntPrint("\n\nGOURAUD SHADED TMESH EXAMPLE\n");
|
//~ FntPrint("\n\nGOURAUD SHADED TMESH EXAMPLE\n");
|
||||||
//~ FntPrint("SCHNAPPY, 2020 \n");
|
//~ FntPrint("SCHNAPPY, 2020 \n");
|
||||||
//~ FntPrint("BASED ON PRIMDRAW BY LAMEGUY64, 2014 \n");
|
//~ FntPrint("BASED ON PRIMDRAW BY LAMEGUY64, 2014 \n");
|
||||||
FntPrint("# tris :%d \n", modelCube.len);
|
FntPrint("# tris :%d \n", sizeof(ot[db])/sizeof(POLY_GT3));
|
||||||
FntPrint("Vsync :%d \n", vs);
|
FntPrint("Vsync :%d \n", vs);
|
||||||
FntPrint("%d ", sizeof(meshes)/sizeof(TMESH *));
|
FntPrint("%d ", sizeof(meshes)/sizeof(TMESH *));
|
||||||
FntPrint("%d ", meshes[0]->tim->prect->y);
|
FntPrint("%d ", meshes[0]->tim->prect->y);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user