shattered_view 0.3.1 → 0.3.2
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/base.rb +1 -2
- data/lib/extensions.rb +2 -2
- data/lib/mesh/mesh.rb +9 -6
- data/lib/node.rb +1 -1
- data/lib/runner.rb +1 -1
- data/lib/shattered_view.rb +2 -13
- metadata +2 -3
- data/lib/game.rb +0 -42
data/lib/base.rb
CHANGED
@@ -6,7 +6,7 @@ require 'mesh/mesh'
|
|
6
6
|
|
7
7
|
include ShatteredSupport
|
8
8
|
|
9
|
-
module ShatteredView
|
9
|
+
module ShatteredView #:nodoc:
|
10
10
|
|
11
11
|
class Error < StandardError; end
|
12
12
|
|
@@ -82,7 +82,6 @@ module ShatteredView
|
|
82
82
|
class Base < ShatteredSupport::Base
|
83
83
|
attr_reader :meshes
|
84
84
|
attr_accessor :model
|
85
|
-
|
86
85
|
|
87
86
|
def new_material=(name)
|
88
87
|
@materials ||= {}
|
data/lib/extensions.rb
CHANGED
data/lib/mesh/mesh.rb
CHANGED
@@ -61,10 +61,6 @@ module ShatteredView
|
|
61
61
|
|
62
62
|
module InstanceMethods
|
63
63
|
|
64
|
-
def unload!
|
65
|
-
meshes.each { |mesh| mesh.remove_from_scene }
|
66
|
-
end
|
67
|
-
|
68
64
|
#Note that this method is very similiar to ShatteredController::Actor.
|
69
65
|
#And that a common function can be refactored from both.
|
70
66
|
def method_missing(method, *args)
|
@@ -83,6 +79,10 @@ module ShatteredView
|
|
83
79
|
end
|
84
80
|
|
85
81
|
private
|
82
|
+
|
83
|
+
def unload!
|
84
|
+
meshes.each { |mesh| mesh.remove_from_scene }
|
85
|
+
end
|
86
86
|
|
87
87
|
def mesh(file, options={})
|
88
88
|
mesh = Mesh.new(file)
|
@@ -107,7 +107,7 @@ module ShatteredView
|
|
107
107
|
animation(:#{name})
|
108
108
|
end
|
109
109
|
end
|
110
|
-
EOF
|
110
|
+
EOF
|
111
111
|
call_object_function_for_each_key(:"#{mesh.name}.#{name}", options)
|
112
112
|
end
|
113
113
|
end
|
@@ -156,7 +156,10 @@ module ShatteredView
|
|
156
156
|
return @animations[animation]
|
157
157
|
end
|
158
158
|
|
159
|
-
|
159
|
+
# Remove the Ogre Mesh from the scene
|
160
|
+
def remove_from_scene
|
161
|
+
@scene_object.removeFromScene
|
162
|
+
end
|
160
163
|
private
|
161
164
|
|
162
165
|
# populate_animations queries ShatteredOgre and adds the found animations to the mesh.
|
data/lib/node.rb
CHANGED
data/lib/runner.rb
CHANGED
data/lib/shattered_view.rb
CHANGED
@@ -1,16 +1,5 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
require dependency
|
4
|
-
rescue LoadError => e
|
5
|
-
require 'rubygems'
|
6
|
-
require dependency
|
7
|
-
end
|
8
|
-
end
|
9
|
-
|
10
|
-
raise( ShatteredSupport::Error, "Could not find ShatteredOgre (a ShatteredView dependency)" ) if not defined? ShatteredOgre
|
11
|
-
|
12
|
-
require 'rubygems'
|
13
|
-
require "active_support"
|
1
|
+
require 'shattered_ogre'
|
2
|
+
raise( ShatteredSupport::Error, "Could not find ShatteredOgre (a ShatteredView dependency)" ) unless defined? ShatteredOgre
|
14
3
|
|
15
4
|
require File.dirname(__FILE__) + '/utilities'
|
16
5
|
require File.dirname(__FILE__) + '/node'
|
metadata
CHANGED
@@ -3,8 +3,8 @@ rubygems_version: 0.8.10
|
|
3
3
|
specification_version: 1
|
4
4
|
name: shattered_view
|
5
5
|
version: !ruby/object:Gem::Version
|
6
|
-
version: 0.3.
|
7
|
-
date: 2006-
|
6
|
+
version: 0.3.2
|
7
|
+
date: 2006-06-04
|
8
8
|
summary: "Shattered View: Manipulates OGRE in a ruby-esque fashion."
|
9
9
|
require_paths:
|
10
10
|
- lib
|
@@ -29,7 +29,6 @@ files:
|
|
29
29
|
- lib/base.rb
|
30
30
|
- lib/camera.rb
|
31
31
|
- lib/extensions.rb
|
32
|
-
- lib/game.rb
|
33
32
|
- lib/light.rb
|
34
33
|
- lib/node.rb
|
35
34
|
- lib/resources.rb
|
data/lib/game.rb
DELETED
@@ -1,42 +0,0 @@
|
|
1
|
-
require 'ruby/utilities'
|
2
|
-
require 'view/View'
|
3
|
-
include View
|
4
|
-
|
5
|
-
class Game
|
6
|
-
@@instance = MockObject.new
|
7
|
-
def initialize( sceneType)
|
8
|
-
@renderer = Renderer.new
|
9
|
-
@scene = Scene.new sceneType
|
10
|
-
@camera = @scene.getCamera()
|
11
|
-
@camera.setDirection(Vector3.UNIT_Z)
|
12
|
-
@listeners = []
|
13
|
-
@timeScale = 1.0
|
14
|
-
|
15
|
-
@@instance = self
|
16
|
-
@@gameOver=false
|
17
|
-
end
|
18
|
-
def Game.end
|
19
|
-
@@gameOver = true
|
20
|
-
end
|
21
|
-
def Game.instance
|
22
|
-
return @@instance
|
23
|
-
end
|
24
|
-
def each_frame
|
25
|
-
while( !@@gameOver && @renderer.nextFrame ) do
|
26
|
-
@listeners.each do |listener|
|
27
|
-
listener.frameStarted @renderer.timeSinceLastFrame * timeScale
|
28
|
-
end
|
29
|
-
yield @renderer.timeSinceLastFrame * timeScale
|
30
|
-
end
|
31
|
-
end
|
32
|
-
def addFrameListener( instance )
|
33
|
-
@listeners << instance
|
34
|
-
end
|
35
|
-
def removeFrameListener( instance )
|
36
|
-
@listeners.delete instance
|
37
|
-
end
|
38
|
-
|
39
|
-
attr_reader :scene, :camera
|
40
|
-
attr_accessor :timeScale
|
41
|
-
end
|
42
|
-
|