Class: CyberarmEngine::Stats::StatsPlotter
- Inherits:
-
Object
- Object
- CyberarmEngine::Stats::StatsPlotter
- Defined in:
- lib/cyberarm_engine/stats.rb
Instance Attribute Summary collapse
-
#position ⇒ Object
readonly
Returns the value of attribute position.
Instance Method Summary collapse
- #calculate_frame_timings_graph ⇒ Object
- #calculate_graphs ⇒ Object
- #draw ⇒ Object
- #draw_graphs ⇒ Object
- #draw_timings ⇒ Object
-
#initialize(x, y, z = Float::INFINITY, width = 128, height = 128) ⇒ StatsPlotter
constructor
A new instance of StatsPlotter.
Constructor Details
#initialize(x, y, z = Float::INFINITY, width = 128, height = 128) ⇒ StatsPlotter
Returns a new instance of StatsPlotter.
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 |
# File 'lib/cyberarm_engine/stats.rb', line 110 def initialize(x, y, z = Float::INFINITY, width = 128, height = 128) @position = Vector.new(x, y, z) @width = width @height = height @padding = 2 @text_size = 16 @max_timing_label = CyberarmEngine::Text.new("", x: x + @padding + 1, y: y + @padding, z: z, size: @text_size, border: true) @avg_timing_label = CyberarmEngine::Text.new("", x: x + @padding + 1, y: y + @padding + @height / 2 - @text_size / 2, z: z, size: @text_size, border: true) @min_timing_label = CyberarmEngine::Text.new("", x: x + @padding + 1, y: y + @height - (@text_size + @padding / 2), z: z, size: @text_size, border: true) @timings_label = CyberarmEngine::Text.new("", x: x + @padding + @width + @padding, y: y + @padding, z: z, size: @text_size, border: true) @frame_stats = [] @graphs = { frame_timings: [] } end |
Instance Attribute Details
#position ⇒ Object (readonly)
Returns the value of attribute position.
108 109 110 |
# File 'lib/cyberarm_engine/stats.rb', line 108 def position @position end |
Instance Method Details
#calculate_frame_timings_graph ⇒ Object
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 |
# File 'lib/cyberarm_engine/stats.rb', line 134 def calculate_frame_timings_graph @graphs[:frame_timings].clear samples = @width - @padding nodes = Array.new(samples.ceil) { [] } slice = 0 @frame_stats.each_slice((CyberarmEngine::Stats.max_frame_history / samples.to_f).ceil) do |bucket| bucket.each do |frame| nodes[slice] << frame.frame_timing.duration end slice += 1 end nodes.each_with_index do |cluster, i| break if cluster.empty? @graphs[:frame_timings] << CyberarmEngine::Vector.new(@position.x + @padding + 1 * i, (@position.y + @height - @padding) - cluster.max) end end |
#calculate_graphs ⇒ Object
130 131 132 |
# File 'lib/cyberarm_engine/stats.rb', line 130 def calculate_graphs calculate_frame_timings_graph end |
#draw ⇒ Object
156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 |
# File 'lib/cyberarm_engine/stats.rb', line 156 def draw @frame_stats = CyberarmEngine::Stats.frames.select(&:complete?) return if @frame_stats.empty? calculate_graphs @max_timing_label.text = "Max: #{@frame_stats.map { |f| f.frame_timing.duration }.max.to_s.rjust(3, " ")}ms" @avg_timing_label.text = "Avg: #{(@frame_stats.map { |f| f.frame_timing.duration }.sum / @frame_stats.size).to_s.rjust(3, " ")}ms" @min_timing_label.text = "Min: #{@frame_stats.map { |f| f.frame_timing.duration }.min.to_s.rjust(3, " ")}ms" Gosu.draw_rect(@position.x, @position.y, @width, @height, 0xaa_222222, @position.z) Gosu.draw_rect(@position.x + @padding, @position.y + @padding, @width - @padding * 2, @height - @padding * 2, 0xaa_222222, @position.z) draw_graphs @max_timing_label.draw @avg_timing_label.draw @min_timing_label.draw # TODO: Make this optional draw_timings end |
#draw_graphs ⇒ Object
179 180 181 |
# File 'lib/cyberarm_engine/stats.rb', line 179 def draw_graphs Gosu.draw_path(@graphs[:frame_timings], Gosu::Color::WHITE, Float::INFINITY) end |
#draw_timings ⇒ Object
183 184 185 186 187 188 189 |
# File 'lib/cyberarm_engine/stats.rb', line 183 def draw_timings frame = @frame_stats.last @timings_label.text = "#{frame.attempted_multitiming? ? "<c=d00>Attempted Multitiming!\nTimings may be inaccurate for:\n#{frame.multitimings.map { |m, _| m}.join("\n") }</c>\n\n" : ''}#{frame.timings.map { |t, v| "#{t}: #{v.duration}ms" }.join("\n")}" Gosu.draw_rect(@timings_label.x - @padding, @timings_label.y - @padding, @timings_label.width + @padding * 2, @timings_label.height + @padding * 2, 0xdd_222222, @position.z) @timings_label.draw end |