Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/data/levels/includes/asteroidField.lua @ 9016

Last change on this file since 9016 was 9016, checked in by jo, 12 years ago

Merging presentation2011 branch to trunk. Please check for possible bugs.

File size: 2.8 KB
Line 
1--[[ fog generator
2generates fog
3        posX, posY, posZ - position in space
4        size - size of billboard
5        brightness - [0,1] fog brightness
6--]]
7function generateFog(posX, posY, posZ, size, brightness)
8                print("<Billboard ")
9                        print("position = \"") 
10                                print(posX) print(",") 
11                                print(posY) print(",") 
12                                print(posZ) print("\" ") 
13                        print("colour=\"")
14                                print(brightness) print(",") 
15                                print(brightness) print(",") 
16                                print(brightness) print("\" ") 
17                        print("material=\"Smoke/Smoke\" scale=")
18                        print(size)
19                        print(" />")
20end
21
22--[[ asteroid field generator
23generates asteroid field
24        posX, posY, posZ - position in space
25        minSize, maxSize - size boundaries of each asteroid
26        radius - size of the cube around position in space
27        count - number of asteroids
28        fog - enable fog 0/1
29--]]
30function asteroidField(posX, posY, posZ, minSize, maxSize, radius, count, fog)
31        for i = 1, count, 1
32        do
33                size = (math.random() * (maxSize - minSize)) + minSize
34                pX = (2 * math.random() * radius) - radius + posX
35                pY = (2 * math.random() * radius) - radius + posY
36                pZ = (2 * math.random() * radius) - radius + posZ
37                print("<StaticEntity ")
38               
39                print("position = \"") 
40                print(pX) print(",") 
41                print(pY) print(",") 
42                print(pZ) print("\" ")
43               
44                print("scale = \"") print(size) print("\" ")
45               
46                print("collisionType = static linearDamping = 0.8 angularDamping = 1 ") 
47                print("collisiondamage = 1000 enablecollisiondamage = true>")
48               
49                print("<attached>")
50                        print("<Model mass=\"") print(size * 10) print("\" ")
51                        print("mesh=\"ast") print(math.mod(i,6) + 1) print(".mesh\" />")
52                print("</attached>")
53               
54                print("<collisionShapes> ")
55                        print("<SphereCollisionShape radius=\"") 
56                        print(size * 2.5) print("\" />")
57                print("</collisionShapes>")
58               
59                print("</StaticEntity>")
60               
61                if fog == 1 and i % 5 == 0 then
62                        generateFog(pX, pY, pZ, radius*0.04, 0.2)
63                end
64        end
65end
66
67
68--[[ asteroid belt generator
69generates asteroid belt
70        posX, posY, posZ - position in space
71        yaw, pitch - rotation
72        minSize, maxSize - size boundaries of each asteroid
73        radius0, radius1 - inner/outer radius
74        count - number of asteroids
75        fog - enable fog 0/1
76--]]
77function asteroidBelt(centerX, centerY, centerZ, yaw, pitch, segments, minSize, maxSize, radius0, radius1, count, fog)
78        dPhi = (2 * math.pi) / segments
79        width = math.abs(radius1 - radius0)
80        radius = (radius1 + radius0) / 2
81        segmentCount = count / segments
82       
83        print("<StaticEntity collisionType=static yaw=") print(yaw) 
84        print(" pitch=") print(pitch)
85       
86        print(" position = \"") 
87                print(centerX) print(",") 
88                print(centerY) print(",") 
89                print(centerZ) print("\"") 
90        print(">")
91       
92        print("<attached>")
93       
94        for i = 0, segments - 1, 1
95        do
96                asteroidField((radius * math.cos(i * dPhi)),
97                                        (radius * math.sin(i * dPhi)),
98                                        0, minSize, maxSize, width, segmentCount, fog)
99        end
100       
101        print("</attached>")
102        print("</StaticEntity>")
103end
Note: See TracBrowser for help on using the repository browser.