GithubHelp home page GithubHelp logo

marijnvdwerf / openrct2 Goto Github PK

View Code? Open in Web Editor NEW

This project forked from openrct2/openrct2

2.0 2.0 2.0 80.64 MB

An open source re-implementation of Roller Coaster Tycoon 2.

Home Page: http://openrct2.website

License: GNU General Public License v3.0

CMake 0.11% XC 0.14% PowerShell 0.21% NSIS 0.12% Shell 0.08% C 90.94% C++ 7.20% Objective-C 1.15% GLSL 0.05%

openrct2's Introduction

OpenRCT2

An open-source re-implementation of RollerCoaster Tycoon 2. A construction and management simulation video game that simulates amusement park management.

Build Status

Windows Linux / Mac Download
master AppVeyor Travis CI OpenRCT2.org
develop AppVeyor Travis CI OpenRCT2.org

Chat

English:
Gitter
Gitter
Nederlands:
Gitter

Contents

1 Introduction

OpenRCT2 is an open-source re-implementation of RollerCoaster Tycoon 2 (RCT2). The gameplay revolves around building and maintaining an amusement park containing attractions, shops and facilities. The player must try to make a profit and maintain a good park reputation whilst keeping the guests happy. OpenRCT2 allows for both scenario and sandbox play. Scenarios require the player to complete a certain objective in a set time limit whilst sandbox allows the player to build a more flexible park with optionally no restrictions or finance.

RollerCoaster Tycoon 2 was originally written by Chris Sawyer in x86 assembly and is the sequel to RollerCoaster Tycoon. The engine was based on Transport Tycoon, an older game which also has an equivalent open-source project, OpenTTD. OpenRCT2 attempts to provide everything from RCT2 as well as many improvements and additional features, some of these include support for modern platforms, an improved interface, improved guest and staff AI, more editing tools, increased limits, and cooperative multiplayer. It also re-introduces mechanics from RollerCoaster Tycoon that were not present in RollerCoaster Tycoon 2. Some of those include; mountain tool in-game, the "have fun" objective, launched coasters (not passing-through the station) and several buttons on the toolbar.

2 Downloading the game (pre-built)

OpenRCT2 requires original files of RollerCoaster Tycoon 2 to play. It can be bought at either Steam or GOG.com.

OpenRCT2.org offers precompiled builds and installers of the latest stable and the develop branch. There is also a cross platform Launcher available that will automatically update your build of the game so that you always have the latest version.

3 Building the game

3.1 Building prerequisites

OpenRCT2 requires original files of RollerCoaster Tycoon 2 to play. It can be bought at either Steam or GOG.com.

Windows:

Mac:

Mac / Linux:

  • sdl2
  • sdl2-ttf
  • speexdsp
  • curl (only if building with network support)
  • jansson (only if building with network support)
  • iconv (part of glibc on Linux)
  • cmake All libs listed here (bar cmake) required in 32 bit variants.

3.2 Compiling and running

Windows:

  1. Check out the repository. This can be done using GitHub Desktop or other tools.
  2. Open a new Developer Command Prompt for VS2015, run PowerShell and then navigate to the repository.
  3. Run the setenv.ps1 script in the repository to set up your PowerShell environment for OpenRCT2 development. This will warn you of any missing applications required to build OpenRCT2.
  4. Run install to download the required dependencies to build OpenRCT2.
  5. Run build all to build all the required components for OpenRCT2.
  6. Run run to run OpenRCT2.

These PowerShell scripts are stored in .\scripts\ps and have parameters. Once you have used the build script once, further development can be done within Visual Studio by opening openrct2.sln. The build scripts have several commands allowing you to rebuild certain components such g2.dat or language files.

Mac:

We support native builds for macOS (limited to i386 only for now). Make sure that you have Homebrew installed and than run the following commands to install all the needed libraries and build OpenRCT2.

# Install libraries
./install.sh

# Build OpenRCT2
./build.sh

# Run the game
./openrct2

Linux:

We support native builds for Linux (limited to i386 only for now). As the easiest approach depends on your distribution, please take a look at the wiki.

4 Contributing

OpenRCT2 uses the gitflow workflow. If you are implementing a new feature or logic from the original game, please branch off and perform pull requests to develop. If you are fixing a bug for the next release, please branch off and perform pull requests to the correct release branch. master only contains tagged releases, you should never branch off this.

Please read our contributing guidelines for information.

4.1 Bug fixes

A list of bugs can be found on the issue tracker. Feel free to work on any bug and submit a pull request to the develop branch with the fix. Mentioning that you intend to fix a bug on the issue will prevent other people from trying as well.

4.2 New features

Please talk to the OpenRCT2 team first before starting to develop a new feature. We may already have plans or reasons against it, therefore contacting us will allow us to help you or prevent you from wasting any time. You can talk to us via gitter, see links at the top of this page.

4.3 Translation

You can translate the game into other languages by editing the language files in data/language directory. Please join discussions and submit pull requests to OpenRCT2/Localisation.

5 Licence

OpenRCT2 is licensed under the GNU General Public License version 3.

6 More information

openrct2's People

Contributors

intelorca avatar duncanspumpkin avatar janisozaur avatar marijnvdwerf avatar gymnasiast avatar zsilencer avatar openrct2-git-bot avatar trigger-segfault avatar kevinburke avatar adrian17 avatar lrflew avatar zedthree avatar qcz avatar lnz avatar overv avatar gdanix avatar broxzier avatar hexdec avatar aaronvangeffen avatar tweerwag avatar thomasdenh avatar mzmiric5 avatar x123m3-256 avatar ddevrien avatar anyc avatar jinxit avatar maciekbaron avatar wirlie avatar runelaenen avatar atmaxinger avatar

Stargazers

CJ Gaspari avatar  avatar

Watchers

 avatar James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.