12a4d129e7
* Completely rewrote settler settle logic * Added back original file to eligible locations * Improved settling * Fixed not finding cities in range * Fixed settle AI not filtering impassible tiles. * Fixed the possibility that there is no best tile within range. * Fixed minimum city range being to low and causing an error * Found the real fix for when there is no path to a tile to settle * Adjusted tile ranking values * Inverted sorting order to be from highest to lowest * Fixed using tile instead of rankTile * Fixed settle AI only looking at the current tile * Changed behavior of settle AI at the start of the game * Reduced the impact of being near a city * Evaluation now assumes that a lighthouse is build while on a coast * Settle highlight now sorts correctly * Changed the weight of being near a city again * Settle AI now prefers moving to the best tile when no viable tiles were in close distance * Fixed an annoying bug where the settle does not value a city consistently for ranking * Fixed a newer version of the unreachable tile error again * Increased the distance to consider cities by one * Tiles to settle now do not contain duplicate unique luxury resource values * Increased coast tile value * Removed only AI benefiting from ranking unexplored tiles * Changed nearbyCities.any to a for loop * Changed filter and sorting order * Move rankTile to its own function * Moved valuing tiles by distance to city to its own function * Filtering tiles now creates a new map * First settler no longer explores for a better location * Removed bestTile rank from the return * Changed BestTilesToFoundCity to return a separate class holding the return data * Removed some trailing whitespace |
||
---|---|---|
.github | ||
.idea/inspectionProfiles | ||
android | ||
buildSrc | ||
core | ||
desktop | ||
detekt/config | ||
docs | ||
extraImages | ||
fastlane/metadata/android | ||
gradle/wrapper | ||
ios | ||
server | ||
tests | ||
.dockerignore | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
build.gradle.kts | ||
changelog.md | ||
debug.keystore | ||
docker-compose.yml | ||
Dockerfile | ||
gradle.properties | ||
gradlew | ||
gradlew.bat | ||
keystore.jks | ||
LICENSE | ||
mkdocs.yml | ||
README.md | ||
settings.gradle.kts |
Unciv - Civ V remake for Android & Desktop
What is this?
An open source, mod-friendly Android and Desktop remake of Civ V, made with LibGDX
Is this any good?
Depends what you're looking for. If you're in the market for high-res graphics, amazing soundtracks, animations etc, I highly recommend Firaxis's Civ-V-like game, "Civilization V".
If you want a small, fast, moddable, FOSS, in-depth 4X that can still run on a potato, you've come to the right place :)
What's the roadmap?
In this order:
- Polish! As you may have noticed, Unciv is fully functional but rough around the edges. This means:
- UI+UX improvements (suggestions welcome!)
- Better automation, AI etc. in-game
- Finishing off Vanilla mechanics - mostly done!
- G&K mechanics - espionage, small other changes (see #4697)
- BNW mechanics - trade routes, world congress, etc.
Contributing
How can I help?
Programmers start here!
Translators start here!
Modders start here!
You can join us in any of the open issue, or work on improving anything you want - once you're finished, issue a pull request and it'll go into the next version!
If not, you can help by spreading the word - vote for Unciv where you can, mention it on Reddit or Twitter etc, and help us with new ideas of how to get the word out!
FAQ
How do I install?
- Android - Google Play or F-droid
- Windows/Linux - itch.io, Flatpak via Flathub, or AUR
- Raspberry Pi - Pi-apps
- MacOS - Install with this guide
- Jars, APKs and Windows/Linux builds also available in Releases (run jar with
java -jar Unciv.jar
) - not recommended since we update frequently and you will quickly become out-of-date - Build from scratch if that's your thing
How about IOS?
I'm not planning on it. It means paying money to Apple, yet another release path, and since I don't have an IOS device it means I can't test it properly.
Steam release?
Steam has decided that they don't want to host Unciv, they probably don't want to risk legal issues with Firaxis (although those should be non-existent, see below)
Will you implement {feature}?
If it's in the original Civ V, then yes!
There's a lot left to implement, so it's hard to give an estimation of when exactly each feature will be added, but we're constantly improving!
If not, then the feature won't be added until we've finished all the features from the original Civ - as mentioned, this will take a while!
Why not? This is its own game, why not add features that weren't in Civ V?
Having a clear vision is important for actually getting things done.
Anyone can make a suggestion. Not all are good, viable, or simple. Not many can actually implement stuff.
As an open source project, this stuff is done in our spare time, of which there isn't much.
We need a clear-cut criteria to decide what to work on and what not to work on.
Will you implement Civ VI?
Considering how long it took to get this far, no.
How can I learn to play? Where's the wiki?
All the tutorial information is available in-game at menu > civilopedia > tutorials
All the information is included in the amazing Civ V wiki
Since this is a Civ V clone, you can search Google for how to play Civ V and there are loads of answers =)
Alternatively, you could join us on Discord and ask there =D
Aren't you basically making a Civ V clone? Is that even legal?
This is a subject that I've heard a lot of hearsay on but no solid sources of law.
From what I gather, it is illegal:
- To use the Civilization name
- To impersonate the Civ games (so calling yourself civi|zation with a similar logo, for instance)
- To use any assets from the original game (images, sound etc) - they belong to Firaxis
From what I understand, intellectual property rights apply to names, characters and settings. They do not apply to mechanics - as I'm sure you know, there are a billion Flappy Bird knockoffs
If anyone has any real legal sources, or can shed some light on the limits of what is and is not allowed, I'd be happy to hear!
Run with Docker
If you have docker compose installed:
$ docker compose build && docker compose up
and then goto http://localhost:6901/vnc.html?password=headless
If just docker:
$ docker build . -t unciv && docker run -d -p 6901:6901 -p 5901:5901 unciv
Or just use our already built one:
$ docker run -d -p 6901:6901 -p 5901:5901 ghcr.io/yairm210/unciv
and then goto http://localhost:6901/vnc.html?password=headless