I spent a fair amount of time working on learning Lua in 2023 (mainly through online courses). In an effort to reinforce that learning, I decided to start working on Lua mods for a couple of games. Towards the end of the year, I finished a mod for Binding of Isaac which is based around increasing the drop rate of items based on how many things the player can kill without taking damage.
While the premise of the mod was relatively straightforward, there were still several programming and design challenges along the way.
The first challenge was simply coming to grips with how Lua works vs. the C-based languages that I’m more accustomed to through other game projects. It’s one thing to follow along with a tutorial, but actually attempting to use a new programming language on a personal project was a really great experience in troubleshooting and debugging. It was interesting trying to implement Lua functionality in multiple scripts, but ultimately I learned a ton trying to use multiple scripts (unlike what I saw in some of the tutorials I watched).
Fortunately, with the help of good documentation and the AI tool Phind, I was able to implement my designs and debug errors which I found difficult to decipher. It’s easy for simple typos or capitalization to go unnoticed in an XML file or Lua file in VS Code, so leveraging AI to help me finish the mod was incredibly valuable.
Since my goal was to reinforce my Lua knowledge, I tried to keep the scope of my mod relatively practical and small.
The heart of the mod’s design comes from a couple of places. A lot of what I think is fun about the original game is not only the way that items mix, but also the systems running under the hood that reward players for things like completing floors without taking damage. So, this is ultimately how I settled on rewarding players for streaks.
My initial design lead to balance challenges as playing the game exceptionally well lead to near guaranteed item drops from most enemies. Other issues I ran into included things like a boss death counting as 60+ entity deaths and skyrocketing the player’s streak. Also, since my mod’s loot table allows player upgrades to drop in addition to normal items like keys and hearts, the player’s build QUICKLY got out of hand (which is fun at first, but ultimately sucks all the fun and challenge out of the experience).
I tried to fixing the issues by doing things like reducing the drop rate, only increasing the streak when a player cleared a room, and not allowing bosses to increase the player’s streak. Ultimately, after getting advice from another designer about some of the challenges I was facing, I settled on capping the maximum streak that a player can achieve. This made the mod play much more like I intended with the original design.
Ultimately, I learned a lot about how the inner workings of Isaac are setup and I gained a new appreciation both for the modding community and for Lua. I was able to accomplish my goal and create some interesting back end functionality, like increasing drop rates every time a player doesn’t get an item (something I took from Diablo 3).
I feel like I only scratched the surface on modding Isaac, but I’m intrigued to create more mods in the future after finishing up this project.
The mod is available on the Steam Workshop! My design document (with the loot table spread sheet) for the project is available here. The Lua scripts can be viewed here.
Website concept art by Tyler Osgood. You can find him at TylerOsgoodArt.com.
Copyright 2022 Daniel Hassett. All Rights Reserved.