diff options
author | Campbell Barton <ideasman42@gmail.com> | 2009-01-06 11:58:45 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2009-01-06 11:58:45 +0300 |
commit | 823aa30cba2d9e6d209ee9f5f5dbdbf2fd70264e (patch) | |
tree | 10a90bee19a815ac5725c189d47b23bb2e9e19cd /release | |
parent | 49b5edddd4521d3bb5e6fe0e98cde026d69e27e4 (diff) |
string extraction wasnt working + minor changes
Diffstat (limited to 'release')
-rwxr-xr-x | release/scripts/import_web3d.py | 49 |
1 files changed, 26 insertions, 23 deletions
diff --git a/release/scripts/import_web3d.py b/release/scripts/import_web3d.py index 6974edf8e07..d73f05483bb 100755 --- a/release/scripts/import_web3d.py +++ b/release/scripts/import_web3d.py @@ -52,11 +52,11 @@ def dirName(path): def imageConvertCompat(path): - try: import os - except: - return path + try: import os + except: return path + if os.sep=='\\': return path # assime win32 has quicktime, dont convert - if path.endswith('.gif'): + if path.lower().endswith('.gif'): path_to = path[:-3] + 'png' ''' @@ -147,13 +147,12 @@ def vrmlFormat(data): data = data[:start] + data[end:] ok = True # keep looking - last_i = end - len(item) + 1 + last_i = (end - len(item)) + 1 # print last_i, item, '|' + data[last_i] + '|' # done with messy extracting strings part - # Bad, dont take strings into account ''' data = data.replace('#', '\n#') @@ -175,13 +174,14 @@ def vrmlFormat(data): while ok: ok = False i = data.find(search + '"', last_i) - + # print i if i != -1: start = i + len(search) # first char after end of search item = string_ls.pop(0) + # print item data = data[:start] + item + data[start:] - last_i = start + len(item) + last_i = start + len(item) + 1 ok = True @@ -918,7 +918,7 @@ class vrmlNode(object): lines.insert(0, 'root_node____') lines.append('}') ''' - ff = open('/tmp/test.txt', 'w') + ff = open('/root/test.txt', 'w') ff.writelines([l+'\n' for l in lines]) ''' @@ -1167,11 +1167,11 @@ def vrml_parse(path): lines.append('}') # Use for testing our parsed output, so we can check on line numbers. - """ + ff = open('/tmp/test.txt', 'w') ff.writelines([l+'\n' for l in lines]) ff.close() - """ + # Now evaluate it node_type, new_i = is_nodeline(0, []) @@ -1908,7 +1908,7 @@ def importShape(node, ancestry): ima_url = ima.getFieldAsString('url', None, ancestry) if ima_url==None: - try: ima_url = ima.getFieldAsStringArray('url', None, ancestry)[0] # in some cases we get a list of images. + try: ima_url = ima.getFieldAsStringArray('url', ancestry)[0] # in some cases we get a list of images. except: ima_url = None if ima_url==None: @@ -2137,6 +2137,10 @@ def importTransform(node, ancestry): bpyob = node.blendObject = bpy.data.scenes.active.objects.new('Empty', name) # , name) bpyob.setMatrix( getFinalMatrix(node, None, ancestry) ) + # so they are not too annoying + bpyob.emptyShape= Blender.Object.EmptyShapes.AXES + bpyob.drawSize= 0.2 + #def importTimeSensor(node): @@ -2332,8 +2336,12 @@ def load_web3d(path, PREF_FLAT=False, PREF_CIRCLE_DIV=16, HELPER_FUNC = None): prefix = node.getPrefix() if prefix=='PROTO': pass - el + else ''' + if HELPER_FUNC and HELPER_FUNC(node, ancestry): + # Note, include this function so the VRML/X3D importer can be extended + # by an external script. - gets first pick + pass if spec=='Shape': importShape(node, ancestry) elif spec in ('PointLight', 'DirectionalLight', 'SpotLight'): @@ -2350,15 +2358,9 @@ def load_web3d(path, PREF_FLAT=False, PREF_CIRCLE_DIV=16, HELPER_FUNC = None): ipo = bpy.data.ipos.new('web3d_ipo', 'Object') translatePositionInterpolator(node, ipo) ''' - - else: - # Note, include this function so the VRML/X3D importer can be extended - # by an external script. - if HELPER_FUNC: - HELPER_FUNC(node, ancestry) - - - + + + # After we import all nodes, route events - anim paths for node, ancestry in all_nodes: importRoute(node, ancestry) @@ -2503,4 +2505,5 @@ def test(): bpy.data.scenes.active = sce # Window. load_web3d(f, PREF_FLAT=True) -
\ No newline at end of file + + |