Procedural / dynamic ground creation

1 favourites
  • 3 posts
From the Asset Store
25 high quality isometric ground blocks + sprite sheet
  • Hey there!

    I want to create a game like penguin slider (video link below), where you have to speed up a penguin over a dynamic and randomly generated ground by forcing it down in the right moment.

    The question:

    Iam thinking about the best way to create a dynamic ground.

    My intention is this game:

    youtube.com/watch

    guess they created a dynamic spine where the area below will be drawed / filled by code. Do somebody know if this would be possible with construct and whats the best way to do it? I wount create any prefabs with fix elements / tiles. Guess it wount be that dynamic, because you will remember those tiles after a bunch of tries. On the other hand this game mode would depend on a variable ground generation for maximum fun.

    Thanks in advance!

  • We don't have access to the collision polygons at runtime, so it a choice between setting position via math formula(spline) with drawing on canvas, or placing generic sprites with various shaped poly's with some shader/blends as a mask. Or possibly some combination of the two.

  • Try Construct 3

    Develop games in your browser. Powerful, performant & highly capable.

    Try Now Construct 3 users don't see these ads
  • The terrain is just a graph. For any x position you just need a way to calculate a y.

    A simple start would be y=sin(x)

    Or to center it vertically and make the hills bigger you can do y=240+100*sin(x)

    There are many ways to make the terrain more interesting than just a sine wave. You can use a noise plugin, or maybe add multiple sine waves together. Another idea is to just fill an array with random numbers and use cosp() to interpolate smoothly between the numbers.

    So basically a function like this:

    Function terrain(x)

    — i = int( x/100)

    — t = x/100 -i

    — return cosp(array.at(i),array.at(i+1),t)

    Then you can move the player around in any way you like, and you can know if it hit the ground if player.y > function.call(“terrain”, player.x)

    I don’t really want to fight with constructs collision system to somehow make it work with this, so instead you can do it manually. It’s also simple enough to do your own motion with a vx and vy variable.

    Every tick

    — add 200*dt to player.vy

    — add player.vx*dt to player.y

    — add player.vy*dt to player.y

    Set y0 to function.call(“terrain”, player.x)

    Set y1 to function call(“terrain”, player.x + 0.001)

    Set ang to angle(0,y0,0.001,y1)

    Player.y > terrain(player.x)

    — set player.y to y0

    — set dot to player.vx*cos(ang)+player.vy*sin(ang)

    — set player.vx to dot*cos(ang)

    — set player.vy to dot*sin(ang)

    So far so good. I guess I forgot to cover a way to draw the terrain. You could get away with only drawing what’s on screen.

    Destroy circle

    Repeat 100 times

    — create circle at (0,0)

    — set x to lerp(leftScreen, rightscreen, loopindex/99)

    — set y to function.call(“terrain”, self.x)

    You could also stretch rectangle sprites between the circles to give a continuous line.

    To fill the area below you could use all the circle locations along with the bottom two corners of the screen with a canvas fill function.

    The gradients would require reasoning about how you’d want it to look and maybe drawing an offset polygon or placing blurred scaled sprites at key spots.

    EDIT:

    working example.

    uc5b5be68baf7366532b23b7006d.dl.dropboxusercontent.com/cd/0/get/Ch9ml0RjxFIH4ee6NYaG1l9TTrZWnmHpNrSK-EyBZD2FvT__vKsQ8SJ6tfSiEPAZHK6upiKGkn-FdL-8aq_i632FnQdlh0-6qYQZzlm0qhZKCJLbJUb7ESqRsdMQho9refIUyQrJXnOAJIkrHuC26NKX/file

Jump to:
Active Users
There are 1 visitors browsing this topic (0 users and 1 guests)