forked from bartvdbraak/blender
added multilayer vertexColor support to fbx and removed videoscape_export.py
This commit is contained in:
parent
71843bf103
commit
417498a865
@ -5,7 +5,7 @@ Blender: 243
|
||||
Group: 'Export'
|
||||
Tooltip: 'Selection to an ASCII Autodesk FBX '
|
||||
"""
|
||||
__author__ = "Campbell Barton, Jiri Hnidek"
|
||||
__author__ = "Campbell Barton"
|
||||
__url__ = ['www.blender.org', 'blenderartists.org']
|
||||
__version__ = "1.1"
|
||||
|
||||
@ -1694,7 +1694,62 @@ Objects: {''')
|
||||
file.write('\n\t\t}')
|
||||
|
||||
|
||||
|
||||
|
||||
# Write VertexColor Layers
|
||||
collayers = []
|
||||
if me.vertexColors:
|
||||
collayers = me.getColorLayerNames()
|
||||
collayer_orig = me.activeColorLayer
|
||||
for colindex, collayer in enumerate(collayers):
|
||||
me.activeColorLayer = collayer
|
||||
file.write('\n\t\tLayerElementColor: %i {' % colindex)
|
||||
file.write('\n\t\t\tVersion: 101')
|
||||
file.write('\n\t\t\tName: "%s"' % collayer)
|
||||
|
||||
file.write('''
|
||||
MappingInformationType: "ByPolygonVertex"
|
||||
ReferenceInformationType: "IndexToDirect"
|
||||
Colors: ''')
|
||||
|
||||
i = -1
|
||||
ii = 0 # Count how many Colors we write
|
||||
|
||||
for f in me.faces:
|
||||
for col in f.col:
|
||||
if i==-1:
|
||||
file.write('%i,%i,%i' % (col[0], col[1], col[2]))
|
||||
i=0
|
||||
else:
|
||||
if i==7:
|
||||
file.write('\n ')
|
||||
i=0
|
||||
file.write(',%i,%i,%i' % (col[0], col[1], col[2]))
|
||||
i+=1
|
||||
ii+=1 # One more Color
|
||||
|
||||
file.write('\n\t\t\tColorIndex: ')
|
||||
i = -1
|
||||
for j in xrange(ii):
|
||||
if i == -1:
|
||||
file.write('%i' % j)
|
||||
i=0
|
||||
else:
|
||||
if i==55:
|
||||
file.write('\n ')
|
||||
i=0
|
||||
file.write(',%i' % j)
|
||||
i+=1
|
||||
|
||||
file.write('\n\t\t}')
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
# Write UV and texture layers.
|
||||
uvlayers = []
|
||||
if me.faceUV:
|
||||
uvlayers = me.getUVLayerNames()
|
||||
uvlayer_orig = me.activeUVLayer
|
||||
@ -1725,7 +1780,7 @@ Objects: {''')
|
||||
i+=1
|
||||
ii+=1 # One more UV
|
||||
|
||||
file.write('\n UVIndex: ')
|
||||
file.write('\n\t\t\tUVIndex: ')
|
||||
i = -1
|
||||
for j in xrange(ii):
|
||||
if i == -1:
|
||||
@ -1733,12 +1788,12 @@ Objects: {''')
|
||||
i=0
|
||||
else:
|
||||
if i==55:
|
||||
file.write('\n ')
|
||||
file.write('\n\t\t\t\t')
|
||||
i=0
|
||||
file.write(',%i' % j)
|
||||
i+=1
|
||||
|
||||
file.write('\n }')
|
||||
file.write('\n\t\t}')
|
||||
|
||||
if textures:
|
||||
file.write('\n\t\tLayerElementTexture: %i {' % uvindex)
|
||||
@ -1847,7 +1902,14 @@ Objects: {''')
|
||||
Type: "LayerElementTexture"
|
||||
TypedIndex: 0
|
||||
}''')
|
||||
|
||||
|
||||
if me.vertexColors:
|
||||
file.write('''
|
||||
LayerElement: {
|
||||
Type: "LayerElementColor"
|
||||
TypedIndex: 0
|
||||
}''')
|
||||
|
||||
if me.faceUV:
|
||||
file.write('''
|
||||
LayerElement: {
|
||||
@ -1858,7 +1920,7 @@ Objects: {''')
|
||||
|
||||
file.write('\n\t\t}')
|
||||
|
||||
if me.faceUV and len(uvlayers) > 1:
|
||||
if len(uvlayers) > 1:
|
||||
for i in xrange(1, len(uvlayers)):
|
||||
|
||||
file.write('\n\t\tLayer: %i {' % i)
|
||||
@ -1881,8 +1943,23 @@ Objects: {''')
|
||||
file.write('\n\t\t\t}')
|
||||
|
||||
file.write('\n\t\t}')
|
||||
|
||||
|
||||
if len(collayers) > 1:
|
||||
# Take into account any UV layers
|
||||
layer_offset = 0
|
||||
if uvlayers: layer_offset = len(uvlayers)-1
|
||||
|
||||
for i in xrange(layer_offset, len(collayers)+layer_offset):
|
||||
file.write('\n\t\tLayer: %i {' % i)
|
||||
file.write('\n\t\t\tVersion: 100')
|
||||
|
||||
file.write('''
|
||||
LayerElement: {
|
||||
Type: "LayerElementColor"''')
|
||||
|
||||
file.write('\n\t\t\t\tTypedIndex: %i' % i)
|
||||
file.write('\n\t\t\t}')
|
||||
file.write('\n\t\t}')
|
||||
file.write('\n\t}')
|
||||
|
||||
|
||||
|
@ -1,282 +0,0 @@
|
||||
#!BPY
|
||||
|
||||
"""
|
||||
Name: 'VideoScape with Vertex Colors (.obj)...'
|
||||
Blender: 232
|
||||
Group: 'Export'
|
||||
Tooltip: 'Export selected mesh to VideoScape File Format (.obj)'
|
||||
"""
|
||||
|
||||
__author__ = "Anthony D'Agostino (Scorpius)"
|
||||
__url__ = ("blender", "elysiun",
|
||||
"Author's homepage, http://www.redrival.com/scorpius")
|
||||
__version__ = "Part of IOSuite 0.5"
|
||||
|
||||
__bpydoc__ = """\
|
||||
This script exports meshes (including vertex colors) to VideoScape File Format.
|
||||
|
||||
The VideoScape file format is a simple format that is natively supported
|
||||
in Blender. I wrote this module because Blender's internal exporter
|
||||
doesn't export vertex colors correctly. Check the source for a *fast* algorithm for
|
||||
averaging vertex colors.
|
||||
|
||||
Usage:<br>
|
||||
Select meshes to be exported and run this script from "File->Export" menu.
|
||||
|
||||
Supported:<br>
|
||||
Exports meshes only. Hint: use ALT-C to convert non-mesh objects,
|
||||
and CTRL-ALT-A if you have "dupliverts" objects.
|
||||
|
||||
Notes:<br>
|
||||
Before exporting, the mesh must have vertex colors. Here's how to assign them:
|
||||
|
||||
1. Use radiosity!
|
||||
|
||||
2. Set up lights and materials, select a mesh, switch the drawing mode
|
||||
to "textured," press the VKEY.
|
||||
|
||||
3. Press the VKEY and paint manually.
|
||||
|
||||
4. Use a custom script to calculate and apply simple diffuse shading and
|
||||
specular highlights to the vertex colors.
|
||||
|
||||
5. The Videoscape format also allows vertex colors to be specified.
|
||||
"""
|
||||
|
||||
# $Id$
|
||||
#
|
||||
# +---------------------------------------------------------+
|
||||
# | Copyright (c) 2001 Anthony D'Agostino |
|
||||
# | http://www.redrival.com/scorpius |
|
||||
# | scorpius@netzero.com |
|
||||
# | June 5, 2001 |
|
||||
# | Write Videoscape File Format (*.obj NOT WAVEFRONT OBJ) |
|
||||
# +---------------------------------------------------------+
|
||||
|
||||
# ***** BEGIN GPL LICENSE BLOCK *****
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public License
|
||||
# as published by the Free Software Foundation; either version 2
|
||||
# of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
#
|
||||
# ***** END GPL LICENCE BLOCK *****
|
||||
|
||||
import Blender, meshtools
|
||||
#import time
|
||||
|
||||
# =====================================
|
||||
# ====== Write VideoScape Format ======
|
||||
# =====================================
|
||||
def write(filename):
|
||||
#start = time.clock()
|
||||
file = open(filename, "wb")
|
||||
|
||||
objects = Blender.Object.GetSelected()
|
||||
objname = objects[0].name
|
||||
meshname = objects[0].getData(name_only=1)
|
||||
mesh = Blender.NMesh.GetRaw(meshname)
|
||||
obj = objects[0]
|
||||
|
||||
if not meshtools.has_vertex_colors(mesh):
|
||||
message = "Please assign vertex colors before exporting.\n"
|
||||
message += objname + " object was not saved."
|
||||
meshtools.print_boxed(message)
|
||||
return
|
||||
|
||||
vcols = average_vertexcolors(mesh)
|
||||
|
||||
# === Write Videoscape Header ===
|
||||
file.write("GOUR\n")
|
||||
file.write("%d\n" % len(mesh.verts))
|
||||
|
||||
# === Write Vertex List & Vertex Colors ===
|
||||
for i in range(len(mesh.verts)):
|
||||
if not i%100 and meshtools.show_progress:
|
||||
Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Writing Verts")
|
||||
file.write("% f % f % f 0x" % tuple(mesh.verts[i].co))
|
||||
for j in range(len(vcols[i])):
|
||||
file.write("%02X" % vcols[i][j])
|
||||
file.write("\n")
|
||||
|
||||
# === Write Face List ===
|
||||
for i in range(len(mesh.faces)):
|
||||
if not i%100 and meshtools.show_progress:
|
||||
Blender.Window.DrawProgressBar(float(i)/len(mesh.faces), "Writing Faces")
|
||||
file.write("%d " % len(mesh.faces[i].v)) # numfaceverts
|
||||
for j in range(len(mesh.faces[i].v)):
|
||||
file.write("%d " % mesh.faces[i].v[j].index)
|
||||
file.write("\n")
|
||||
|
||||
Blender.Window.DrawProgressBar(1.0, '') # clear progressbar
|
||||
file.close()
|
||||
#end = time.clock()
|
||||
#seconds = " in %.2f %s" % (end-start, "seconds")
|
||||
message = "Successfully exported " + Blender.sys.basename(filename)# + seconds
|
||||
meshtools.print_boxed(message)
|
||||
|
||||
# ===========================================
|
||||
# === Vector Operations for Vertex Colors ===
|
||||
# ===========================================
|
||||
vcolor_add = lambda u, v: [u[0]+v[0], u[1]+v[1], u[2]+v[2], u[3]+v[3]]
|
||||
vcolor_div = lambda u, s: [u[0]/s, u[1]/s, u[2]/s, u[3]/s]
|
||||
|
||||
# ========================================
|
||||
# === Average All Vertex Colors (Fast) ===
|
||||
# ========================================
|
||||
def average_vertexcolors(mesh, debug=0):
|
||||
vertexcolors = {}
|
||||
for i in range(len(mesh.faces)): # get all vcolors that share this vertex
|
||||
if not i%100 and meshtools.show_progress: Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Finding Shared VColors")
|
||||
for j in range(len(mesh.faces[i].v)):
|
||||
index = mesh.faces[i].v[j].index
|
||||
color = mesh.faces[i].col[j]
|
||||
r,g,b,a = color.r, color.g, color.b, color.a
|
||||
vertexcolors.setdefault(index, []).append([r,g,b,a])
|
||||
if debug: print 'before'; vcprint(vertexcolors)
|
||||
|
||||
for i in range(len(vertexcolors)): # average them
|
||||
if not i%100 and meshtools.show_progress: Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Averaging Vertex Colors")
|
||||
vcolor = [0,0,0,0] # rgba
|
||||
for j in range(len(vertexcolors[i])):
|
||||
vcolor = vcolor_add(vcolor, vertexcolors[i][j])
|
||||
shared = len(vertexcolors[i])
|
||||
vertexcolors[i] = vcolor_div(vcolor, shared)
|
||||
if debug: print 'after'; vcprint(vertexcolors)
|
||||
return vertexcolors
|
||||
|
||||
# ========================================
|
||||
# === Average all Vertex Colors Slow 1 ===
|
||||
# ========================================
|
||||
def average_vertexcolors_slow_1(mesh, debug=0):
|
||||
vertexcolors = []
|
||||
i = 0
|
||||
for vertex in mesh.verts:
|
||||
if not i%100 and meshtools.show_progress: Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Averaging Vertex Colors")
|
||||
i += 1
|
||||
vcolor = [0,0,0,0] # rgba
|
||||
shared = 0
|
||||
for face in mesh.faces:
|
||||
if vertex in face.v:
|
||||
index = face.v.index(vertex)
|
||||
color = face.col[index]
|
||||
r,g,b,a = color.r, color.g, color.b, color.a
|
||||
vcolor = vcolor_add(vcolor, [r,g,b,a])
|
||||
shared += 1
|
||||
if not shared: print "Error, vertex %d is not shared." % i; shared += 1
|
||||
vertexcolors.append(vcolor_div(vcolor, shared))
|
||||
if debug: print 'after'; vcprint(vertexcolors)
|
||||
return vertexcolors
|
||||
|
||||
# ========================================
|
||||
# === Average all Vertex Colors Slow 2 ===
|
||||
# ========================================
|
||||
def average_vertexcolors_slow_2(mesh, debug=0):
|
||||
vertexcolors = []
|
||||
for i in range(len(mesh.verts)):
|
||||
if not i%100 and meshtools.show_progress: Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Averaging Vertex Colors")
|
||||
vcolor = [0,0,0,0] # rgba
|
||||
shared = 0
|
||||
for j in range(len(mesh.faces)):
|
||||
if mesh.verts[i] in mesh.faces[j].v:
|
||||
index = mesh.faces[j].v.index(mesh.verts[i])
|
||||
color = mesh.faces[j].col[index]
|
||||
r,g,b,a = color.r, color.g, color.b, color.a
|
||||
vcolor = vcolor_add(vcolor, [r,g,b,a])
|
||||
shared += 1
|
||||
vertexcolors.append(vcolor_div(vcolor, shared))
|
||||
if debug: print 'after'; vcprint(vertexcolors)
|
||||
return vertexcolors
|
||||
|
||||
# ========================================
|
||||
# === Average all Vertex Colors Slow 3 ===
|
||||
# ========================================
|
||||
def average_vertexcolors_slow_3(mesh, debug=0):
|
||||
vertexcolors = []
|
||||
for i in range(len(mesh.verts)):
|
||||
if not i%100 and meshtools.show_progress: Blender.Window.DrawProgressBar(float(i)/len(mesh.verts), "Averaging Vertex Colors")
|
||||
vcolor = [0,0,0,0] # rgba
|
||||
shared = 0
|
||||
for j in range(len(mesh.faces)):
|
||||
if len(mesh.faces[j].v) == 4:
|
||||
v1,v2,v3,v4 = mesh.faces[j].v
|
||||
faceverts = v1.index, v2.index, v3.index, v4.index
|
||||
else:
|
||||
v1,v2,v3 = mesh.faces[j].v
|
||||
faceverts = v1.index, v2.index, v3.index
|
||||
|
||||
if i in faceverts:
|
||||
index = mesh.faces[j].v.index(mesh.verts[i])
|
||||
color = mesh.faces[j].col[index]
|
||||
r,g,b,a = color.r, color.g, color.b, color.a
|
||||
vcolor = vcolor_add(vcolor, [r,g,b,a])
|
||||
shared += 1
|
||||
vertexcolors.append(vcolor_div(vcolor, shared))
|
||||
if debug: print 'after'; vcprint(vertexcolors)
|
||||
return vertexcolors
|
||||
|
||||
def fs_callback(filename):
|
||||
if filename.find('.obj', -4) <= 0: filename += '.VIDEOSCAPE.obj'
|
||||
write(filename)
|
||||
|
||||
Blender.Window.FileSelector(fs_callback, "Export VideoScape")
|
||||
|
||||
|
||||
# filename = "VIDEOSCAPE_" + objname + ".obj"
|
||||
# filename = 'nul'
|
||||
# file = open(filename, "wb")
|
||||
# debug = 0
|
||||
# time_functions = 1
|
||||
# time_loop = 0
|
||||
#
|
||||
# if time_functions:
|
||||
# funcs = [ average_vertexcolors,
|
||||
# average_vertexcolors_slow_1,
|
||||
# average_vertexcolors_slow_2,
|
||||
# average_vertexcolors_slow_3 ]
|
||||
#
|
||||
# print
|
||||
# for func in funcs:
|
||||
# start = time.clock()
|
||||
# vcols = func(mesh, debug)
|
||||
# end = time.clock()
|
||||
# seconds = "in %.2f %s" % (end-start, "seconds")
|
||||
# print func.__name__, "finished in", seconds
|
||||
#
|
||||
# elif time_loop:
|
||||
# total = 0
|
||||
# loops = 6
|
||||
# for i in range(loops):
|
||||
# start = time.clock()
|
||||
# vcols = average_vertexcolors(mesh, debug)
|
||||
# end = time.clock()
|
||||
# total += (end-start)
|
||||
# print "Total: %5.2f Avg: %.2f " % (total, total/loops)
|
||||
# else:
|
||||
# start = time.clock()
|
||||
# vcols = average_vertexcolors(mesh, debug)
|
||||
|
||||
# # =====================================
|
||||
# # === Print Vertex Colors for Debug ===
|
||||
# # =====================================
|
||||
# def vcprint(data):
|
||||
# print type(data)
|
||||
# for i in range(len(data)):
|
||||
# print "%2d" % i,
|
||||
# for j in range(len(data[i])):
|
||||
# try:
|
||||
# print "[%3d %3d %3d %3d]" % tuple(data[i][j]), # before
|
||||
# except:
|
||||
# print "[%3d]" % data[i][j], # after
|
||||
# print
|
||||
# print
|
||||
#
|
Loading…
Reference in New Issue
Block a user