Skip to main content

Indie game storeFree gamesFun gamesHorror games
Game developmentAssetsComics
SalesBundles
Jobs
TagsGame Engines
(2 edits) (+1)

Yeah, the most important part of a rhythm game is making it feel smooth, accurate, and consistent. It becomes immediately apparent if it's even a little bit off. I know the pain because I've made one DDR thing in the past - I made a room run at 300fps and it was done so badly lmao. This time I stood with 60fps, but syncing a song to 60fps with no access to real time functions was like a puzzle. I managed to perfect the timing and charting tho, as long as there's no lag spikes or frame skips because then it desyncs, and I couldn't figure out a way to resync it.

Interesting that you managed to get your’s working without real-time. I had mine measure if the time was greater than or equal to the time of when the hit circle needs to be fully visible for every frame, so the time value is relative to the start of the song and is already preset in the map file. If multiple objects were behind, the program would go iterate frame by frame adding and deleting objects until it is in sync. An issue with this is that each object begins to appear slightly late since it needs to render in sync with the frame rate of the game loop so that might be part of why it seems off too. Aside from this, the objects should be at least timed on sync relative to one another as the maps were designed in the osu editor. The start offset might be off by a significant amount though due to desync with the audio and visuals combined with lag.

(+1)

It was actually a fun puzzle to figure out. The song was exactly 125sec long (7500 frames at 60fps), and exactly 1504 beats long, which means if I play a beat every 5 frames, I'd have 4 beats left over at the end, meaning every 1875 frames I need to advance beat by +1 to reach 1504, keeping everything in sync the whole way through. After that, just sync the song+arrows to the chart, and bam! Sync! :D