Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rajko-horvat/OpenCiv1
Open source rewrite of the original Civilization 1 Game designed by Sid Meier and Bruce Shelley in year 1991
https://github.com/rajko-horvat/OpenCiv1
4x 4x-strategy-game civilization civilization-games game remake remake-games retro retro-game retrogaming sid-meier-civilization
Last synced: 3 months ago
JSON representation
Open source rewrite of the original Civilization 1 Game designed by Sid Meier and Bruce Shelley in year 1991
- Host: GitHub
- URL: https://github.com/rajko-horvat/OpenCiv1
- Owner: rajko-horvat
- License: mit
- Created: 2023-05-04T08:35:52.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-08-01T22:30:38.000Z (3 months ago)
- Last Synced: 2024-08-02T13:53:47.678Z (3 months ago)
- Topics: 4x, 4x-strategy-game, civilization, civilization-games, game, remake, remake-games, retro, retro-game, retrogaming, sid-meier-civilization
- Language: C#
- Homepage:
- Size: 11.3 MB
- Stars: 220
- Watchers: 14
- Forks: 10
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/code_of_conduct.md
Awesome Lists containing this project
README
## About
OpenCiv1 project is an open source rewrite of Civilization 1 Game designed by Sid Meier and Bruce Shelley in year 1991.
- The OpenCiv1 uses .NET 8 and Avalonia UI framework and is OS independent. It is currently compatible with desktops: Windows, Linux and MacOSX.
- The game logic is Based on original DOS Civilization 1 game version 475.05 disassembly.
- The game is still very popular and easy to play. But the obsoletness of DOS or Windows 16-bit platform and the bugs that have never been fixed are hindering the popularity of the game.
- The news, discussions about this project and release news are published regularly on Civilization Fanatics Forum page
- For contact purposes [email protected] public email address can be used.
## Copyright considerations
The available code is not a full working copy of the game. To run OpenCiv1 you are legally required to own your own copy of the DOS Civilization game.
This is the reason that not a single file from the original Civilization 1 game is included in this GitHub repository as they are copyrighted.
The part of the game assembly code is emulated with Virtual CPU, and the rest of the code has been rewritten from scratch until all of the code is replaced with new copyright free code.
The other resources (like graphics, music and text) will also be completely replaced with copyright free resources before publishing the complete game.
## Current status
The game is in working state, but you have to legally own the Original game (the .txt, .pic and .pal files have to be present).
## How to Contribute to this project
Anyone can contribute to this repository in accordance with these Contributing guidelines
Currently, you can contribute to this repository in one of the following ways:
- By testing the game functionality and submitting Issues,
- By translating the part(s) of the code from pseudo assembly language to native C# language (for details see Introduction to code translating),
- By designing parts of a 'Default' Visual and Audio theme (which must preserve original Game appearance and feel as much as possible, SVG and MIDI/SoundFonts would be the best),
- By designing parts of a 'Custom' Visual and Audio theme(s) (SVG and MIDI/SoundFonts would be the best).
## Frequently asked questions
Q: Why did you use C#, instead of C in which the original game is written?
A: I have chosen C# becase it's platform independent, secure, flexible, managed, popular, modern and API rich language.
***
Q: Why does the OpenCiv1 differs, in some aspects, from the original Civilization 1 game?
A: There are numerous reasons:
- Simply replicating all of the functionality to skip the DosBox emulation to be able to run the game natively is not a good enough reason (for me) to start a project of this magnitude.
- Copying the game Code, Functionality, Graphics and Audio would be considered a Copyright volation and that is prohibited by current Copyright laws.
- To make the OpenCiv1 available to anyone who wishes to play the game, and that means Copyright free Code, Graphics and Audio.
- To add additional functionalities (features) to the game (like online gaming, scalable HQ Grahics, HQ Audio, plugins, etc.).
- To make OpenCiv1 platform independent, popular, appealing and easy to play, to the older, as well as to the younger public, as was original Civilization 1 game popular back in the day.
***
Q: Does that mean that the OpenCiv1 will be completely different from original Civilization 1 game, like, for example FreeCiv?
A: Absolutely not, the goal is to keep all of the original rules and functionalities, as well as much as possible of the original Visual and Audio appearance.
***
Q: You know that Civilization 7 will be published soon, doesn't that make First Civilization game in the series completely obsolete?
A: Based on some stats, many people think that the first Civilization offers as much fun as the other sequels do.
***
Q: Are there any additional keyboard shorcuts (apart from the default ones)?
A: Yes, these are additional keyboard shorcuts that you can use during the game:
- Alt + D - Enable / Disable the Debug mode<7b> (previously, Shift-56)
- Alt + P - Pause / Resume game
- Alt + 1 - Show / Hide Screen 1
- Alt + 2 - Show / Hide Screen 2
- Alt + 3 - Show / Hide Screen 3
## Dependencies
- .NET Core 8
- Visual C++ 2015-2019 redistributable (on some Windows machines)
## How to run the release version of OpenCiv1
The files from the Release should be copied directly into installed and working DOS Civilization game directory. The game can be run by running the OpenCiv1 executable.
## How to compile the code (.NET Core 8 SDK required)
If you want to Debug (or Compile) the code with Visual Studio 2022 Community Edition, it is assumed that:
- For debugging purposes you have installed DOS Civilization game at 'c:\Dos\Civ1\', or at '~/Dos/Civ1/' if you are using Linux (be careful of uppercase files!).
It is where its home directory resides (Images, palettes, text and save games are loaded/saved there, for now).
You can also compile with CLI method:
- git clone https://github.com/rajko-horvat/OpenCiv1 (To clone a specific branch use: git clone -b [branch] https://github.com/rajko-horvat/OpenCiv1)
- cd OpenCiv1
- dotnet build -c Release
## Project milestones
The goal is to completely rewrite the code (first stage), fix the bugs and port the code to a modern platform (second stage).
### Milestones for a first stage
- Reaching the initial playability of the game (passed),
- Rewrite of the game code, functionalities and features (in progress...),
- Archive the game code.
### Planned milestones for a second stage
What will change in the new version:
- Porting to Razor platform (Web interface, online gaming),
- HQ Graphics (the new graphics will be as close as possible to the spirit of the original version),
- HQ Audio (the new Audio will be as close as possible to the spirit of the original version),
- Some text where appropriate,
- Design (Map zoom functionality, some small updates, also some dialogs will be slightly different),
- Multilanguage capability,
- Multiplayer capability,
- Cheat capability,
- Plugin capability (can override rules, graphics and music/sounds).
What will stay the same:
- Original game rules and logic (except for established bugs),
- Overall look and feel of the original game.
## Current screenshots of the OpenCiv1 game