This is a Work In Progress simplistic game engine based on SDL2.
Made for self-educational purposes.
Install sdl2
, sdl2_image
, sdl2_mixer
and sdl2_ttf
libraries.
For MacOS you can simply brew install
all of them.
Install the gem, either straight-up with gem install hemi
or using Bundler:
# Gemfile
source "https://rubygems.org"
gem "hemi"
require "hemi"
class Game
prepend Hemi::Engine
end
This proc
will contain logic to be performed during each rendered frame.
Font = Hemi::Render::Font
Sprite = Hemi::Render::Sprite
def text_logic
proc {
Font[:jost_32].render("quick brown fox jumped over the lazy dog", position: [20, 20])
Font[:jost_16].render("press [space] to change LoopState", position: [20, 400])
Font[:jost_16].render("press [q] or [esc] to quit", position: [20, 420])
Font[:jost_16].render("press [F12] to start debug", position: [20, 440])
}
end
def sprite_logic
proc {
Sprite[:gem].render(position: { y: 220, x: 20 })
Sprite[:gem].render(position: { y: 320, x: 220 }, size: { height: 64, width: 128 })
Font[:jost_16].render("press [space] to change LoopState", position: [20, 400])
Font[:jost_16].render("press [q] or [esc] to quit", position: [20, 420])
Font[:jost_16].render("press [F12] to start debug", position: [20, 440])
}
end
LM = Hemi::Event::LoopMachine
def text_events
{
space: -> { LM.switch(:image) },
escape: :stop!,
q: :stop!,
f12: :debug!
}
end
def sprite_events
{
space: -> { LM.switch(:text) },
escape: :stop!,
q: :stop!,
f12: :debug!
}
end
def run
LM.register(:text, text_logic, text_events)
LM.register(:image, sprite_logic, sprite_events)
end
Game.instance.run