annotate SceneGraph/BlenderScript/export_xml.py @ 658:30a72124c7fd

export_xml3 for Blender 2.5 ( not yet worked )
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 27 Nov 2009 18:22:20 +0900
parents fffbfbfc9e34
children 22d7263cec2d
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
345
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
24 global images, imageCount
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
25 images = {}
fffbfbfc9e34 [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)
658
30a72124c7fd 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" %
30a72124c7fd 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),
30a72124c7fd 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__)))
30a72124c7fd 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
fffbfbfc9e34 [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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
58 ###change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
59 #def export_anime(object_name):
5c194c71eca8 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')
658
30a72124c7fd 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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
63 #str = ""
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
64 file.write("")
5c194c71eca8 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
658
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
71 ##### XML header ######
30a72124c7fd 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
5c194c71eca8 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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
96 file.write("\t\t</anim>\n")
658
30a72124c7fd 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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
102 ##change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
103 #def exportMesh(mesh, obj):
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
104 def exportMesh(mesh, obj, file):
5c194c71eca8 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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
141 ###change
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
142 def getFaces():
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
143 ##change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
144 #str = ""
5c194c71eca8 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()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
147
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
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
154 ###change
5c194c71eca8 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])
5c194c71eca8 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
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<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
160 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
161 ###change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
162 #str += "\t\t<coordinate>\n"
5c194c71eca8 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
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
169 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
170 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
171 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
172 file.write("\t\t</coordinate>\n")
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
173
109
5c194c71eca8 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
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
180 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
181 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
182 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
183 file.write("\t\t</normal>\n" )
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
184
109
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 ###parameter of translate
109
5c194c71eca8 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]) )
5c194c71eca8 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
5c194c71eca8 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]]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
196
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
197 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
198 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
199 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
200 file.write("\t\t</texture>\n")
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
201 else:
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
202 file.write("\t\t<texture/>\n")
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
203
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
204
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
205 ### get texture_image and change base64 data
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
206 texture = mesh.faces[0].image
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
207 if texture:
345
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
208 file.write(loadTexture(texture))
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
209
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
210 else:
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
211 file.write("\t\t<image name=\"%s\">\n" %("sample_white.png") )
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
212
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
213 file.write("\t\t\tiVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAAAAADhZOFXAAAAEElEQVQImWP8zwABTAwUMQBJQQEP\n");
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
214 file.write("\t\t\tlYH+agAAAABJRU5ErkJggg==\n");
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
215
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
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
218 #return str
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
219
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
220 vdata = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
221 vlist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
222 flist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
223 for face in mesh.faces:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
224 iis = [-1, -1, -1, -1]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
225 for vi in range(len(face.v)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
226 vert = face.v[vi]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
227 if face.smooth:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
228 normal = vert.no
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
229 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
230 normal = face.no
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
231 if len(face.uv) == len(face.v):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
232 uv = face.uv[vi]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
233 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
234 uv = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
235 iis[vi] = addVertex(vert.index, vert.co, normal, uv)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
236 addFace(face.materialIndex, iis[0], iis[1], iis[2])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
237 if len(face.v)==4:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
238 addFace(face.materialIndex, iis[2], iis[3], iis[0])
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
239
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
240 #str = ""
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
241 #str += getFaces()
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
242 getFaces();
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
243
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
244 #return str
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
245
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
246
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
247 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
248 # EXPORT
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
249 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
250 def save_xml(filename, unindexedname, anim):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
251 print("XML EXPORT\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
252 time1 = Blender.sys.time()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
253 print("Saving to '" + filename + "'...\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
254 file = open(filename, 'w')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
255
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
256 count_h = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
257 n = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
258 filename_h = filename[:-4] + ".h" #header file for cpp
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
259 file_h = open(filename_h, 'w')
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
260
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
261 ##### XML header ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
262 file.write("<?xml version=\"1.0\"?>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
263
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
264 #get all the objects in this scene
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
265 activelayers = Window.ViewLayer()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
266 for i in range(len(activelayers)):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
267 activelayers[i] = 2**(activelayers[i]-1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
268 object_list1 = Blender.Scene.GetCurrent().getChildren()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
269 object_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
270 matnames= []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
271 for obj in object_list1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
272 if obj.Layer in activelayers:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
273 object_list.append(obj)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
274
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
275 if obj.getType() == "Mesh":
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
276 materials_obj_list = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
277 materials_obj_list = obj.getData().materials
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
278 for mat in materials_obj_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
279 if mat.name not in matnames:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
280 matnames.append(mat.name)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
281
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
282 ##### Process Meshes ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
283 meshlist = []
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
284 file.write("<OBJECT-3D>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
285 for obj in object_list:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
286 if obj.getType() == "Mesh":
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
287 objectname = obj.getName()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
288 mesh = Blender.NMesh.GetRawFromObject(objectname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
289 meshname = mesh.name
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
290 meshlight = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
291 if len(mesh.materials) > 0:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
292 mat0 = mesh.materials[0]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
293 if mat0.emit > 0:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
294 meshlight = 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
295 if meshlight:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
296 print "processing Object \"%s\" as Meshlight (Mesh \"%s\")..." %(objectname, meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
297 else:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
298 print "processing Object \"%s\" (Mesh \"%s\")..." %(objectname, meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
299 try:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
300 meshlist.index(meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
301 except ValueError:
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
302 ###change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
303 #file.write(exportMesh(mesh,obj))
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
304 exportMesh(mesh,obj,file)
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
305 meshlist.append(meshname)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
306 if anim == 1:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
307 #file.write("\t\t<anim>\n")
109
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
308 ###change
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
309 #file.write(export_anime(obj))
5c194c71eca8 Cerium cvs version
gongo@gendarme.local
parents: 107
diff changeset
310 export_anime(obj,file)
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
311 #file.write("\t\t</anim>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
312 file.write("\t</surface>\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
313 file_h.write("#define %s scene_graph" %(obj.name))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
314 while n != count_h:
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
315 file_h.write("->next")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
316 n = n + 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
317 file_h.write("\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
318 count_h = count_h + 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
319 n = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
320
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
321
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
322 ##### XML FOOTER ######
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
323 file.write("</OBJECT-3D>")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
324 file.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
325 file_h.close()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
326 print("Finished.\n")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
327
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
328 time2 = Blender.sys.time()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
329 print("Processing time: %f\n" %(time2-time1))
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
330 Draw.Exit()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
331
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
332
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
333 ### SAVE ANIMATION ###
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
334 def save_anim(filename):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
335 global MatSaved
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
336
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
337 MatSaved = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
338 unindexedname = filename
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
339 save_xml(filename, unindexedname, 1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
340
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
341
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
342 #### SAVE STILL (hackish...) ####
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
343 def save_still(filename):
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
344 global MatSaved
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
345
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
346 MatSaved = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
347 unindexedname = filename
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
348 save_xml(filename, unindexedname, 0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
349
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
350 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
351 # Settings GUI
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
352 ######################################################
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
353
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
354 # Assign event numbers to buttons
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
355 evtNoEvt = 0
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
356 evtExport = 1
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
357 evtExportAnim = 2
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
358
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
359 # Set initial values of buttons
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
360
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
361 ## <size>800 600</size>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
362
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
363 sceneSizeX = Scene.GetCurrent().getRenderingContext().imageSizeX()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
364 sceneSizeY = Scene.GetCurrent().getRenderingContext().imageSizeY()
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
365
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
366 SizeX = Draw.Create(sceneSizeX)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
367 SizeY = Draw.Create(sceneSizeY)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
368 TexExponent = Draw.Create(2.3)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
369
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
370 ## <metropolis>1</metropolis>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
371 MLT = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
372
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
373 ## <large_mutation_prob>0.1</large_mutation_prob>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
374 LMP = Draw.Create(0.1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
375
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
376 ## <max_change>0.02</max_change>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
377 MaxChange = Draw.Create(0.02)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
378
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
379 ## <russian_roulette_live_prob>0.7</russian_roulette_live_prob>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
380 RRLP = Draw.Create(0.7)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
381
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
382 ## <max_depth>100</max_depth>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
383 MaxDepth = Draw.Create(100)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
384
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
385 ## <bidirectional>false</bidirectional>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
386 Bidirectional = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
387
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
388 ## <strata_width>14</strata_width>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
389 StrataWidth = Draw.Create(14)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
390
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
391 ## <logging>0</logging>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
392 Logging = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
393
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
394 ## <save_untonemapped_exr>false</save_untonemapped_exr>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
395 SaveUTMExr = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
396
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
397 ## <save_tonemapped_exr>false</save_tonemapped_exr>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
398 SaveTMExr = Draw.Create(0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
399
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
400 ## <lens_radius>0.0</lens_radius>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
401 LensRadius = Draw.Create(0.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
402
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
403 ## <focus_distance>2.0</focus_distance>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
404 FocusDistance = Draw.Create(2.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
405
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
406 ## <turbidity>2.0</turbidity>
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
407 Turbidity = Draw.Create(2.0)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
408
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
409 GroundPlane = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
410
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
411 ## Separate materials
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
412 MatFile = Draw.Create(1)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
413
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
414 # text color fix
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
415 textcol = [0, 0, 0]
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
416
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
417
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
418 def gui():
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
419 global evtNoEvt, evtExport, evtExportAnim
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
420 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
421 global textcol
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
422
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
423 Draw.Button("Export", evtExport, 10, 25, 100, 18, "Open file dialog and export")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
424 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
425 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
426
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
427 BGL.glRasterPos2i(10,60) ; Draw.Text("xml exporter for libps3")
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
428
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
429
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
430 def event(evt, val): # function that handles keyboard and mouse events
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
431 if evt == Draw.ESCKEY or evt == Draw.QKEY:
658
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
432 stop = Draw.PupMenu("OK?%t|Cancel export %x1")
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
433 if stop == 1:
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
434 Draw.Exit()
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
435 return
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
436
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
437 def buttonEvt(evt): # function that handles button events
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
438 if evt == evtExport:
658
30a72124c7fd 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_still, "Export", newFName('xml'))
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
440 if evt == evtExportAnim:
658
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
441 Blender.Window.FileSelector(save_anim, "Export Animation", newFName('xml'))
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
442 #if there was an event, redraw the window
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
443 if evt:
658
30a72124c7fd export_xml3 for Blender 2.5 ( not yet worked )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 345
diff changeset
444 Draw.Redraw()
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
445
345
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
446
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
447 def loadTexture(texture):
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
448 global images, imageCount
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
449 name = texture.getName()
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
450 if name in images:
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
451 return "\t\t<image name=\"" + name + "\"/>\n"
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
452 out = "\t\t<image name=\"" + name + "\">\n"
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
453 imageCount += 1
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
454 images[name] = imageCount
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
455 image_path = texture.getFilename()
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
456 input = open(expandpath(image_path), 'r')
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
457 output = open('output.txt', 'w')
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
458 base64.encode(input,output)
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
459 input.close()
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
460 output.close()
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
461 input = open('output.txt', 'r')
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
462 for b64 in input.readlines():
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
463 out += "\t\t\t%s" %b64
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
464 input.close()
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
465 os.remove('output.txt')
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
466 out += "\t\t</image>\n"
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
467 return out
fffbfbfc9e34 [BlenderScript/export_xml.py] deplicate image
aaa
parents: 109
diff changeset
468
107
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
469 Draw.Register(gui, event, buttonEvt)
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
470
ce5755f544c1 Initial revision
chiaki
parents:
diff changeset
471