Skip to content
My entry into the Linux Game Jam 2017; official repo here:
Branch: stable
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
screenshots
src
.gitignore
LGJ2017.nimble
LICENSE.txt
README.md

README.md

Pucker Up (Linux Game Jam 2017)

Pucker Up is a game made I made for the Linux Game Jam 2017 which was hosted by The Linux Gamer.

Update 03/28/17: Last night I finished porting the game to HTML5, you can play it here: https://16bpp.net/games/pucker-up-lgj-2017

Pucker Up Screenshot

The license for this game is GPLv3, which the details of that can be found in the files LICENSE.txt.

The source for this game can be found on GitLab here: https://gitlab.com/define-private-public/LGJ2017

Though here is a GitHub mirror: https://github.com/define-private-public/LGJ2017

Needed to Run

  • Some machine that can handle OpenGL
  • A monitor that has at least 800x800 pixels (sorry, that screen size is hard coded in, my bad)
  • Some sort of audio device
  • SDL2 and SDL2_Mixer runtime libraries installed

How To Play

The goal of the game is simple. Make sure that little white puck that is bouncing around doesn't get into the goal at the center. You have two shields that you can bounce the puck off of. Your score at the end of the game will appear in the terminal window.

Controls:

  • Q -- Move outter shield counter clock wise
  • W -- Move inner shield counter clock wise
  • O -- Move inner shield clock wise
  • P -- Move outter shield clock wise
  • Esc -- Quit the game
  • R -- Reset the game

(I'm sorry for the QWOP control sceheme... It happened by accident, I swear.)

How To Build

This game was made using v0.16.x of the fantastic but young Nim Programming Langauge. You should check it out if you haven't. You'll definately need that.

You'll need the development headers and libraries for SDL2, SDL2_Mixer, and some way of accessing the OpenGL headers/libraries on your system.

Don't forget to grab the packages that are listed in LGL2017.nimble; they're required.

To actually build the game. Change into the src/ directory and type nim c game. It should compile to a binary called game. Go head and run it and have fun.

How it was made

I decided I wanted to do some game development in Nim, and do it a bit more "Hard Core," so I decided to forego using a well known game library and build my own. Since Nim is still quite in its infancy, there was a lot more work cut out for me.

In the end, I decided to just use the Circle drawing and collision stuff to game the game. I had to scale back on my original ideas, as I spent way more time on infrastructure work rather than the actual game logic. It was stuff fun and I'm somewhat satisfied with what I made.

"I'm going to write my own game engine from scratch during this game jam, it will be fun!" Things I'll never ever say again...

Special Thanks:

  • The guys who work on Nim
  • jsfxr

Find Me Online:

You can’t perform that action at this time.