annotate SceneGraph/BlenderScript/export_xml.py @ 1888:5238ca826d6e draft

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