2023-03-27 02:09:28 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2023-03-08 03:06:29 +00:00
|
|
|
# Code that only gets run once on game start
|
|
|
|
def init(args)
|
2023-03-26 23:28:26 +00:00
|
|
|
Input.reset_swipe(args)
|
2023-03-08 03:06:29 +00:00
|
|
|
GameSetting.load_settings(args)
|
2023-05-08 04:51:26 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
2023-03-27 02:09:28 +00:00
|
|
|
# Code that runs every game tick (mainly just calling other ticks)
|
2023-03-08 03:06:29 +00:00
|
|
|
def tick(args)
|
2023-03-27 02:09:28 +00:00
|
|
|
init(args) if args.state.tick_count.zero?
|
2023-05-07 23:35:52 +00:00
|
|
|
|
|
|
|
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
|
2023-03-27 02:09:28 +00:00
|
|
|
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
|
|
|
|
2023-03-26 23:28:26 +00:00
|
|
|
Input.track_swipe(args) if mobile?
|
2023-03-08 03:06:29 +00:00
|
|
|
|
2023-03-27 02:09:28 +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)
|
2023-03-27 02:09:28 +00:00
|
|
|
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
|
2023-03-27 02:09:28 +00:00
|
|
|
'Mobile simulation on'
|
2023-03-08 03:06:29 +00:00
|
|
|
else
|
2023-03-27 02:09:28 +00:00
|
|
|
'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
|