d650d11a23ce48c54a330f43b98cbc24d1010724
[blender.git] / release / scripts / raw_import.py
1 #!BPY
2
3 """
4 Name: 'Raw Triangle (.raw)...'
5 Blender: 232
6 Group: 'Import'
7 Tooltip: 'Import Raw Triangle File Format (.raw)'
8 """
9
10 __author__ = "Anthony D'Agostino (Scorpius)"
11 __url__ = ("blender", "elysiun",
12 "Author's homepage, http://www.redrival.com/scorpius")
13 __version__ = "Part of IOSuite 0.5"
14
15 __bpydoc__ = """\
16 This script imports Raw Triangle File format files to Blender.
17
18 Usage:
19
20 Execute this script from the "File->Import" menu and choose a Raw file to
21 open.
22 """
23
24
25 # $Id$
26 #
27 # +---------------------------------------------------------+
28 # | Copyright (c) 2002 Anthony D'Agostino                   |
29 # | http://www.redrival.com/scorpius                        |
30 # | scorpius@netzero.com                                    |
31 # | April 28, 2002                                          |
32 # | Released under the Blender Artistic Licence (BAL)       |
33 # | Import Export Suite v0.5                                |
34 # +---------------------------------------------------------+
35 # | Read and write RAW Triangle File Format (*.raw)         |
36 # +---------------------------------------------------------+
37
38 import Blender, mod_meshtools
39 #import time
40
41 # ================================
42 # === Read RAW Triangle Format ===
43 # ================================
44 def read(filename):
45         #start = time.clock()
46         file = open(filename, "rb")
47
48         # Collect data from RAW format
49         faces = []
50         for line in file.readlines():
51                 try:
52                         f1, f2, f3, f4, f5, f6, f7, f8, f9 = map(float, line.split())
53                         faces.append([(f1, f2, f3), (f4, f5, f6), (f7, f8, f9)])
54                 except: # Quad
55                         f1, f2, f3, f4, f5, f6, f7, f8, f9, A, B, C = map(float, line.split())
56                         faces.append([(f1, f2, f3), (f4, f5, f6), (f7, f8, f9), (A, B, C)])
57
58         # Generate verts and faces lists, without duplicates
59         verts = []
60         coords = {}
61         index = 0
62         for i in range(len(faces)):
63                 for j in range(len(faces[i])):
64                         vertex = faces[i][j]
65                         if not coords.has_key(vertex):
66                                 coords[vertex] = index
67                                 index += 1
68                                 verts.append(vertex)
69                         faces[i][j] = coords[vertex]
70
71         objname = Blender.sys.splitext(Blender.sys.basename(filename))[0]
72
73         mod_meshtools.create_mesh(verts, faces, objname)
74         Blender.Window.DrawProgressBar(1.0, '')  # clear progressbar
75         file.close()
76         #end = time.clock()
77         #seconds = " in %.2f %s" % (end-start, "seconds")
78         message = "Successfully imported " + Blender.sys.basename(filename)# + seconds
79         mod_meshtools.print_boxed(message)
80
81 def fs_callback(filename):
82         read(filename)
83
84 Blender.Window.FileSelector(fs_callback, "Import Raw")