Skip to main content

Vertical Scrolling Rhythm Game Package

Project description

Reamber (Py)

pip install reamber

This is a simple package to handle VSRG file, useful if you'd want to manipulate data such as offset, column, bpm, etc.

This doesn't provide complex algorithms, only the base dataclasses and helpful basic algorithms

For Developers

Note that reamber is still in alpha stage, means a lot of things aren't settled down yet. That means that a lot of function names and references will change without notice.

It is recommended to only build scratch/temp files if you want to utilize this library

Wiki

Visit the wiki for more info

Info

Motivation

A growing amount of osu!mania players are becoming interested in programming. The best way to learn is to relate it to something that you're familiar with. That's why I'm making a library for most common VSRG (Vertical Scrolling Rhythm Game) types.

WIIFY (What's in it for you)

Picking it up

Everything is in Python, a very easy to pick up language. Installing it is as easy as:

  1. Installing pip
  2. Run pip install reamber

Easy Typing

The library heavily focuses on Typing for explicit returns and arguments. This is at an expense of slower processing speed.

I recommend using PyCharm or any other python editor that supports hinting. Hinting is where the editor hints you available functions, variables, etc.

Piping

Inspired by R Lang %>% operator.

Piping is the act of chaining multiple functions together.

# Grabbing the notes in between 1s and 2s in columns 1 and 3

# Without Piping
Notes(Notes(notes.after(1000)).before(2000)).inColumns([1, 3])

# With Piping
notes.after(1000).before(2000).inColumns([1, 3]).data()

This library supports it, to retrieve the list, just call .data()

List, Pandas Support

This library also supports exporting multiple classes as a list or pandas.DataFrame via .data() and .df() respectively.

So you don't need to feel limited to just the current interfaces.

Examples

Load in a osu! map

Grab the sorted holds in columns 1 & 2 in between 1s and 2s as a list

from reamber.osu.OsuMapObj import OsuMapObj

m = OsuMapObj()
m.readFile("map.osu")
print(m.notes.holds.sorted().inColumns([1, 2]).between(1000, 2000, includeEnds=False).data())

Load in a Quaver map

Grab the SV multiplier values as a list

from reamber.quaver.QuaMapObj import QuaMapObj

m = QuaMapObj()
m.readFile("map.qua")
print(m.svs.multipliers())

Dev Info

How it works

The base hierarchy goes like

MapsetObj
    list of MapObj
        prop BpmList
            extends TimedList
            list of BpmObj
                extends TimedObj
        prop NotePkg
            prop HitList 
                extends NoteList
                list of HitObj
                    extends TimedObj
            prop HoldList
                extends NoteList
                lsit of HoldObj
                    extends TimedObj

A derived file format like osu goes

OsuMap
    extends Map Obj
    prop OsuNotePkg
        extends NotePkg
        prop OsuHitList
            extends OsuNoteList
                extends NoteList
            list of OsuHitObj
                extends HitObj
                    extends NoteObj
                        extends Timedobj
        prop OsuHoldList
            extends OsuNoteList
                extends NoteList
            list of OsuHoldObj
                extends HoldObj
                    extends NoteObj
                        extends TimedObj
    prop OsuBpmList
        extends BpmList
        list of OsuBpmObj
            extends OsuTimingPointMeta
            extends BpmObj
    prop OsuSvList
        extends TimedList
        list of OsuSvObj
            extends TimedObj

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

reamber-0.0.11.tar.gz (45.6 kB view hashes)

Uploaded Source

Built Distribution

reamber-0.0.11-py3-none-any.whl (138.6 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page