/ld26

To get this branch, use:
bzr branch http://9ix.org/bzr/ld26
13 by Josh C
pull data from svg to place objects into the world
1
#!/usr/bin/python
2
3
# ./svg_levels.py >svg_levels.lua
4
5
import os, glob
6
from lxml import etree
7
from lxml.cssselect import CSSSelector
8
9
print '-- autogenerated by svg_levels.py\n\nsvg_objects = {'
10
11
ns = {'svg': 'http://www.w3.org/2000/svg',
12
      'ink': 'http://www.inkscape.org/namespaces/inkscape'}
14 by Josh C
some transitions in svg
13
38 by Josh C
gate
14
gate = ''
15
13 by Josh C
pull data from svg to place objects into the world
16
for svg in glob.glob('data/*.svg'):
17
    t = etree.parse(svg)
18
    basefile = os.path.basename(svg).split('.')[0]
19
    print '%s = {' % basefile
20
21
    sel = CSSSelector('svg|rect[ink|label="displace"]', ns)
22
    for e in sel(t):
23
        x, y = float(e.get('x')), float(e.get('y'))
24
        w, h = float(e.get('width')), float(e.get('height'))
14 by Josh C
some transitions in svg
25
13 by Josh C
pull data from svg to place objects into the world
26
        print """
27
Displacer:new{
28
  x = %f, y = %f,
29
  width = %f, height = %f
14 by Josh C
some transitions in svg
30
},
13 by Josh C
pull data from svg to place objects into the world
31
""" % (x,y,w,h)
32
14 by Josh C
some transitions in svg
33
    sel = CSSSelector('svg|rect[ink|label="transition"]', ns)
34
    for e in sel(t):
35
        x, y = float(e.get('x')), float(e.get('y'))
36
        w, h = float(e.get('width')), float(e.get('height'))
37
38
        desc = ""
39
        descSel = CSSSelector('svg|desc', ns)
40
        for d in descSel(e):
41
            desc = desc + d.text
42
43
        print """
44
Transition:new{
45
  x = %f, y = %f,
46
  width = %f, height = %f,
47
  %s
48
},
49
""" % (x,y,w,h, desc)
50
19 by Josh C
inventory (and a flower)
51
    sel = CSSSelector('svg|rect[ink|label="flower"]', ns)
52
    for e in sel(t):
53
        x, y = float(e.get('x')), float(e.get('y'))
54
55
        print """
56
Flower:new{
57
  x = %f, y = %f,
58
},
59
""" % (x,y)
60
39 by Josh C
cat
61
    sel = CSSSelector('svg|rect[ink|label="cat"]', ns)
62
    for e in sel(t):
63
        x, y = float(e.get('x')), float(e.get('y'))
64
65
        print """
66
Cat:new{
67
  x = %f, y = %f,
68
},
69
""" % (x,y)
70
34 by Josh C
GET FISH
71
    sel = CSSSelector('svg|rect[ink|label="fish"]', ns)
72
    for e in sel(t):
73
        x, y = float(e.get('x')), float(e.get('y'))
74
        w, h = float(e.get('width')), float(e.get('height'))
75
76
        print """
77
Fish:new{
78
  x = %f, y = %f,
79
  width = %f, height = %f,
80
},
81
""" % (x,y,w,h)
82
36 by Josh C
flag
83
    sel = CSSSelector('svg|rect[ink|label="flag"]', ns)
84
    for e in sel(t):
85
        x, y = float(e.get('x')), float(e.get('y'))
86
        w, h = float(e.get('width')), float(e.get('height'))
87
88
        print """
89
Flag:new{
90
  x = %f, y = %f,
91
  width = %f, height = %f,
92
},
93
""" % (x,y,w,h)
94
38 by Josh C
gate
95
    sel = CSSSelector('svg|rect[ink|label="gatetrigger"]', ns)
96
    for e in sel(t):
97
        x, y = float(e.get('x')), float(e.get('y'))
98
        w, h = float(e.get('width')), float(e.get('height'))
99
100
        print """
101
GateTrigger:new{
102
  x = %f, y = %f,
103
  width = %f, height = %f,
104
},
105
""" % (x,y,w,h)
106
35 by Josh C
troll
107
    sel = CSSSelector('svg|rect[ink|label="troll"]', ns)
108
    for e in sel(t):
109
        x, y = float(e.get('x')), float(e.get('y'))
110
        #w, h = float(e.get('width')), float(e.get('height'))
111
112
        print """
113
Troll:new{
114
  x = %f, y = %f,
115
},
116
""" % (x,y)
117
34 by Josh C
GET FISH
118
13 by Josh C
pull data from svg to place objects into the world
119
    print '},'
120
38 by Josh C
gate
121
    # gate...
122
    sel = CSSSelector('svg|rect[ink|label="gateup"]', ns)
123
    for e in sel(t):
124
        x, y = float(e.get('x')), float(e.get('y'))
125
        w, h = float(e.get('width')), float(e.get('height'))
126
127
        gate = gate + """
128
gateup = Fill:new{
129
  x = %f, y = %f,
130
  width = %f, height = %f,
131
  fill = {108,57,22,255},
132
  gateup = true
133
}
134
""" % (x,y,w,h)
135
136
    sel = CSSSelector('svg|rect[ink|label="gatedown"]', ns)
137
    for e in sel(t):
138
        x, y = float(e.get('x')), float(e.get('y'))
139
        w, h = float(e.get('width')), float(e.get('height'))
140
141
        gate = gate + """
142
gatedown = Fill:new{
143
  x = %f, y = %f,
144
  width = %f, height = %f,
145
  fill = {108,57,22,255},
146
  visible = false
147
}
148
""" % (x,y,w,h)
149
150
13 by Josh C
pull data from svg to place objects into the world
151
print '}'
38 by Josh C
gate
152
153
print gate