Jump to content
  • Advertisement
Sign in to follow this  

Chunk based level generater

This topic is 2023 days old which is more than the 365 day threshold we allow for new replies. Please post a new topic.

If you intended to correct an error in the post then please contact us.

Recommended Posts



I'm currently in the process of making a "level generater" or whatever you call it. The whole concept evolves around it so I kinda don't want to have "non-pseudo-random levels".


This is the approach I'm going with atm;


I have many chunks which basically is a tile with game object placed on it. The tile has a list of other types of tiles that it is "connect-able" with in 8 directions. Up, down, left, right and the diagonals. This is all good and well. But here is the problem. 


When the client connects to a server, the server sends a seed to the client. This seed is used to "random" which chunks to pick from the "connect-able" list. But if I expand(add chunks around) the tile at 0,0 the tile at 1,0 and at 0,1 both has to be connect-able to the chunk at tile 1,1.. And thisis where my logic crashes. Because, after a we tests it was crashing because it encountered impossible connections; Where 1,0 and 0,1 didn't didn't share a connect-able chunk.


And after about using 51 hours and smashing my head against the wall I've come here for ideas, tips, and inspiration..


One of the other things I'm worrying about is that it won't be "realistic" enough. That it would go like Jungle -> city -> beach -> airport in like 4 chunks, which is like all to small of a distance from a realistic point of view.



It doesn't have to be chunk-based solution - but it has be deterministic since I can't transfer all the data for the terrain all the time from the server to client. Aiming at a maximum of about 250 players per server.

Share this post

Link to post
Share on other sites

trying to follow whats going on here...


you're generating terrain using a random number seed.


you start with a tile at 0,0.


but when you add tiles around it, they don't "connect" correctly, despite having an "allowable adjacency" table ?


first thing...  are the allowable adjacency tables in the client and server the same? a typo in one would cause the problem you're getting, IE client and server generate different tiles from same seed.

Share this post

Link to post
Share on other sites

You need to make the generation more hierarchial, so that the "chunks" can be placed in whatever way you feel like. Inside each of those chunks, you now have limited beach-y stuff to watery areas, and city stuff to city areas etc.




[Water, Shore, Land]

**Water:[Oil rig, Sea, Rocky island]

**Shore:[Beach, Harbor, Seaside buildings]

**Land:[Habitated area, Nonhabitated area]

****Habitated area:[City, Village, Farmland]

****Nonhabitated area:[Jungle, Trees, Mountain, Plain]


Each chunk at a particular level should be able to transfer to any other chunk at that level. When picking out the chunks in the level below, take the neighbors at the upper level into account.

For example, you have Shore and Land touch each other. So, when generating Land, you try to place habitated area near that edge, and nonhabitated area away from that edge.

Or if you have Habitated and nonhabitated area next to each other, you try to place Mountain of nonhabitated area away from the shared edge with habitated area.


This would probably create smooth transitions and keep everything logical, and possibly make the world look less ugly. Its a big more complex though.

Share this post

Link to post
Share on other sites

Random map generation with cohesive features flow of tile types that make sense


I did this before and the way you do it is to grow the features


You place seeds that terrain types grow out from  and rules that arbitrate conflicting types


Water features usuall are a key determining factor so you probably build those first   ocean areas and rivers (rivers travel in a given direction doing some random wandering )

Then heights like mountains that grow out from a few scattered  start points (and have a change to down grade to hills before shifting to flat (and stopping)


Next certain plant ecology terrain has restrictions like jungle must be near water  high mountaisn dont have trees abut lower ones might


beaches (if you have them) are around edges of ocean


desert scrub is on flat away from water


etc.. for the rules   (I recall I did an 'influence map' for nearness to water when it had to reflect more than simple adjacency)



Depending on your game mechanics you may have to reprocess the simple 'grown' map to make adaquate play area  - randomly flattening areas or forcing an ocean that takes up too much of the map to be smaller  etc....

Share this post

Link to post
Share on other sites
Sign in to follow this  

  • Advertisement

Important Information

By using GameDev.net, you agree to our community Guidelines, Terms of Use, and Privacy Policy.

We are the game development community.

Whether you are an indie, hobbyist, AAA developer, or just trying to learn, GameDev.net is the place for you to learn, share, and connect with the games industry. Learn more About Us or sign up!

Sign me up!