| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | #!BPY | 
					
						
							|  |  |  | """ 
 | 
					
						
							|  |  |  | Name: '3D Studio (.3ds)...' | 
					
						
							| 
									
										
										
										
											2007-08-01 10:19:16 +00:00
										 |  |  | Blender: 244 | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | Group: 'Import' | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | Tooltip: 'Import from 3DS file format (.3ds)' | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | __author__= ['Bob Holcomb', 'Richard L?rk?ng', 'Damien McGinnes', 'Campbell Barton', 'Mario Lapin'] | 
					
						
							| 
									
										
										
										
											2006-12-25 23:14:48 +00:00
										 |  |  | __url__ = ("blenderartists.org", "www.blender.org", "www.gametutorials.com", "lib3ds.sourceforge.net/") | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | __version__= '0.996' | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | __bpydoc__= '''\
 | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 3ds Importer | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | This script imports a 3ds file and the materials into Blender for editing. | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | Loader is based on 3ds loader from www.gametutorials.com (Thanks DigiBen). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | 0.996 by Mario Lapin (mario.lapin@gmail.com) 13/04/200 <br> | 
					
						
							|  |  |  |  - Implemented workaround to correct association between name, geometry and materials of | 
					
						
							|  |  |  |    imported meshes. | 
					
						
							|  |  |  |     | 
					
						
							|  |  |  |    Without this patch, version 0.995 of this importer would associate to each mesh object the | 
					
						
							|  |  |  |    geometry and the materials of the previously parsed mesh object. By so, the name of the | 
					
						
							|  |  |  |    first mesh object would be thrown away, and the name of the last mesh object would be | 
					
						
							|  |  |  |    automatically merged with a '.001' at the end. No object would desappear, however object's | 
					
						
							|  |  |  |    names and materials would be completely jumbled. | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 0.995 by Campbell Barton<br> | 
					
						
							|  |  |  | - workaround for buggy mesh vert delete | 
					
						
							|  |  |  | - minor tweaks | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | 0.99 by Bob Holcomb<br> | 
					
						
							|  |  |  | - added support for floating point color values that previously broke on import. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 0.98 by Campbell Barton<br> | 
					
						
							|  |  |  | - import faces and verts to lists instead of a mesh, convert to a mesh later | 
					
						
							|  |  |  | - use new index mapping feature of mesh to re-map faces that were not added. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-04 10:09:21 +00:00
										 |  |  | 0.97 by Campbell Barton<br> | 
					
						
							|  |  |  | - Strip material names of spaces | 
					
						
							|  |  |  | - Added import as instance to import the 3ds into its own | 
					
						
							|  |  |  |   scene and add a group instance to the current scene | 
					
						
							|  |  |  | - New option to scale down imported objects so they are within a limited bounding area. | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 0.96 by Campbell Barton<br> | 
					
						
							|  |  |  | - Added workaround for bug in setting UV's for Zero vert index UV faces. | 
					
						
							|  |  |  | - Removed unique name function, let blender make the names unique. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 0.95 by Campbell Barton<br> | 
					
						
							|  |  |  | - Removed workarounds for Blender 2.41 | 
					
						
							|  |  |  | - Mesh objects split by material- many 3ds objects used more then 16 per mesh. | 
					
						
							|  |  |  | - Removed a lot of unneeded variable creation. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 0.94 by Campbell Barton<br>  | 
					
						
							|  |  |  | - Face import tested to be about overall 16x speedup over 0.93. | 
					
						
							|  |  |  | - Material importing speedup. | 
					
						
							|  |  |  | - Tested with more models. | 
					
						
							|  |  |  | - Support some corrupt models. | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 0.93 by Campbell Barton<br>  | 
					
						
							|  |  |  | - Tested with 400 3ds files from turbosquid and samples. | 
					
						
							|  |  |  | - Tactfully ignore faces that used the same verts twice. | 
					
						
							|  |  |  | - Rollback to 0.83 sloppy un-reorganized code, this broke UV coord loading. | 
					
						
							|  |  |  | - Converted from NMesh to Mesh. | 
					
						
							|  |  |  | - Faster and cleaner new names. | 
					
						
							|  |  |  | - Use external comprehensive image loader. | 
					
						
							|  |  |  | - Re intergrated 0.92 and 0.9 changes | 
					
						
							|  |  |  | - Fixes for 2.41 compat. | 
					
						
							|  |  |  | - Non textured faces do not use a texture flag. | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 0.92<br> | 
					
						
							|  |  |  | - Added support for diffuse, alpha, spec, bump maps in a single material | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 0.9<br> | 
					
						
							|  |  |  | - Reorganized code into object/material block functions<br> | 
					
						
							|  |  |  | - Use of Matrix() to copy matrix data<br> | 
					
						
							|  |  |  | - added support for material transparency<br> | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 0.83 2005-08-07: Campell Barton | 
					
						
							|  |  |  | -  Aggressive image finding and case insensitivy for posisx systems. | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 0.82a 2005-07-22 | 
					
						
							|  |  |  | - image texture loading (both for face uv and renderer) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 0.82 - image texture loading (for face uv) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 0.81a (fork- not 0.9) Campbell Barton 2005-06-08 | 
					
						
							|  |  |  | - Simplified import code | 
					
						
							|  |  |  | - Never overwrite data | 
					
						
							|  |  |  | - Faster list handling | 
					
						
							|  |  |  | - Leaves import selected | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 0.81 Damien McGinnes 2005-01-09 | 
					
						
							|  |  |  | - handle missing images better | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | 0.8 Damien McGinnes 2005-01-08 | 
					
						
							|  |  |  | - copies sticky UV coords to face ones | 
					
						
							|  |  |  | - handles images better | 
					
						
							|  |  |  | - Recommend that you run 'RemoveDoubles' on each imported mesh after using this script | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | '''
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-02 19:50:30 +00:00
										 |  |  | # ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Script copyright (C) Bob Holcomb  | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # 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 ***** | 
					
						
							|  |  |  | # -------------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | # Importing modules | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import Blender | 
					
						
							| 
									
										
										
										
											2007-03-26 19:44:44 +00:00
										 |  |  | import bpy | 
					
						
							|  |  |  | from Blender import Mesh, Object, Material, Image, Texture, Lamp, Mathutils | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | from Blender.Mathutils import Vector | 
					
						
							|  |  |  | import BPyImage | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-26 04:39:46 +00:00
										 |  |  | import BPyMessages | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | import struct | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | from struct import calcsize, unpack | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | import os | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-05 19:28:21 +00:00
										 |  |  | # If python version is less than 2.4, try to get set stuff from module | 
					
						
							| 
									
										
										
										
											2006-07-03 01:52:14 +00:00
										 |  |  | try: | 
					
						
							|  |  |  | 	set | 
					
						
							|  |  |  | except: | 
					
						
							| 
									
										
										
										
											2006-04-05 19:28:21 +00:00
										 |  |  | 	from sets import Set as set | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | BOUNDS_3DS= [] | 
					
						
							| 
									
										
										
										
											2006-07-03 01:52:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | #this script imports uvcoords as sticky vertex coords | 
					
						
							|  |  |  | #this parameter enables copying these to face uv coords | 
					
						
							|  |  |  | #which shold be more useful. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def createBlenderTexture(material, name, image): | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 	texture= bpy.data.textures.new(name) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	texture.setType('Image') | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	texture.image= image | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	material.setTexture(0, texture, Texture.TexCo.UV, Texture.MapTo.COL) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | ###################################################### | 
					
						
							|  |  |  | # Data Structures | 
					
						
							|  |  |  | ###################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | #Some of the chunks that we will see | 
					
						
							|  |  |  | #----- Primary Chunk, at the beginning of each file | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | PRIMARY= long('0x4D4D',16) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | #------ Main Chunks | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | OBJECTINFO   =      long('0x3D3D',16);      #This gives the version of the mesh and is found right before the material and object information | 
					
						
							|  |  |  | VERSION      =      long('0x0002',16);      #This gives the version of the .3ds file | 
					
						
							|  |  |  | EDITKEYFRAME=      long('0xB000',16);      #This is the header for all of the key frame info | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #------ sub defines of OBJECTINFO | 
					
						
							|  |  |  | MATERIAL=45055		#0xAFFF				// This stored the texture info | 
					
						
							|  |  |  | OBJECT=16384		#0x4000				// This stores the faces, vertices, etc... | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #>------ sub defines of MATERIAL | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | #------ sub defines of MATERIAL_BLOCK | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | MAT_NAME		=	long('0xA000',16)	# This holds the material name | 
					
						
							|  |  |  | MAT_AMBIENT		=	long('0xA010',16)	# Ambient color of the object/material | 
					
						
							|  |  |  | MAT_DIFFUSE		=	long('0xA020',16)	# This holds the color of the object/material | 
					
						
							|  |  |  | MAT_SPECULAR	=	long('0xA030',16)	# SPecular color of the object/material | 
					
						
							|  |  |  | MAT_SHINESS		=	long('0xA040',16)	# ?? | 
					
						
							|  |  |  | MAT_TRANSPARENCY=	long('0xA050',16)	# Transparency value of material | 
					
						
							|  |  |  | MAT_SELF_ILLUM	=	long('0xA080',16)	# Self Illumination value of material | 
					
						
							|  |  |  | MAT_WIRE		=	long('0xA085',16)	# Only render's wireframe | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MAT_TEXTURE_MAP	=	long('0xA200',16)	# This is a header for a new texture map | 
					
						
							|  |  |  | MAT_SPECULAR_MAP=	long('0xA204',16)	# This is a header for a new specular map | 
					
						
							|  |  |  | MAT_OPACITY_MAP	=	long('0xA210',16)	# This is a header for a new opacity map | 
					
						
							|  |  |  | MAT_REFLECTION_MAP=	long('0xA220',16)	# This is a header for a new reflection map | 
					
						
							|  |  |  | MAT_BUMP_MAP	=	long('0xA230',16)	# This is a header for a new bump map | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | MAT_MAP_FILENAME =      long('0xA300',16)      # This holds the file name of the texture | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MAT_FLOAT_COLOR = long ('0x0010', 16) #color defined as 3 floats | 
					
						
							|  |  |  | MAT_24BIT_COLOR	= long ('0x0011', 16) #color defined as 3 bytes | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #>------ sub defines of OBJECT | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | OBJECT_MESH  =      long('0x4100',16);      # This lets us know that we are reading a new object | 
					
						
							|  |  |  | OBJECT_LAMP =      long('0x4600',16);      # This lets un know we are reading a light object | 
					
						
							|  |  |  | OBJECT_LAMP_SPOT = long('0x4610',16);		# The light is a spotloght. | 
					
						
							|  |  |  | OBJECT_LAMP_OFF = long('0x4620',16);		# The light off. | 
					
						
							|  |  |  | OBJECT_LAMP_ATTENUATE = long('0x4625',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_RAYSHADE = long('0x4627',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_SHADOWED = long('0x4630',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_LOCAL_SHADOW = long('0x4640',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_LOCAL_SHADOW2 = long('0x4641',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_SEE_CONE = long('0x4650',16);	 | 
					
						
							|  |  |  | OBJECT_LAMP_SPOT_RECTANGULAR= long('0x4651',16); | 
					
						
							|  |  |  | OBJECT_LAMP_SPOT_OVERSHOOT= long('0x4652',16); | 
					
						
							|  |  |  | OBJECT_LAMP_SPOT_PROJECTOR= long('0x4653',16); | 
					
						
							|  |  |  | OBJECT_LAMP_EXCLUDE= long('0x4654',16); | 
					
						
							|  |  |  | OBJECT_LAMP_RANGE= long('0x4655',16); | 
					
						
							|  |  |  | OBJECT_LAMP_ROLL= long('0x4656',16); | 
					
						
							|  |  |  | OBJECT_LAMP_SPOT_ASPECT= long('0x4657',16); | 
					
						
							|  |  |  | OBJECT_LAMP_RAY_BIAS= long('0x4658',16); | 
					
						
							|  |  |  | OBJECT_LAMP_INNER_RANGE= long('0x4659',16); | 
					
						
							|  |  |  | OBJECT_LAMP_OUTER_RANGE= long('0x465A',16); | 
					
						
							|  |  |  | OBJECT_LAMP_MULTIPLIER = long('0x465B',16); | 
					
						
							|  |  |  | OBJECT_LAMP_AMBIENT_LIGHT = long('0x4680',16); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OBJECT_CAMERA=      long('0x4700',16);      # This lets un know we are reading a camera object | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #>------ sub defines of CAMERA | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | OBJECT_CAM_RANGES=   long('0x4720',16);      # The camera range values | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #>------ sub defines of OBJECT_MESH | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | OBJECT_VERTICES =   long('0x4110',16);      # The objects vertices | 
					
						
							|  |  |  | OBJECT_FACES    =   long('0x4120',16);      # The objects faces | 
					
						
							|  |  |  | OBJECT_MATERIAL =   long('0x4130',16);      # This is found if the object has a material, either texture map or color | 
					
						
							|  |  |  | OBJECT_UV       =   long('0x4140',16);      # The UV texture coordinates | 
					
						
							|  |  |  | OBJECT_TRANS_MATRIX  =   long('0x4160',16); # The Object Matrix | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | global scn | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | scn= None | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #the chunk class | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | class chunk: | 
					
						
							|  |  |  | 	ID=0 | 
					
						
							|  |  |  | 	length=0 | 
					
						
							|  |  |  | 	bytes_read=0 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	#we don't read in the bytes_read, we compute that | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	binary_format='<HI' | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	def __init__(self): | 
					
						
							|  |  |  | 		self.ID=0 | 
					
						
							|  |  |  | 		self.length=0 | 
					
						
							|  |  |  | 		self.bytes_read=0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	def dump(self): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		print 'ID: ', self.ID | 
					
						
							|  |  |  | 		print 'ID in hex: ', hex(self.ID) | 
					
						
							|  |  |  | 		print 'length: ', self.length | 
					
						
							|  |  |  | 		print 'bytes_read: ', self.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def read_chunk(file, chunk): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	temp_data=file.read(calcsize(chunk.binary_format)) | 
					
						
							|  |  |  | 	data=unpack(chunk.binary_format, temp_data) | 
					
						
							|  |  |  | 	chunk.ID=data[0] | 
					
						
							|  |  |  | 	chunk.length=data[1] | 
					
						
							|  |  |  | 	#update the bytes read function | 
					
						
							|  |  |  | 	chunk.bytes_read=6 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	#if debugging | 
					
						
							|  |  |  | 	#chunk.dump() | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def read_string(file): | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	#read in the characters till we get a null character | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	s='' | 
					
						
							|  |  |  | 	while not s.endswith('\x00'): | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 		s+=unpack( '<c', file.read(1) )[0] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		#print 'string: ',s | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	#remove the null character from the string | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	return s[:-1] | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ###################################################### | 
					
						
							|  |  |  | # IMPORT | 
					
						
							|  |  |  | ###################################################### | 
					
						
							|  |  |  | def process_next_object_chunk(file, previous_chunk): | 
					
						
							|  |  |  | 	new_chunk=chunk() | 
					
						
							|  |  |  | 	temp_chunk=chunk() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (previous_chunk.bytes_read<previous_chunk.length): | 
					
						
							|  |  |  | 		#read the next chunk | 
					
						
							|  |  |  | 		read_chunk(file, new_chunk) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def skip_to_end(file, skip_chunk): | 
					
						
							|  |  |  | 	buffer_size=skip_chunk.length-skip_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	binary_format='%ic' % buffer_size | 
					
						
							|  |  |  | 	temp_data=file.read(calcsize(binary_format)) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	skip_chunk.bytes_read+=buffer_size | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | def add_texture_to_material(image, texture, material, mapto): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	if mapto=='DIFFUSE': | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		map=Texture.MapTo.COL | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	elif mapto=='SPECULAR': | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		map=Texture.MapTo.SPEC | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	elif mapto=='OPACITY': | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		map=Texture.MapTo.ALPHA | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	elif mapto=='BUMP': | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		map=Texture.MapTo.NOR | 
					
						
							|  |  |  | 	else: | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 		print '/tError:  Cannot map to "%s"\n\tassuming diffuse color. modify material "%s" later.' % (mapto, material.name) | 
					
						
							|  |  |  | 		map=Texture.MapTo.COL | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if image: texture.setImage(image) # double check its an image. | 
					
						
							|  |  |  | 	free_tex_slots= [i for i, tex in enumerate( material.getTextures() ) if tex==None] | 
					
						
							|  |  |  | 	if not free_tex_slots: | 
					
						
							|  |  |  | 		print '/tError: Cannot add "%s" map. 10 Texture slots alredy used.' % mapto | 
					
						
							|  |  |  | 	else: | 
					
						
							|  |  |  | 		material.setTexture(free_tex_slots[0],texture,Texture.TexCo.UV,map) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | def process_next_chunk(file, previous_chunk, importedObjects, IMAGE_SEARCH): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	#print previous_chunk.bytes_read, 'BYTES READ' | 
					
						
							|  |  |  | 	contextObName= None | 
					
						
							|  |  |  | 	contextLamp= [None, None] # object, Data | 
					
						
							|  |  |  | 	contextMaterial= None | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 	contextMatrix_rot= None # Blender.Mathutils.Matrix(); contextMatrix.identity() | 
					
						
							|  |  |  | 	#contextMatrix_tx= None # Blender.Mathutils.Matrix(); contextMatrix.identity() | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 	contextMesh_vertls= None | 
					
						
							|  |  |  | 	contextMesh_facels= None | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	contextMeshMaterials= {} # matname:[face_idxs] | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | 	contextMeshUV= None | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	TEXTURE_DICT={} | 
					
						
							|  |  |  | 	MATDICT={} | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	TEXMODE= Mesh.FaceModes['TEX'] | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	# Localspace variable names, faster. | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	STRUCT_SIZE_1CHAR= calcsize('c') | 
					
						
							|  |  |  | 	STRUCT_SIZE_2FLOAT= calcsize('2f') | 
					
						
							|  |  |  | 	STRUCT_SIZE_3FLOAT= calcsize('3f') | 
					
						
							|  |  |  | 	STRUCT_SIZE_UNSIGNED_SHORT= calcsize('H') | 
					
						
							|  |  |  | 	STRUCT_SIZE_4UNSIGNED_SHORT= calcsize('4H') | 
					
						
							|  |  |  | 	STRUCT_SIZE_4x3MAT= calcsize('ffffffffffff') | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 	_STRUCT_SIZE_4x3MAT= calcsize('fffffffffffff') | 
					
						
							|  |  |  | 	# STRUCT_SIZE_4x3MAT= calcsize('ffffffffffff') | 
					
						
							|  |  |  | 	# print STRUCT_SIZE_4x3MAT, ' STRUCT_SIZE_4x3MAT' | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 	def putContextMesh(myContextMesh_vertls, myContextMesh_facels, myContextMeshMaterials): | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 		materialFaces= set() # faces that have a material. Can optimize? | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		# Now make copies with assigned materils. | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		def makeMeshMaterialCopy(matName, faces):			 | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 			'''
 | 
					
						
							|  |  |  | 			Make a new mesh with only face the faces that use this material. | 
					
						
							|  |  |  | 			faces can be any iterable object - containing ints. | 
					
						
							|  |  |  | 			'''
 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			faceVertUsers = [False] * len(myContextMesh_vertls) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			ok=0 | 
					
						
							|  |  |  | 			for fIdx in faces: | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 				for vindex in myContextMesh_facels[fIdx]: | 
					
						
							|  |  |  | 					faceVertUsers[vindex] = True | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					if matName != None: # if matName is none then this is a set(), meaning we are using the untextured faces and do not need to store textured faces. | 
					
						
							|  |  |  | 						materialFaces.add(fIdx) | 
					
						
							|  |  |  | 					ok=1 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if not ok: | 
					
						
							|  |  |  | 				return | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 			myVertMapping = {} | 
					
						
							|  |  |  | 			vertMappingIndex = 0 | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 			vertsToUse = [i for i in xrange(len(myContextMesh_vertls)) if faceVertUsers[i]] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			myVertMapping = dict( [ (ii, i) for i, ii in enumerate(vertsToUse) ] ) | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2007-03-27 14:49:37 +00:00
										 |  |  | 			tempName= '%s_%s' % (contextObName, matName) # matName may be None. | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			bmesh = bpy.data.meshes.new(tempName) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			if matName == None: | 
					
						
							|  |  |  | 				img= None | 
					
						
							|  |  |  | 			else: | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				bmat = MATDICT[matName][1] | 
					
						
							|  |  |  | 				bmesh.materials= [bmat] | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 				try:	img= TEXTURE_DICT[bmat.name] | 
					
						
							|  |  |  | 				except:	img= None | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 			bmesh_verts = bmesh.verts | 
					
						
							|  |  |  | 			bmesh_verts.extend( [Vector()] ) | 
					
						
							|  |  |  | 			bmesh_verts.extend( [myContextMesh_vertls[i] for i in vertsToUse] ) | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 			# +1 because of DUMMYVERT | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 			face_mapping= bmesh.faces.extend( [ [ bmesh_verts[ myVertMapping[vindex]+1] for vindex in myContextMesh_facels[fIdx]] for fIdx in faces ], indexList=True ) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2007-09-19 09:15:16 +00:00
										 |  |  | 			if bmesh.faces and (contextMeshUV or img): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				bmesh.faceUV= 1 | 
					
						
							|  |  |  | 				for ii, i in enumerate(faces): | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 					 | 
					
						
							|  |  |  | 					# Mapped index- faces may have not been added- if so, then map to the correct index | 
					
						
							|  |  |  | 					# BUGGY API - face_mapping is not always the right length | 
					
						
							|  |  |  | 					map_index= face_mapping[ii] | 
					
						
							|  |  |  | 					 | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 					if map_index != None: | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 						targetFace= bmesh.faces[map_index] | 
					
						
							|  |  |  | 						if contextMeshUV: | 
					
						
							|  |  |  | 							# v.index-1 because of the DUMMYVERT | 
					
						
							|  |  |  | 							targetFace.uv= [contextMeshUV[vindex] for vindex in myContextMesh_facels[i]] | 
					
						
							|  |  |  | 						if img: | 
					
						
							|  |  |  | 							targetFace.image= img | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			# bmesh.transform(contextMatrix) | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 			ob = SCN_OBJECTS.new(bmesh, tempName) | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			'''
 | 
					
						
							|  |  |  | 			if contextMatrix_tx: | 
					
						
							|  |  |  | 				ob.setMatrix(contextMatrix_tx) | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if contextMatrix_rot: | 
					
						
							|  |  |  | 				ob.setMatrix(contextMatrix_rot) | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 			importedObjects.append(ob) | 
					
						
							| 
									
										
										
										
											2008-05-25 13:48:36 +00:00
										 |  |  | 			bmesh.calcNormals() | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		for matName, faces in myContextMeshMaterials.iteritems(): | 
					
						
							|  |  |  | 			makeMeshMaterialCopy(matName, faces) | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 		if len(materialFaces)!=len(myContextMesh_facels): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			# Invert material faces. | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			makeMeshMaterialCopy(None, set(range(len( myContextMesh_facels ))) - materialFaces) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#raise 'Some UnMaterialed faces', len(contextMesh.faces) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	#a spare chunk | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	new_chunk= chunk() | 
					
						
							|  |  |  | 	temp_chunk= chunk() | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	CreateBlenderObject = False | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	#loop through all the data for this chunk (previous chunk) and see what it is | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 	while (previous_chunk.bytes_read<previous_chunk.length): | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 		#print '\t', previous_chunk.bytes_read, 'keep going' | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		#read the next chunk | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		#print 'reading a chunk' | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		read_chunk(file, new_chunk) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		#is it a Version chunk? | 
					
						
							|  |  |  | 		if (new_chunk.ID==VERSION): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'if (new_chunk.ID==VERSION):' | 
					
						
							|  |  |  | 			#print 'found a VERSION chunk' | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			#read in the version of the file | 
					
						
							|  |  |  | 			#it's an unsigned short (H) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			temp_data= file.read(calcsize('I')) | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			version = unpack('<I', temp_data)[0] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= 4 #read the 4 bytes for the version number | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			#this loader works with version 3 and below, but may not with 4 and above | 
					
						
							|  |  |  | 			if (version>3): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				print '\tNon-Fatal Error:  Version greater than 3, may not load correctly: ', version | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		#is it an object info chunk? | 
					
						
							|  |  |  | 		elif (new_chunk.ID==OBJECTINFO): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==OBJECTINFO):' | 
					
						
							|  |  |  | 			# print 'found an OBJECTINFO chunk' | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 			process_next_chunk(file, new_chunk, importedObjects, IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			#keep track of how much we read in the main chunk | 
					
						
							|  |  |  | 			new_chunk.bytes_read+=temp_chunk.bytes_read | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		#is it an object chunk? | 
					
						
							|  |  |  | 		elif (new_chunk.ID==OBJECT): | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			if CreateBlenderObject: | 
					
						
							|  |  |  | 				putContextMesh(contextMesh_vertls, contextMesh_facels, contextMeshMaterials) | 
					
						
							|  |  |  | 				contextMesh_vertls= []; contextMesh_facels= [] | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 				## preparando para receber o proximo objeto | 
					
						
							|  |  |  | 				contextMeshMaterials= {} # matname:[face_idxs] | 
					
						
							|  |  |  | 				contextMeshUV= None | 
					
						
							|  |  |  | 				#contextMesh.vertexUV= 1 # Make sticky coords. | 
					
						
							|  |  |  | 				# Reset matrix | 
					
						
							|  |  |  | 				contextMatrix_rot= None | 
					
						
							|  |  |  | 				#contextMatrix_tx= None | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			CreateBlenderObject= True | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			tempName= read_string(file) | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 			contextObName= tempName | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read += len(tempName)+1 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		#is it a material chunk? | 
					
						
							|  |  |  | 		elif (new_chunk.ID==MATERIAL): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MATERIAL):' | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			contextMaterial= bpy.data.materials.new('Material') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_NAME): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_NAME):' | 
					
						
							|  |  |  | 			material_name= read_string(file) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			#plus one for the null character that ended the string | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= len(material_name)+1 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 			contextMaterial.name= material_name.rstrip() # remove trailing  whitespace | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			MATDICT[material_name]= (contextMaterial.name, contextMaterial) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_AMBIENT): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_AMBIENT):' | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 			read_chunk(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | 			if (temp_chunk.ID==MAT_FLOAT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3f')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+=12 | 
					
						
							|  |  |  | 				contextMaterial.mirCol=[float(col) for col in unpack('<3f', temp_data)] | 
					
						
							|  |  |  | 			elif (temp_chunk.ID==MAT_24BIT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3B')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+= 3 | 
					
						
							|  |  |  | 				contextMaterial.mirCol= [float(col)/255 for col in unpack('<3B', temp_data)] # data [0,1,2] == rgb | 
					
						
							|  |  |  | 			else: | 
					
						
							|  |  |  | 				skip_to_end(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_DIFFUSE): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_DIFFUSE):' | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 			read_chunk(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | 			if (temp_chunk.ID==MAT_FLOAT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3f')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+=12 | 
					
						
							|  |  |  | 				contextMaterial.rgbCol=[float(col) for col in unpack('<3f', temp_data)] | 
					
						
							|  |  |  | 			elif (temp_chunk.ID==MAT_24BIT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3B')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+= 3 | 
					
						
							|  |  |  | 				contextMaterial.rgbCol= [float(col)/255 for col in unpack('<3B', temp_data)] # data [0,1,2] == rgb | 
					
						
							|  |  |  | 			else: | 
					
						
							|  |  |  | 				skip_to_end(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_SPECULAR): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_SPECULAR):' | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 			read_chunk(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | 			if (temp_chunk.ID==MAT_FLOAT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3f')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+=12 | 
					
						
							|  |  |  | 				contextMaterial.mirCol=[float(col) for col in unpack('<3f', temp_data)] | 
					
						
							|  |  |  | 			elif (temp_chunk.ID==MAT_24BIT_COLOR): | 
					
						
							|  |  |  | 				temp_data=file.read(calcsize('3B')) | 
					
						
							|  |  |  | 				temp_chunk.bytes_read+= 3 | 
					
						
							|  |  |  | 				contextMaterial.mirCol= [float(col)/255 for col in unpack('<3B', temp_data)] # data [0,1,2] == rgb | 
					
						
							|  |  |  | 			else: | 
					
						
							|  |  |  | 				skip_to_end(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-10-19 21:56:11 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_TEXTURE_MAP): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_TEXTURE_MAP):' | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			new_texture= bpy.data.textures.new('Diffuse') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			new_texture.setType('Image') | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			img = None | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			while (new_chunk.bytes_read<new_chunk.length): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				#print 'MAT_TEXTURE_MAP..while', new_chunk.bytes_read, new_chunk.length | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 				read_chunk(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				if (temp_chunk.ID==MAT_MAP_FILENAME): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					texture_name=read_string(file) | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 					#img= TEXTURE_DICT[contextMaterial.name]= BPyImage.comprehensiveImageLoad(texture_name, FILENAME) | 
					
						
							|  |  |  | 					img= TEXTURE_DICT[contextMaterial.name]= BPyImage.comprehensiveImageLoad(texture_name, FILENAME, PLACE_HOLDER= False, RECURSIVE= IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 					new_chunk.bytes_read += (len(texture_name)+1) #plus one for the null character that gets removed | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 					 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 				else: | 
					
						
							|  |  |  | 					skip_to_end(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			#add the map to the material in the right channel | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			if img: | 
					
						
							|  |  |  | 				add_texture_to_material(img, new_texture, contextMaterial, 'DIFFUSE') | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_SPECULAR_MAP): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_SPECULAR_MAP):' | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			new_texture= bpy.data.textures.new('Specular') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			new_texture.setType('Image') | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			img = None | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			while (new_chunk.bytes_read<new_chunk.length): | 
					
						
							|  |  |  | 				read_chunk(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 				if (temp_chunk.ID==MAT_MAP_FILENAME): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					texture_name= read_string(file) | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 					#img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME) | 
					
						
							|  |  |  | 					img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME, PLACE_HOLDER= False, RECURSIVE= IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					new_chunk.bytes_read+= (len(texture_name)+1) #plus one for the null character that gets removed | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 				else: | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 					skip_to_end(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 			#add the map to the material in the right channel | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			if img: | 
					
						
							|  |  |  | 				add_texture_to_material(img, new_texture, contextMaterial, 'SPECULAR') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 		elif (new_chunk.ID==MAT_OPACITY_MAP): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'new_texture=Blender.Texture.New('Opacity')' | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			new_texture= bpy.data.textures.new('Opacity') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			new_texture.setType('Image') | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			img = None | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			while (new_chunk.bytes_read<new_chunk.length): | 
					
						
							|  |  |  | 				read_chunk(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				if (temp_chunk.ID==MAT_MAP_FILENAME): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					texture_name= read_string(file) | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 					#img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME) | 
					
						
							|  |  |  | 					img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME, PLACE_HOLDER= False, RECURSIVE= IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 					new_chunk.bytes_read += (len(texture_name)+1) #plus one for the null character that gets removed | 
					
						
							|  |  |  | 				else: | 
					
						
							|  |  |  | 					skip_to_end(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				new_chunk.bytes_read+= temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			#add the map to the material in the right channel | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			if img: | 
					
						
							|  |  |  | 				add_texture_to_material(img, new_texture, contextMaterial, 'OPACITY') | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_BUMP_MAP): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_BUMP_MAP):' | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			new_texture= bpy.data.textures.new('Bump') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			new_texture.setType('Image') | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			img = None | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			while (new_chunk.bytes_read<new_chunk.length): | 
					
						
							|  |  |  | 				read_chunk(file, temp_chunk) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 				if (temp_chunk.ID==MAT_MAP_FILENAME): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 					texture_name= read_string(file) | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 					#img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME) | 
					
						
							|  |  |  | 					img= BPyImage.comprehensiveImageLoad(texture_name, FILENAME, PLACE_HOLDER= False, RECURSIVE= IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 					new_chunk.bytes_read += (len(texture_name)+1) #plus one for the null character that gets removed | 
					
						
							|  |  |  | 				else: | 
					
						
							|  |  |  | 					skip_to_end(file, temp_chunk) | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				new_chunk.bytes_read+=temp_chunk.bytes_read | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			#add the map to the material in the right channel | 
					
						
							| 
									
										
										
										
											2007-01-04 15:20:28 +00:00
										 |  |  | 			if img: | 
					
						
							|  |  |  | 				add_texture_to_material(img, new_texture, contextMaterial, 'BUMP') | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 		elif (new_chunk.ID==MAT_TRANSPARENCY): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'elif (new_chunk.ID==MAT_TRANSPARENCY):' | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			read_chunk(file, temp_chunk) | 
					
						
							|  |  |  | 			temp_data=file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			temp_chunk.bytes_read+=2 | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 			contextMaterial.alpha= 1-(float(unpack('<H', temp_data)[0])/100) | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 			new_chunk.bytes_read+=temp_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		elif (new_chunk.ID==OBJECT_LAMP): # Basic lamp support. | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			temp_data=file.read(STRUCT_SIZE_3FLOAT) | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 			x,y,z=unpack('<3f', temp_data) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			new_chunk.bytes_read+=STRUCT_SIZE_3FLOAT | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 			contextLamp[1]= bpy.data.lamps.new() | 
					
						
							| 
									
										
										
										
											2007-05-28 17:52:53 +00:00
										 |  |  | 			contextLamp[0]= SCN_OBJECTS.new(contextLamp[1]) | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 			importedObjects.append(contextLamp[0]) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'number of faces: ', num_faces | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			#print x,y,z | 
					
						
							|  |  |  | 			contextLamp[0].setLocation(x,y,z) | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			# Reset matrix | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			contextMatrix_rot= None | 
					
						
							|  |  |  | 			#contextMatrix_tx= None | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print contextLamp.name,  | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 		elif (new_chunk.ID==OBJECT_MESH): | 
					
						
							| 
									
										
										
										
											2008-05-25 13:48:36 +00:00
										 |  |  | 			# print 'Found an OBJECT_MESH chunk' | 
					
						
							|  |  |  | 			pass | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		elif (new_chunk.ID==OBJECT_VERTICES): | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 			'''
 | 
					
						
							|  |  |  | 			Worldspace vertex locations | 
					
						
							|  |  |  | 			'''
 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			# print 'elif (new_chunk.ID==OBJECT_VERTICES):' | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			temp_data=file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			num_verts=unpack('<H', temp_data)[0] | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			new_chunk.bytes_read+=2 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			# print 'number of verts: ', num_verts | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			def getvert(): | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 				temp_data= unpack('<3f', file.read(STRUCT_SIZE_3FLOAT)) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 				new_chunk.bytes_read += STRUCT_SIZE_3FLOAT #12: 3 floats x 4 bytes each | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 				return temp_data | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			#contextMesh.verts.extend( [Vector(),] ) # DUMMYVERT! - remove when blenders internals are fixed. | 
					
						
							|  |  |  | 			contextMesh_vertls= [getvert() for i in xrange(num_verts)] | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#print 'object verts: bytes read: ', new_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		elif (new_chunk.ID==OBJECT_FACES): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			# print 'elif (new_chunk.ID==OBJECT_FACES):' | 
					
						
							|  |  |  | 			temp_data= file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			num_faces= unpack('<H', temp_data)[0] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= 2 | 
					
						
							|  |  |  | 			#print 'number of faces: ', num_faces | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			def getface(): | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 				# print '\ngetting a face' | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				temp_data= file.read(STRUCT_SIZE_4UNSIGNED_SHORT) | 
					
						
							|  |  |  | 				new_chunk.bytes_read+= STRUCT_SIZE_4UNSIGNED_SHORT #4 short ints x 2 bytes each | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 				v1,v2,v3,dummy= unpack('<4H', temp_data) | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 				return v1, v2, v3 | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 			contextMesh_facels= [ getface() for i in xrange(num_faces) ] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		elif (new_chunk.ID==OBJECT_MATERIAL): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			# print 'elif (new_chunk.ID==OBJECT_MATERIAL):' | 
					
						
							|  |  |  | 			material_name= read_string(file) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			new_chunk.bytes_read += len(material_name)+1 # remove 1 null character. | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			temp_data=file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			num_faces_using_mat = unpack('<H', temp_data)[0] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read += STRUCT_SIZE_UNSIGNED_SHORT | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			def getmat(): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 				temp_data= file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							|  |  |  | 				new_chunk.bytes_read+= STRUCT_SIZE_UNSIGNED_SHORT | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 				return unpack('<H', temp_data)[0] | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			contextMeshMaterials[material_name]= [ getmat() for i in xrange(num_faces_using_mat) ] | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			#look up the material in all the materials | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		elif (new_chunk.ID==OBJECT_UV): | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			temp_data=file.read(STRUCT_SIZE_UNSIGNED_SHORT) | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 			num_uv=unpack('<H', temp_data)[0] | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			new_chunk.bytes_read+= 2 | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			def getuv(): | 
					
						
							|  |  |  | 				temp_data=file.read(STRUCT_SIZE_2FLOAT) | 
					
						
							|  |  |  | 				new_chunk.bytes_read += STRUCT_SIZE_2FLOAT #2 float x 4 bytes each | 
					
						
							| 
									
										
										
										
											2006-07-11 13:30:57 +00:00
										 |  |  | 				return Vector( unpack('<2f', temp_data) ) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			contextMeshUV= [ getuv() for i in xrange(num_uv) ] | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		elif (new_chunk.ID== OBJECT_TRANS_MATRIX): | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			# How do we know the matrix size? 54 == 4x4 48 == 4x3 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			temp_data=file.read(STRUCT_SIZE_4x3MAT) | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			data= list( unpack('<ffffffffffff', temp_data)  ) | 
					
						
							|  |  |  | 			new_chunk.bytes_read += STRUCT_SIZE_4x3MAT | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			contextMatrix_rot= Blender.Mathutils.Matrix(\ | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			 data[:3] + [0],\ | 
					
						
							|  |  |  | 			 data[3:6] + [0],\ | 
					
						
							|  |  |  | 			 data[6:9] + [0],\ | 
					
						
							|  |  |  | 			 data[9:] + [1]) | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			contextMatrix_rot= Blender.Mathutils.Matrix(\ | 
					
						
							|  |  |  | 			 data[:3] + [0],\ | 
					
						
							|  |  |  | 			 data[3:6] + [0],\ | 
					
						
							|  |  |  | 			 data[6:9] + [0],\ | 
					
						
							|  |  |  | 			 [0,0,0,1]) | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			contextMatrix_rot= Blender.Mathutils.Matrix(\ | 
					
						
							|  |  |  | 			 data[:3] ,\ | 
					
						
							|  |  |  | 			 data[3:6],\ | 
					
						
							|  |  |  | 			 data[6:9]) | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			contextMatrix_rot = Blender.Mathutils.Matrix() | 
					
						
							|  |  |  | 			m = 0 | 
					
						
							|  |  |  | 			for j in xrange(4): | 
					
						
							|  |  |  | 				for i in xrange(3): | 
					
						
							|  |  |  | 					contextMatrix_rot[j][i] = data[m] | 
					
						
							|  |  |  | 					m+=1 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			contextMatrix_rot[0][3]=0; | 
					
						
							|  |  |  | 			contextMatrix_rot[1][3]=0; | 
					
						
							|  |  |  | 			contextMatrix_rot[2][3]=0; | 
					
						
							|  |  |  | 			contextMatrix_rot[3][3]=1; | 
					
						
							|  |  |  | 			'''
 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			#contextMatrix_rot.resize4x4() | 
					
						
							|  |  |  | 			#print "MTX" | 
					
						
							|  |  |  | 			#print contextMatrix_rot | 
					
						
							|  |  |  | 			contextMatrix_rot.invert() | 
					
						
							|  |  |  | 			#print contextMatrix_rot | 
					
						
							|  |  |  | 			#contextMatrix_tx = Blender.Mathutils.TranslationMatrix(0.5 * Blender.Mathutils.Vector(data[9:])) | 
					
						
							|  |  |  | 			#contextMatrix_tx.invert() | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			#tx.invert() | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			#contextMatrix = contextMatrix * tx | 
					
						
							|  |  |  | 			#contextMatrix = contextMatrix  *tx | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		elif  (new_chunk.ID==MAT_MAP_FILENAME): | 
					
						
							|  |  |  | 			texture_name=read_string(file) | 
					
						
							|  |  |  | 			try: | 
					
						
							|  |  |  | 				TEXTURE_DICT[contextMaterial.name] | 
					
						
							|  |  |  | 			except: | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 				#img= TEXTURE_DICT[contextMaterial.name]= BPyImage.comprehensiveImageLoad(texture_name, FILENAME) | 
					
						
							|  |  |  | 				img= TEXTURE_DICT[contextMaterial.name]= BPyImage.comprehensiveImageLoad(texture_name, FILENAME, PLACE_HOLDER= False, RECURSIVE= IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			new_chunk.bytes_read+= len(texture_name)+1 #plus one for the null character that gets removed | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		else: #(new_chunk.ID!=VERSION or new_chunk.ID!=OBJECTINFO or new_chunk.ID!=OBJECT or new_chunk.ID!=MATERIAL): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			# print 'skipping to end of this chunk' | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			buffer_size=new_chunk.length-new_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 			binary_format='%ic' % buffer_size | 
					
						
							|  |  |  | 			temp_data=file.read(calcsize(binary_format)) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 			new_chunk.bytes_read+=buffer_size | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		#update the previous chunk bytes read | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		# print 'previous_chunk.bytes_read += new_chunk.bytes_read' | 
					
						
							| 
									
										
										
										
											2006-02-03 06:42:07 +00:00
										 |  |  | 		# print previous_chunk.bytes_read, new_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 		previous_chunk.bytes_read += new_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		## print 'Bytes left in this chunk: ', previous_chunk.length-previous_chunk.bytes_read | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	# FINISHED LOOP | 
					
						
							|  |  |  | 	# There will be a number of objects still not added | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 	if contextMesh_facels != None: | 
					
						
							|  |  |  | 		putContextMesh(contextMesh_vertls, contextMesh_facels, contextMeshMaterials) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | def load_3ds(filename, PREF_UI= True): | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	global FILENAME, SCN_OBJECTS | 
					
						
							| 
									
										
										
										
											2006-09-26 04:39:46 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if BPyMessages.Error_NoFile(filename): | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	print '\n\nImporting 3DS: "%s"' % (Blender.sys.expandpath(filename)) | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	time1= Blender.sys.time() | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	FILENAME=filename | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	current_chunk=chunk() | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	file=open(filename,'rb') | 
					
						
							| 
									
										
										
										
											2005-12-19 17:21:55 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	#here we go! | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	# print 'reading the first chunk' | 
					
						
							| 
									
										
										
										
											2006-02-01 10:52:54 +00:00
										 |  |  | 	read_chunk(file, current_chunk) | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 	if (current_chunk.ID!=PRIMARY): | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 		print '\tFatal Error:  Not a valid 3ds file: ', filename | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 		file.close() | 
					
						
							|  |  |  | 		return | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	# IMPORT_AS_INSTANCE= Blender.Draw.Create(0) | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	IMPORT_CONSTRAIN_BOUNDS= Blender.Draw.Create(10.0) | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	IMAGE_SEARCH= Blender.Draw.Create(1) | 
					
						
							| 
									
										
										
										
											2009-04-15 07:00:11 +00:00
										 |  |  | 	APPLY_MATRIX= Blender.Draw.Create(0) | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	# Get USER Options | 
					
						
							|  |  |  | 	pup_block= [\ | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	('Size Constraint:', IMPORT_CONSTRAIN_BOUNDS, 0.0, 1000.0, 'Scale the model by 10 until it reacehs the size constraint. Zero Disables.'),\ | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	('Image Search', IMAGE_SEARCH, 'Search subdirs for any assosiated images (Warning, may be slow)'),\ | 
					
						
							| 
									
										
										
										
											2009-04-15 07:00:11 +00:00
										 |  |  | 	('Transform Fix', APPLY_MATRIX, 'Workaround for object transformations importing incorrectly'),\ | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	#('Group Instance', IMPORT_AS_INSTANCE, 'Import objects into a new scene and group, creating an instance in the current scene.'),\ | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	] | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 	if PREF_UI: | 
					
						
							|  |  |  | 		if not Blender.Draw.PupBlock('Import 3DS...', pup_block): | 
					
						
							|  |  |  | 			return | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 	Blender.Window.WaitCursor(1) | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	IMPORT_CONSTRAIN_BOUNDS= IMPORT_CONSTRAIN_BOUNDS.val | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	# IMPORT_AS_INSTANCE= IMPORT_AS_INSTANCE.val | 
					
						
							|  |  |  | 	IMAGE_SEARCH = IMAGE_SEARCH.val | 
					
						
							| 
									
										
										
										
											2009-04-15 07:00:11 +00:00
										 |  |  | 	APPLY_MATRIX = APPLY_MATRIX.val | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	if IMPORT_CONSTRAIN_BOUNDS: | 
					
						
							|  |  |  | 		BOUNDS_3DS[:]= [1<<30, 1<<30, 1<<30, -1<<30, -1<<30, -1<<30] | 
					
						
							|  |  |  | 	else: | 
					
						
							|  |  |  | 		BOUNDS_3DS[:]= [] | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	##IMAGE_SEARCH | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 	scn= bpy.data.scenes.active | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	SCN_OBJECTS = scn.objects | 
					
						
							| 
									
										
										
										
											2006-12-28 11:09:36 +00:00
										 |  |  | 	SCN_OBJECTS.selected = [] # de select all | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	importedObjects= [] # Fill this list with objects | 
					
						
							| 
									
										
										
										
											2007-01-31 01:18:51 +00:00
										 |  |  | 	process_next_chunk(file, current_chunk, importedObjects, IMAGE_SEARCH) | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	# Link the objects into this scene. | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	# Layers= scn.Layers | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	# REMOVE DUMMYVERT, - remove this in the next release when blenders internal are fixed. | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-05-01 00:30:48 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 	for ob in importedObjects: | 
					
						
							| 
									
										
										
										
											2006-12-28 05:00:35 +00:00
										 |  |  | 		if ob.type=='Mesh': | 
					
						
							| 
									
										
										
										
											2006-06-16 10:41:21 +00:00
										 |  |  | 			me= ob.getData(mesh=1) | 
					
						
							|  |  |  | 			me.verts.delete([me.verts[0],]) | 
					
						
							| 
									
										
										
										
											2009-04-15 07:00:11 +00:00
										 |  |  | 			if not APPLY_MATRIX: | 
					
						
							|  |  |  | 				me.transform(ob.matrixWorld.copy().invert()) | 
					
						
							| 
									
										
										
										
											2007-05-01 00:30:48 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-06-19 01:27:41 +00:00
										 |  |  | 	# Done DUMMYVERT | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	"""
 | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	if IMPORT_AS_INSTANCE: | 
					
						
							|  |  |  | 		name= filename.split('\\')[-1].split('/')[-1] | 
					
						
							|  |  |  | 		# Create a group for this import. | 
					
						
							|  |  |  | 		group_scn= Scene.New(name) | 
					
						
							|  |  |  | 		for ob in importedObjects: | 
					
						
							|  |  |  | 			group_scn.link(ob) # dont worry about the layers | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		grp= Blender.Group.New(name) | 
					
						
							|  |  |  | 		grp.objects= importedObjects | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		grp_ob= Object.New('Empty', name) | 
					
						
							|  |  |  | 		grp_ob.enableDupGroup= True | 
					
						
							|  |  |  | 		grp_ob.DupGroup= grp | 
					
						
							|  |  |  | 		scn.link(grp_ob) | 
					
						
							|  |  |  | 		grp_ob.Layers= Layers | 
					
						
							|  |  |  | 		grp_ob.sel= 1 | 
					
						
							|  |  |  | 	else: | 
					
						
							|  |  |  | 		# Select all imported objects. | 
					
						
							|  |  |  | 		for ob in importedObjects: | 
					
						
							|  |  |  | 			scn.link(ob) | 
					
						
							|  |  |  | 			ob.Layers= Layers | 
					
						
							|  |  |  | 			ob.sel= 1 | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 	"""
 | 
					
						
							| 
									
										
										
										
											2006-06-06 09:59:36 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 	if IMPORT_CONSTRAIN_BOUNDS!=0.0: | 
					
						
							| 
									
										
										
										
											2006-08-25 18:05:05 +00:00
										 |  |  | 		# Set bounds from objecyt bounding box | 
					
						
							|  |  |  | 		for ob in importedObjects: | 
					
						
							|  |  |  | 			if ob.type=='Mesh': | 
					
						
							|  |  |  | 				ob.makeDisplayList() # Why dosnt this update the bounds? | 
					
						
							|  |  |  | 				for v in ob.getBoundBox(): | 
					
						
							|  |  |  | 					for i in (0,1,2): | 
					
						
							|  |  |  | 						if v[i] < BOUNDS_3DS[i]: | 
					
						
							|  |  |  | 							BOUNDS_3DS[i]= v[i] # min | 
					
						
							|  |  |  | 						 | 
					
						
							|  |  |  | 						if v[i] > BOUNDS_3DS[i+3]: | 
					
						
							|  |  |  | 							BOUNDS_3DS[i+3]= v[i] # min | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 		# Get the max axis x/y/z | 
					
						
							|  |  |  | 		max_axis= max(BOUNDS_3DS[3]-BOUNDS_3DS[0], BOUNDS_3DS[4]-BOUNDS_3DS[1], BOUNDS_3DS[5]-BOUNDS_3DS[2]) | 
					
						
							| 
									
										
										
										
											2006-12-11 08:57:39 +00:00
										 |  |  | 		# print max_axis | 
					
						
							| 
									
										
										
										
											2006-07-04 01:56:49 +00:00
										 |  |  | 		if max_axis < 1<<30: # Should never be false but just make sure. | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			# Get a new scale factor if set as an option | 
					
						
							|  |  |  | 			SCALE=1.0 | 
					
						
							|  |  |  | 			while (max_axis*SCALE) > IMPORT_CONSTRAIN_BOUNDS: | 
					
						
							|  |  |  | 				SCALE/=10 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			# SCALE Matrix | 
					
						
							|  |  |  | 			SCALE_MAT= Blender.Mathutils.Matrix([SCALE,0,0,0],[0,SCALE,0,0],[0,0,SCALE,0],[0,0,0,1]) | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for ob in importedObjects: | 
					
						
							|  |  |  | 				ob.setMatrix(ob.matrixWorld*SCALE_MAT) | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 		# Done constraining to bounds. | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	# Select all new objects. | 
					
						
							|  |  |  | 	print 'finished importing: "%s" in %.4f sec.' % (filename, (Blender.sys.time()-time1)) | 
					
						
							|  |  |  | 	file.close() | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | 	Blender.Window.WaitCursor(0) | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | DEBUG= False | 
					
						
							|  |  |  | if __name__=='__main__' and not DEBUG: | 
					
						
							| 
									
										
										
										
											2006-02-06 14:23:55 +00:00
										 |  |  | 	Blender.Window.FileSelector(load_3ds, 'Import 3DS', '*.3ds') | 
					
						
							| 
									
										
										
										
											2005-12-15 01:42:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # For testing compatibility | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | #load_3ds('/metavr/convert/vehicle/truck_002/TruckTanker1.3DS', False) | 
					
						
							|  |  |  | #load_3ds('/metavr/archive/convert/old/arranged_3ds_to_hpx-2/only-need-engine-trains/Engine2.3DS', False) | 
					
						
							| 
									
										
										
										
											2006-12-11 23:03:14 +00:00
										 |  |  | '''
 | 
					
						
							| 
									
										
										
										
											2007-08-01 10:19:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | else: | 
					
						
							|  |  |  | 	# DEBUG ONLY | 
					
						
							|  |  |  | 	TIME= Blender.sys.time() | 
					
						
							|  |  |  | 	import os | 
					
						
							|  |  |  | 	print 'Searching for files' | 
					
						
							|  |  |  | 	os.system('find /metavr/ -iname "*.3ds" > /tmp/temp3ds_list') | 
					
						
							|  |  |  | 	# os.system('find /storage/ -iname "*.3ds" > /tmp/temp3ds_list') | 
					
						
							|  |  |  | 	print '...Done' | 
					
						
							|  |  |  | 	file= open('/tmp/temp3ds_list', 'r') | 
					
						
							|  |  |  | 	lines= file.readlines() | 
					
						
							|  |  |  | 	file.close() | 
					
						
							| 
									
										
										
										
											2007-08-01 10:19:16 +00:00
										 |  |  | 	# sort by filesize for faster testing | 
					
						
							|  |  |  | 	lines_size = [(os.path.getsize(f[:-1]), f[:-1]) for f in lines] | 
					
						
							|  |  |  | 	lines_size.sort() | 
					
						
							|  |  |  | 	lines = [f[1] for f in lines_size] | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	def between(v,a,b): | 
					
						
							|  |  |  | 		if v <= max(a,b) and v >= min(a,b): | 
					
						
							|  |  |  | 			return True		 | 
					
						
							|  |  |  | 		return False | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	for i, _3ds in enumerate(lines): | 
					
						
							| 
									
										
										
										
											2007-08-01 10:19:16 +00:00
										 |  |  | 		if between(i, 650,800): | 
					
						
							|  |  |  | 			#_3ds= _3ds[:-1] | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 			print 'Importing', _3ds, '\nNUMBER', i, 'of', len(lines) | 
					
						
							|  |  |  | 			_3ds_file= _3ds.split('/')[-1].split('\\')[-1] | 
					
						
							| 
									
										
										
										
											2007-03-14 06:01:59 +00:00
										 |  |  | 			newScn= Blender.Scene.New(_3ds_file) | 
					
						
							| 
									
										
										
										
											2006-08-25 09:10:06 +00:00
										 |  |  | 			newScn.makeCurrent() | 
					
						
							|  |  |  | 			load_3ds(_3ds, False) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	print 'TOTAL TIME: %.6f' % (Blender.sys.time() - TIME) | 
					
						
							| 
									
										
										
										
											2007-08-01 10:19:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-20 19:27:48 +00:00
										 |  |  | '''
 |