Wave Function Collapse
procedural generation (c#)
Summary & Purpose
I’m a big fan of procedual generation and randomness in video games, to that end I wanted to make a package for doing procedual map generation. I stumbled upon wave function collapse and it seemed to accomplish what we needed to do. I found implementations in python and C, which were for small bitmaps or images which generated the image below.
data:image/s3,"s3://crabby-images/be948/be948d476c166109b4174617a9d79c75dd95c6fe" alt="bitmap WFC"
I ported a combination of these implementations to unity, while adding in the ability to use gameobjects and 3d models of “blocks” as cells.
data:image/s3,"s3://crabby-images/b2a50/b2a507e1dc742535df15a7965f3a48a349efed9f" alt="blocks"
Minimal setup in unity thanks to some custom editor tools allows me to quickly generate maps.
A good start, but we can get even closer to an ‘objective’ level by making this a maze. The way we can do this is by preprocessing cells allowing for one “entrance” and one “exit”.
This is cool and all but adding in a bit of playability goes a long way. ( Car controller scripts not made by me, just a quick asset drop while using my procedually generated roads as a surface)
This system is currently being used as is with different blocks in a roguelike action game I’m making where it generates a procedual maze for certain levels.
data:image/s3,"s3://crabby-images/4f7f0/4f7f0c3ae01f0757690b0551672d8261f993bf71" alt="maze generated"
data:image/s3,"s3://crabby-images/b3930/b39301cd7034e0643b2a3c42eb5f8d0081339e4e" alt="maze path"