cube-tube/🕹️cube-tube/app/tick.rb

102 lines
3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2023-03-08 03:06:29 +00:00
# Code that only gets run once on game start
def init(args)
Input.reset_swipe(args)
2023-03-08 03:06:29 +00:00
GameSetting.load_settings(args)
if args.gtk.platform?(:mobile)
args.gtk.set_window_fullscreen(true)
end
2023-05-22 23:32:35 +00:00
end
2023-03-08 03:06:29 +00:00
# Code that runs every game tick (mainly just calling other ticks)
2023-03-08 03:06:29 +00:00
def tick(args)
init(args) if args.state.tick_count.zero?
Music.tick(args)
2023-03-08 03:06:29 +00:00
# this looks good on non 16:9 resolutions; game background is different
args.outputs.background_color = TRUE_BLACK.values
args.state.has_focus ||= true
args.state.scene_stack ||= []
Scene.push(args, Scene.default(args), reset: true) if args.state.scene_stack.empty?
2023-03-08 03:06:29 +00:00
Input.track_swipe(args) if mobile?
2023-03-08 03:06:29 +00:00
args.state.scene_stack.each do |scene|
scene.tick(args) if scene.tick_in_background || scene == args.state.scene_stack.last
end
2023-05-22 23:32:35 +00:00
if args.inputs.keyboard.key_down.home
screenshot_file_name = 'screenshot.png'
screenshot_file_count = 0
while $gtk.read_file(screenshot_file_name)
screenshot_file_count += 1
screenshot_file_name = "screenshot#{screenshot_file_count}.png"
end
args.outputs.screenshots << { x: 0, y: 0, w: args.grid.w, h: args.grid.h, path: screenshot_file_name }
end
2023-03-08 03:06:29 +00:00
debug_tick(args)
rescue FinishTick
end
# raise this as an easy way to end the current tick early
class FinishTick < StandardError; end
# code that only runs while developing
# put shortcuts and helpful info here
def debug_tick(args)
return unless debug?
debug_label(
args, 24.from_right, 24.from_top,
2023-08-03 03:47:02 +00:00
"v#{version} | DR v#{$gtk.version} (#{$gtk.platform}) | Ticks: #{args.state.tick_count} | FPS: #{args.gtk.current_framerate.round} | Win: #{args.grid.window_width}x#{args.grid.window_height}",
2023-03-08 03:06:29 +00:00
ALIGN_RIGHT)
if args.inputs.keyboard.key_down.zero
2023-03-23 05:16:35 +00:00
Sound.play(args, :select)
2023-03-08 03:06:29 +00:00
args.state.render_debug_details = !args.state.render_debug_details
end
if args.inputs.keyboard.key_down.i
2023-03-23 05:16:35 +00:00
Sound.play(args, :select)
2023-03-08 03:06:29 +00:00
Sprite.reset_all(args)
args.gtk.notify!('Sprites reloaded')
2023-03-08 03:06:29 +00:00
end
if args.inputs.keyboard.key_down.r
2023-03-23 05:16:35 +00:00
Sound.play(args, :select)
2023-03-08 03:06:29 +00:00
$gtk.reset
end
if args.inputs.keyboard.key_down.m
2023-03-23 05:16:35 +00:00
Sound.play(args, :select)
2023-03-08 03:06:29 +00:00
args.state.simulate_mobile = !args.state.simulate_mobile
msg = if args.state.simulate_mobile
'Mobile simulation on'
2023-03-08 03:06:29 +00:00
else
'Mobile simulation off'
2023-03-08 03:06:29 +00:00
end
args.gtk.notify!(msg)
end
end
# render a label that is only shown when in debug mode and the debug details
# are shown; toggle with +0+ key
def debug_label(args, x, y, text, align=ALIGN_LEFT)
return unless debug?
return unless args.state.render_debug_details
args.outputs.debug << { x: x, y: y, text: text, alignment_enum: align }.merge(WHITE).label!
end
# different than background_color... use this to change the bg color for the
# visible portion of the game
def draw_bg(args, color)
args.outputs.solids << { x: args.grid.left, y: args.grid.bottom, w: args.grid.w, h: args.grid.h }.merge(color)
end