annotate SceneGraph/BlenderScript/export_xml.py @ 109:5c194c71eca8

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