2018-04-11 20:46:00 +00:00
|
|
|
package com.unciv
|
2018-03-02 13:34:24 +00:00
|
|
|
|
|
|
|
import com.badlogic.gdx.Game
|
|
|
|
import com.badlogic.gdx.Gdx
|
|
|
|
import com.unciv.logic.GameInfo
|
2018-05-29 10:05:16 +00:00
|
|
|
import com.unciv.logic.GameSaver
|
2018-05-29 19:01:22 +00:00
|
|
|
import com.unciv.models.gamebasics.GameBasics
|
2018-12-01 20:22:30 +00:00
|
|
|
import com.unciv.ui.LanguagePickerScreen
|
2018-08-14 16:09:58 +00:00
|
|
|
import com.unciv.ui.utils.ImageGetter
|
2018-03-02 13:34:24 +00:00
|
|
|
import com.unciv.ui.worldscreen.WorldScreen
|
|
|
|
|
|
|
|
class UnCivGame : Game() {
|
|
|
|
var gameInfo: GameInfo = GameInfo()
|
2018-06-05 18:58:02 +00:00
|
|
|
lateinit var settings : GameSettings
|
2018-03-02 13:34:24 +00:00
|
|
|
|
2018-06-20 15:30:40 +00:00
|
|
|
/**
|
|
|
|
* This exists so that when debugging we can see the entire map.
|
|
|
|
* Remember to turn this to false before commit and upload!
|
|
|
|
*/
|
2018-11-01 17:27:57 +00:00
|
|
|
val viewEntireMapForDebug = false
|
2018-06-20 15:30:40 +00:00
|
|
|
|
2018-12-06 20:02:03 +00:00
|
|
|
// For when you need to test something in an advanced game and don't have time to faff around
|
2018-12-25 20:12:11 +00:00
|
|
|
val superchargedForDebug = false
|
2018-12-06 20:02:03 +00:00
|
|
|
|
2018-05-31 16:46:11 +00:00
|
|
|
lateinit var worldScreen: WorldScreen
|
2018-05-06 05:55:20 +00:00
|
|
|
|
2018-03-02 13:34:24 +00:00
|
|
|
override fun create() {
|
2018-07-26 10:15:38 +00:00
|
|
|
Current = this
|
2018-08-14 16:09:58 +00:00
|
|
|
Gdx.input.isCatchBackKey=true
|
2018-10-12 12:02:12 +00:00
|
|
|
GameBasics.run { } // just to initialize the GameBasics
|
2018-06-05 18:58:02 +00:00
|
|
|
settings = GameSaver().getGeneralSettings()
|
2018-05-29 10:05:16 +00:00
|
|
|
if (GameSaver().getSave("Autosave").exists()) {
|
2018-10-30 20:37:30 +00:00
|
|
|
try {
|
2018-05-06 05:55:20 +00:00
|
|
|
loadGame("Autosave")
|
2018-10-30 20:37:30 +00:00
|
|
|
} catch (ex: Exception) { // silent fail if we can't read the autosave
|
|
|
|
startNewGame()
|
|
|
|
}
|
2018-03-02 13:34:24 +00:00
|
|
|
}
|
2019-01-04 08:59:47 +00:00
|
|
|
else screen= LanguagePickerScreen()
|
2018-05-06 05:55:20 +00:00
|
|
|
}
|
2018-03-02 13:34:24 +00:00
|
|
|
|
2018-06-05 18:58:02 +00:00
|
|
|
fun loadGame(gameInfo:GameInfo){
|
|
|
|
this.gameInfo = gameInfo
|
2018-03-02 13:34:24 +00:00
|
|
|
worldScreen = WorldScreen()
|
|
|
|
setWorldScreen()
|
|
|
|
}
|
|
|
|
|
2018-06-05 18:58:02 +00:00
|
|
|
fun loadGame(gameName:String){
|
|
|
|
loadGame(GameSaver().loadGame( gameName))
|
|
|
|
}
|
|
|
|
|
2018-07-26 10:15:38 +00:00
|
|
|
fun startNewGame() {
|
2019-01-04 08:59:47 +00:00
|
|
|
val newGame = GameStarter().startNewGame(GameParameters().apply { difficulty="Chieftain" })
|
2018-05-29 19:01:22 +00:00
|
|
|
gameInfo = newGame
|
2018-03-02 13:34:24 +00:00
|
|
|
|
|
|
|
worldScreen = WorldScreen()
|
|
|
|
setWorldScreen()
|
|
|
|
}
|
|
|
|
|
|
|
|
fun setWorldScreen() {
|
|
|
|
setScreen(worldScreen)
|
2018-05-31 16:46:11 +00:00
|
|
|
Gdx.input.inputProcessor = worldScreen.stage
|
2018-12-02 21:05:05 +00:00
|
|
|
worldScreen.shouldUpdate=true // This can set the screen to the policy picker or tech picker screen, so the input processor must come before
|
2018-03-02 13:34:24 +00:00
|
|
|
}
|
|
|
|
|
2018-08-14 16:09:58 +00:00
|
|
|
override fun resume() {
|
2019-01-10 18:43:32 +00:00
|
|
|
super.resume()
|
2018-08-14 16:09:58 +00:00
|
|
|
ImageGetter.refreshAltas()
|
2018-12-04 18:47:37 +00:00
|
|
|
|
|
|
|
// This is to solve a rare problem that I still on't understand its cause -
|
|
|
|
// Sometimes, resume() is called and the gameInfo doesn't have any civilizations.
|
|
|
|
// My guess is that resume() was called but create() wasn't, or perhaps was aborted too early,
|
|
|
|
// and the original (and empty) initial GameInfo remained.
|
|
|
|
if(gameInfo.civilizations.isEmpty())
|
|
|
|
return create()
|
|
|
|
|
2018-08-14 16:09:58 +00:00
|
|
|
worldScreen = WorldScreen()
|
|
|
|
setWorldScreen()
|
|
|
|
}
|
|
|
|
|
2018-12-10 12:09:01 +00:00
|
|
|
// Maybe this will solve the resume error on chrome OS, issue 322? Worth a shot
|
|
|
|
override fun resize(width: Int, height: Int) {
|
|
|
|
resume()
|
|
|
|
}
|
|
|
|
|
2018-03-02 13:34:24 +00:00
|
|
|
companion object {
|
|
|
|
lateinit var Current: UnCivGame
|
|
|
|
}
|
2018-06-05 18:58:02 +00:00
|
|
|
}
|