annotate SceneGraph/BlenderScript/export_xml.py @ 107:ce5755f544c1 cvs

Initial revision
author chiaki
date Tue, 04 Mar 2008 18:06:44 +0900
parents
children 5c194c71eca8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
1 #!BPY
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
2 """Registration info for Blender menus:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
3 Name: 'Libps3 (.xml)'
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
4 Blender: 240
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
5 Group: 'Export'
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
6 Tooltip: 'Export to (.xml) for libps3'
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
7 """
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
8
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
9
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
10 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
11 # Importing modules
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
12 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
13
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
14 import math
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
15 #import subprocess
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
16 import os
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
17 import Blender
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
18 import struct
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
19 import base64
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
20 from Blender import NMesh, Scene, Object, Material, Texture, Window
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
21 from Blender import sys as bsys, Mathutils, Draw, BGL
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
22 from Blender.sys import *
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
23
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
24
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
25 def info(object, spacing=10, collapse=1):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
26 """Print methods and doc strings.
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
27
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
28 Takes module, class, list, dictionary, or string."""
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
29 methodList = [e for e in dir(object) if callable(getattr(object, e))]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
30 processFunc = collapse and (lambda s: " ".join(s.split())) or (lambda s: s)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
31 print "\n".join(["%s %s" %
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
32 (method.ljust(spacing),
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
33 processFunc(str(getattr(object, method).__doc__)))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
34 for method in methodList])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
35
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
36
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
37 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
38 # Data Structures
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
39 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
40
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
41
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
42
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
43
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
44 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
45 # Functions
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
46 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
47
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
48
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
49 # New name based on old with a different extension
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
50 def newFName(ext):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
51 return Blender.Get('filename')[: -len(Blender.Get('filename').split('.', -1)[-1]) ] + ext
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
52
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
53
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
54 #exporting an anime
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
55 def export_anime(object_name):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
56 startF = Blender.Get('staframe')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
57 endF = Blender.Get('endframe')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
58 str = ""
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
59 str += "\t\t<anim frame=\"%d\">\n" %(endF)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
60 for i in range (startF, endF+1):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
61 Blender.Set('curframe', i)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
62 Blender.Redraw()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
63 time1 = Blender.sys.time()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
64
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
65 ##### XML header ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
66 #get all the objects in this scene
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
67 activelayers = Window.ViewLayer()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
68 for i in range(len(activelayers)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
69 activelayers[i] = 2**(activelayers[i]-1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
70 object_list1 = Blender.Scene.GetCurrent().getChildren()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
71 object_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
72 matnames= []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
73 for obj in object_list1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
74 if obj.Layer in activelayers:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
75 object_list.append(obj)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
76
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
77 if obj.getType() == "Mesh":
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
78 materials_obj_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
79 materials_obj_list = obj.getData().materials
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
80 for mat in materials_obj_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
81 if mat.name not in matnames:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
82 matnames.append(mat.name)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
83
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
84 ##### Process Meshes ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
85 for obj in object_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
86 matrix = obj.getMatrix()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
87 if obj == object_name:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
88 str +="\t\t\t%f %f %f\n" %(matrix[3][0], matrix[3][1], matrix[3][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
89
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
90 str += "\t\t</anim>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
91 return str
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
92
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
93
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
94
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
95 # exporting a mesh
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
96 def exportMesh(mesh, obj):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
97 vdata = [] # list of [ii0, ii1, ii2, ...] lists indexed by Blender-Vertex-index
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
98 vlist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
99 flist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
100 tri_first = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
101 tri_second = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
102 tri_third = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
103
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
104 def addVertex(bvindex, coord, normal, uv):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
105 index = -1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
106 if bvindex < len(vdata):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
107 for ivindex in vdata[bvindex]:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
108 v = vlist[ivindex]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
109 if (abs(v[0][0]-coord[0])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
110 (abs(v[0][1]-coord[1])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
111 (abs(v[0][2]-coord[2])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
112 (abs(v[1][0]-normal[0])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
113 (abs(v[1][1]-normal[1])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
114 (abs(v[1][2]-normal[2])<0.0001):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
115 if ((v[2]==[]) and (uv==[])) or \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
116 ((abs(v[2][0]-uv[0])<0.0001) and \
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
117 (abs(v[2][1]-uv[1])<0.0001)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
118 index = ivindex
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
119 if index < 0:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
120 index = len(vlist)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
121 vlist.append([coord, normal, uv])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
122 while bvindex >= len(vdata):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
123 vdata.append([])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
124 vdata[bvindex].append(index)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
125 return index
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
126
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
127 def addFace(mindex, index0, index1, index2):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
128 while mindex >= len(flist):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
129 flist.append([])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
130 flist[mindex].append([index0, index1, index2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
131
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
132 def getFaces():
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
133 str = ""
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
134 matrix = obj.getMatrix()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
135
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
136 for mindex in range(len(flist)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
137 fl = flist[mindex]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
138 if fl != []:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
139 parent_name = obj.getParent()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
140 if parent_name:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
141 parent_name = "%s" %parent_name
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
142 str += "\t<surface name=\"%s\" size=\"%d\" prim=\"Triangle\" parent=%s>\n" %(obj.name, len(fl)*3, parent_name[8:-1])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
143 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
144 str += "\t<surface name=\"%s\" size=\"%d\" prim=\"Triangle\" parent=\"NULL\">\n" %(obj.name, len(fl)*3)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
145
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
146 str += "\t\t<coordinate>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
147 for f in fl:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
148 tri_first = vlist[f[0]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
149 tri_second = vlist[f[1]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
150 tri_third = vlist[f[2]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
151
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
152 str += "\t\t\t%f %f %f\n" %(tri_first[0][0] + matrix[3][0], tri_first[0][1] + matrix[3][1], tri_first[0][2] + matrix[3][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
153 str += "\t\t\t%f %f %f\n" %(tri_second[0][0] + matrix[3][0], tri_second[0][1] + matrix[3][1], tri_second[0][2] + matrix[3][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
154 str += "\t\t\t%f %f %f\n" %(tri_third[0][0] + matrix[3][0], tri_third[0][1] + matrix[3][1], tri_third[0][2] + matrix[3][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
155 str += "\t\t</coordinate>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
156
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
157 str += "\t\t<normal>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
158 for f in fl:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
159 tri_first = vlist[f[0]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
160 tri_second = vlist[f[1]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
161 tri_third = vlist[f[2]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
162
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
163 str += "\t\t\t%f %f %f\n" %(tri_first[1][0], tri_first[1][1], tri_first[1][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
164 str += "\t\t\t%f %f %f\n" %(tri_second[1][0], tri_second[1][1], tri_second[1][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
165 str += "\t\t\t%f %f %f\n" %(tri_third[1][0], tri_third[1][1], tri_third[1][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
166 str += "\t\t</normal>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
167
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
168 str += "\t\t<model>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
169 ###parameter of translate
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
170 str += "\t\t\t%f %f %f\n" % (matrix[3][0], matrix[3][1], matrix[3][2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
171 str += "\t\t</model>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
172
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
173 if tri_first[2] != []:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
174 str += "\t\t<texture>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
175 for f in fl:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
176 tri_first = vlist[f[0]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
177 tri_second = vlist[f[1]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
178 tri_third = vlist[f[2]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
179
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
180 str += "\t\t\t%f %f\n" %(tri_first[2][0], tri_first[2][1])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
181 str += "\t\t\t%f %f\n" %(tri_second[2][0], tri_second[2][1])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
182 str += "\t\t\t%f %f\n" %(tri_third[2][0], tri_third[2][1])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
183 str += "\t\t</texture>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
184 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
185 str += "\t\t<texture/>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
186
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
187
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
188 ### get texture_image and change base64 data
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
189 texture = mesh.faces[0].image
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
190 if texture:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
191 str += "\t\t<image name=\"%s\">\n" %(texture.getName())
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
192 image_path = texture.getFilename()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
193 input = open(expandpath(image_path), 'r')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
194 output = open('output.txt', 'w')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
195 base64.encode(input,output)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
196 input.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
197 output.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
198 input = open('output.txt', 'r')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
199 for b64 in input.readlines():
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
200 str += "\t\t\t%s" %b64
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
201 input.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
202 str += "\t\t</image>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
203 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
204 str += "\t\t<image/>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
205
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
206 #str += "\t</surface>\n"
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
207
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
208 return str
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
209
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
210 vdata = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
211 vlist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
212 flist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
213 for face in mesh.faces:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
214 iis = [-1, -1, -1, -1]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
215 for vi in range(len(face.v)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
216 vert = face.v[vi]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
217 if face.smooth:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
218 normal = vert.no
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
219 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
220 normal = face.no
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
221 if len(face.uv) == len(face.v):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
222 uv = face.uv[vi]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
223 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
224 uv = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
225 iis[vi] = addVertex(vert.index, vert.co, normal, uv)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
226 addFace(face.materialIndex, iis[0], iis[1], iis[2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
227 if len(face.v)==4:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
228 addFace(face.materialIndex, iis[2], iis[3], iis[0])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
229
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
230 str = ""
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
231 str += getFaces()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
232
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
233 return str
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
234
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
235
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
236 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
237 # EXPORT
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
238 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
239 def save_xml(filename, unindexedname, anim):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
240 print("XML EXPORT\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
241 time1 = Blender.sys.time()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
242 print("Saving to '" + filename + "'...\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
243 file = open(filename, 'w')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
244
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
245 count_h = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
246 n = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
247 filename_h = filename[:-4] + ".h" #header file for cpp
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
248 file_h = open(filename_h, 'w')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
249
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
250 ##### XML header ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
251 file.write("<?xml version=\"1.0\"?>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
252
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
253 #get all the objects in this scene
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
254 activelayers = Window.ViewLayer()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
255 for i in range(len(activelayers)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
256 activelayers[i] = 2**(activelayers[i]-1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
257 object_list1 = Blender.Scene.GetCurrent().getChildren()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
258 object_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
259 matnames= []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
260 for obj in object_list1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
261 if obj.Layer in activelayers:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
262 object_list.append(obj)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
263
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
264 if obj.getType() == "Mesh":
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
265 materials_obj_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
266 materials_obj_list = obj.getData().materials
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
267 for mat in materials_obj_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
268 if mat.name not in matnames:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
269 matnames.append(mat.name)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
270
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
271 ##### Process Meshes ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
272 meshlist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
273 file.write("<OBJECT-3D>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
274 for obj in object_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
275 if obj.getType() == "Mesh":
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
276 objectname = obj.getName()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
277 mesh = Blender.NMesh.GetRawFromObject(objectname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
278 meshname = mesh.name
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
279 meshlight = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
280 if len(mesh.materials) > 0:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
281 mat0 = mesh.materials[0]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
282 if mat0.emit > 0:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
283 meshlight = 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
284 if meshlight:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
285 print "processing Object \"%s\" as Meshlight (Mesh \"%s\")..." %(objectname, meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
286 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
287 print "processing Object \"%s\" (Mesh \"%s\")..." %(objectname, meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
288 try:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
289 meshlist.index(meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
290 except ValueError:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
291 file.write(exportMesh(mesh,obj))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
292 meshlist.append(meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
293 if anim == 1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
294 #file.write("\t\t<anim>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
295 file.write(export_anime(obj))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
296 #file.write("\t\t</anim>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
297 file.write("\t</surface>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
298 file_h.write("#define %s scene_graph" %(obj.name))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
299 while n != count_h:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
300 file_h.write("->next")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
301 n = n + 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
302 file_h.write("\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
303 count_h = count_h + 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
304 n = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
305
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
306
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
307 ##### XML FOOTER ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
308 file.write("</OBJECT-3D>")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
309 file.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
310 file_h.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
311 print("Finished.\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
312
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
313 time2 = Blender.sys.time()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
314 print("Processing time: %f\n" %(time2-time1))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
315 Draw.Exit()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
316
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
317
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
318 ### SAVE ANIMATION ###
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
319 def save_anim(filename):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
320 global MatSaved
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
321
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
322 MatSaved = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
323 unindexedname = filename
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
324 save_xml(filename, unindexedname, 1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
325
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
326
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
327 #### SAVE STILL (hackish...) ####
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
328 def save_still(filename):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
329 global MatSaved
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
330
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
331 MatSaved = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
332 unindexedname = filename
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
333 save_xml(filename, unindexedname, 0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
334
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
335 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
336 # Settings GUI
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
337 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
338
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
339 # Assign event numbers to buttons
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
340 evtNoEvt = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
341 evtExport = 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
342 evtExportAnim = 2
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
343
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
344 # Set initial values of buttons
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
345
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
346 ## <size>800 600</size>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
347
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
348 sceneSizeX = Scene.GetCurrent().getRenderingContext().imageSizeX()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
349 sceneSizeY = Scene.GetCurrent().getRenderingContext().imageSizeY()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
350
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
351 SizeX = Draw.Create(sceneSizeX)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
352 SizeY = Draw.Create(sceneSizeY)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
353 TexExponent = Draw.Create(2.3)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
354
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
355 ## <metropolis>1</metropolis>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
356 MLT = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
357
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
358 ## <large_mutation_prob>0.1</large_mutation_prob>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
359 LMP = Draw.Create(0.1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
360
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
361 ## <max_change>0.02</max_change>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
362 MaxChange = Draw.Create(0.02)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
363
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
364 ## <russian_roulette_live_prob>0.7</russian_roulette_live_prob>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
365 RRLP = Draw.Create(0.7)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
366
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
367 ## <max_depth>100</max_depth>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
368 MaxDepth = Draw.Create(100)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
369
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
370 ## <bidirectional>false</bidirectional>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
371 Bidirectional = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
372
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
373 ## <strata_width>14</strata_width>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
374 StrataWidth = Draw.Create(14)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
375
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
376 ## <logging>0</logging>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
377 Logging = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
378
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
379 ## <save_untonemapped_exr>false</save_untonemapped_exr>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
380 SaveUTMExr = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
381
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
382 ## <save_tonemapped_exr>false</save_tonemapped_exr>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
383 SaveTMExr = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
384
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
385 ## <lens_radius>0.0</lens_radius>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
386 LensRadius = Draw.Create(0.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
387
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
388 ## <focus_distance>2.0</focus_distance>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
389 FocusDistance = Draw.Create(2.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
390
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
391 ## <turbidity>2.0</turbidity>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
392 Turbidity = Draw.Create(2.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
393
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
394 GroundPlane = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
395
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
396 ## Separate materials
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
397 MatFile = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
398
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
399 # text color fix
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
400 textcol = [0, 0, 0]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
401
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
402
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
403 def gui():
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
404 global evtNoEvt, evtExport, evtExportAnim
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
405 global SizeX, SizeY, TexExponent, MLT, LMP, MaxChange, RRLP, MaxDepth, Bidirectional, StrataWidth, Logging, SaveUTMExr, SaveTMExr, LensRadius, FocusDistance,Turbidity, GroundPlane, MatFile
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
406 global textcol
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
407
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
408 Draw.Button("Export", evtExport, 10, 25, 100, 18, "Open file dialog and export")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
409 Draw.Button("Export Animation", evtExportAnim, 130, 25, 150, 18, "Open filedialog and export animation (careful: takes a lot of diskspace!!!)")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
410 BGL.glColor3f(textcol[0], textcol[1], textcol[2]) ; BGL.glRasterPos2i(10,10) ; Draw.Text("Press Q or ESC to quit.", "tiny")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
411
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
412 BGL.glRasterPos2i(10,60) ; Draw.Text("xml exporter for libps3")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
413
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
414
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
415 def event(evt, val): # function that handles keyboard and mouse events
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
416 if evt == Draw.ESCKEY or evt == Draw.QKEY:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
417 stop = Draw.PupMenu("OK?%t|Cancel export %x1")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
418 if stop == 1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
419 Draw.Exit()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
420 return
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
421
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
422 def buttonEvt(evt): # function that handles button events
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
423 if evt == evtExport:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
424 Blender.Window.FileSelector(save_still, "Export", newFName('xml'))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
425 if evt == evtExportAnim:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
426 Blender.Window.FileSelector(save_anim, "Export Animation", newFName('xml'))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
427 #if there was an event, redraw the window
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
428 if evt:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
429 Draw.Redraw()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
430
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
431 Draw.Register(gui, event, buttonEvt)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
432
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
433