Merge branch 'master' into master

This commit is contained in:
lishaoxia1985 2019-09-05 11:10:15 +08:00 committed by GitHub
commit 6f779301dd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
17 changed files with 190 additions and 76 deletions

1
.gitignore vendored
View file

@ -134,3 +134,4 @@ android/assets/fonts/
android/release/android.aab
android/assets/maps/
android/release/android.aab.sig
android/release/android-release.aab

View file

@ -9,10 +9,10 @@ android:
- platform-tools
# The BuildTools version used by your project
- build-tools-28.0.3
- build-tools-29.0.2
# The SDK version used to compile your project
- android-28
- android-29
jdk:

View file

@ -4,7 +4,7 @@
[![Travis CI w/ Logo](https://img.shields.io/travis/yairm210/UnCiv/master.svg?logo=travis)](https://travis-ci.org/yairm210/UnCiv)
[![LibGDX](https://img.shields.io/badge/libgdx-1.9.10-red.svg)](https://libgdx.badlogicgames.com/)
[![Kotlin](https://img.shields.io/badge/kotlin-1.3.41-orange.svg)](http://kotlinlang.org/)
[![Kotlin](https://img.shields.io/badge/kotlin-1.3.50-orange.svg)](http://kotlinlang.org/)
[![Discord Chat](https://img.shields.io/discord/586194543280390151.svg)](https://discord.gg/bjrB4Xw)
@ -18,6 +18,7 @@ Made with LibGDX on Android Studio
* Map tiles (including water), resources and improvements
* Units and movement
* Air units
* Cities, production and buildings
* Population and Specialists
* Science, Cultural and Domination victories
@ -26,13 +27,14 @@ Made with LibGDX on Android Studio
* Promotions and combat modifiers
* Other civilizations, diplomacy and trade
* City-states
* Hotseat multiplayer
* Multiplayer (hotseat and across internet)
* Map editor
# What's next?
* UI+UX improvements (suggestions welcome!)
* Air units
* Filling out gaps (missing civs etc)
I'd love to hear your feedback, either here or via mail to yairm210@hotmail.com!

View file

@ -56,6 +56,7 @@
Simplified_Chinese:"向[civName]宣战吗?"
Portuguese:"Deseja declarar guerra a [civName]?"
Polish:"Wypowiedz wojnę cywilizacji [civName]"
Russian:"Объявить войну [civName]?"
}
"[civName] has declared war on us!":{
@ -101,6 +102,7 @@
Portuguese:"Negociar paz"
French:"Négocier la paix"
Polish:"Negocjuj pokój"
Russian:"Предложить мир"
}
"Very well.":{
@ -109,6 +111,7 @@
Simplified_Chinese:"很好。"
Portuguese:"Muito bem."
Polish:"Niech tak będzie."
Russian:"Очень хорошо."
}
"Farewell.":{
@ -117,12 +120,14 @@
Simplified_Chinese:"再见。"
Portuguese:"Adeus."
Polish:"Żegnaj."
Russian:"До встречи."
}
"Sounds good!":{
Italian:"Sta bene!"
French:"Très bien!"
Polish:"Bardzo dobrze!"
Russian:"Звучит неплохо!"
}
"Not this time.":{ // declining trade text
@ -131,6 +136,7 @@
French:"Pas cette fois."
Portuguese:"Dessa vez não."
Polish:"To się nie uda"
Russian:"Не в этот раз."
}
"Excellent!":{ // AI statement after we accept a trade they proposed, and when we meet a city state, and our response when they agree to our diplomatic demand
@ -139,6 +145,7 @@
French:"Excellent!"
Portuguese:"Excelente!"
Polish:"Wyśmienicie!"
Russian:"Превосходно!"
}
"How about something else...":{ // Counteroffer to AI offer //shouldn't it be 'How about somenthing else?' ?
@ -147,6 +154,7 @@
French:"Pourquoi pas autre chose..."
Portuguese:"Porque não algo mais..."
Polish:"Oto nasza oferta."
Russian:"Как насчёт другого..."
}
"A pleasure to meet you.":{
@ -155,6 +163,7 @@
Simplified_Chinese:"很高兴见到你。"
Portuguese:"Prazer conhece-lo"
Polish:"Czuję się zaszczycony."
Russian:"Рады видеть вас."
}
"Our relationship: ":{
@ -163,6 +172,7 @@
Simplified_Chinese:"我们的关系:"
Portuguese:"Nossas relações"
Polish:"Nasze relacje:"
Russian:"Наши отношения"
}
"We have encountered the City-State of [name]!":{ // e.g. the Cultured city state of Vienna
@ -170,6 +180,7 @@
Portuguese:"Nós encontramos a cidade-estado de [name]"
French:"Nous avons rencontré la cité-état de [name]!"
Polish:"Napotkaliśmy państwo-miasto o nazwie [name]!"
Russian:"Мы обнаружили город-государство [name]!"
}
// Friendship declaration flavor texts
@ -179,6 +190,7 @@
Simplified_Chinese:"宣布相互友善([numberOfTurns]回合)"
Portuguese:"Declarar amizade ([numberOfTurns] turns)"
Polish:"Zadeklaruj przyjaźń na [numberOfTurns] tur"
Russian:"Объявить о дружбе на [numberOfTurns] ходов"
}
"May our nations forever remain united!":{
@ -187,6 +199,7 @@
Simplified_Chinese:"我们两个文明将永远肝胆相照、休戚与共地站在一起!"
Portuguese:"Que nossas nações se mantenho unidas para sempre!"
Polish:"Oby ta przyjaźń już zawsze łączyła nasze cywilizacje!"
Russian:"Да будут наши державы навеки едины!"
}
"Indeed!":{
@ -195,6 +208,7 @@
Simplified_Chinese:"这是无比正确的命运抉择!"
Portuguese:"Perfeito!"
Polish:"Wspaniale!"
Russian:"Разумеется!"
}
// Denunceation flavour texts
@ -202,11 +216,13 @@
Italian:"Denuncia ([numberOfTurns] turni)"
French:"Dénoncer ([numberOfTurns] tours)"
Polish:"Potęp cywilizację na [numberOfTurns] tur"
Russian:"Осуждение на [numberOfTurns] ходов"
}
"We will remember this.":{
Italian:"Non credere che ce lo scorderemo!"
French:"Nous nous en souviendrons."
Russian:"Мы это запомним"
}
@ -217,6 +233,7 @@
French:"Impardonnable"
Simplified_Chinese:"仇深似海"
Portuguese:"Imperdoável"
Russian:"Непростительно враждебные"
}
"Enemy":{
@ -224,6 +241,7 @@
French:"Ennemi"
Simplified_Chinese:"宿命之敌"
Portuguese:"Inimigos" //as in 'we are enemies' not just 'they are our enemy'
Russian:"Враждебные"
}
"Competitor":{
@ -231,6 +249,7 @@
French:"Adversaire" //or en compétition
Simplified_Chinese:"瑜亮之争"
Portuguese:"Adversários"
Russian:"Соперничающие"
}
"Neutral":{
@ -238,6 +257,7 @@
French:"Neutre"
Simplified_Chinese:"泛泛之交"
Portuguese:"Neutra" // relation=relação relação is in feminine so therefore neutral(= neutro/neutra) deve ser feminino
Russian:"Нейтральные"
}
"Favorable":{
@ -245,6 +265,7 @@
French:"Favorable"
Simplified_Chinese:"惺惺相惜"
Portuguese:"Favorável"
Russian:"Приемлемые"
}
"Friend":{
@ -252,6 +273,7 @@
French:"Ami"
Simplified_Chinese:"秦晋之好"
Portuguese:"Amigos"
Russian:"Дружеские"
}
"Ally":{
@ -259,6 +281,7 @@
French:"Allié"
Simplified_Chinese:"歃血之盟"
Portuguese:"Aliado"
Russian:"Союзнические"
}
// City States
@ -266,31 +289,37 @@
"Provides [amountOfCulture] culture at 30 Influence":{
Italian:"Dona [amountOfCulture] punti Cultura a minimo 30 Punti Influenza"
French:"Fournit [amountOfCulture] de Culture à 30 d'influence"
Russian:"Даёт [amountOfCulture] культуры при 30 Влияния"
}
"Provides 3 food in capital and 1 food in other cities at 30 Influence":{
Italian:"Dona 3 Cibo alla Capitale e 1 Cibo alle altre Città a minimo 30 Punti Influenza"
French:"Fournit 3 Nourriture à la capitale et 1 nourriture pour les autres villes à 30 d'influence"
Russian:"Даёт 3 Еды в столице и 1 Еда в остальных городах при 30 Влияния"
}
"Provides 3 happiness at 30 Influence":{
Italian:"Dona 3 Punti Felicità a minimo 30 Punti Influenza"
French:"Fournit 3 de Bonheur à 30 d'influence"
Russian:"Даёт 3 Счастья при 30 Влияния"
},
"Provides land units every 20 turns at 30 Influence":{
Italian:"Concede un'unità terrestre ogni 20 turni a minimo 30 Punti Influenza"
French:"Fournit des unités terrestres tous les 20 tours à 30 d'influence"
Russian:"Даёт сухопутные юниты каждые 20 ходов при 30 Влияния"
},
"Gift [goldAmount] gold":{
Italian:"Dona [goldAmount] Oro"
French:"Donner [goldAmount] ors"
Russian:"Дарит [goldAmount] золота"
}
"Relationship changes in another [turnsToRelationshipChange] turns":{
Italian:"I rapporti cambieranno tra [turnsToRelationshipChange] turni"
French:"Les relations changent dans [turnsToRelationshipChange] tours"
Russian:"Отношения изменятся в следующие [turnsToRelationshipChange] ходов"
}
@ -302,6 +331,7 @@
French:"Vous nous avez déclaré la guerre!"
Simplified_Chinese:"不知死活的蠢货!你竟敢向我们宣战!"
Portuguese:"Você declarou guerra contra nós!"
Russian:"Вы объявляли нам войну!"
}
"Your warmongering ways are unacceptable to us.":{
@ -309,6 +339,7 @@
French:"Votre bellicisme est inacceptable pour nous."
Simplified_Chinese:"你的穷兵黩武行径是我们无法容忍的!"
Portuguese:"Seus costumes de guerra são inaceitáveis para nós."
Russian:"Ваша воинственность для нас неприемлема."
}
"You have captured our cities!":{
@ -316,6 +347,7 @@
French:"Vous avez capturé nos villes!"
Simplified_Chinese:"多行不义必自毙!你竟敢占领我们的城市!"
Portuguese:"Você capturou nossas(nossa) cidades(cidade)!"
Russian:"Вы захватывали наши города!"
}
"Years of peace have strengthened our relations.":{
@ -323,6 +355,7 @@
French:"Les années de paix ont renforcées notre relation"
Simplified_Chinese:"多年的和平时光让我们更加珍视彼此的关系。"
Portuguese:"Anos de paz fortaleceram nossas relações."
Russian:"Годы мира укрепили наши отношения"
}
"Our mutual military struggle brings us closer together.":{
@ -330,6 +363,7 @@
French:"Nos problèmes militaires communs nous ont rapprochés"
Simplified_Chinese:"共同的戎马岁月拉近了彼此的距离。"
Portuguese:"Nossas lutas mutuas nos fazem mais próximos."
Russian:"Наши совместные боевые действия сблизили нас"
}
"We have signed a public declaration of friendship":{
@ -337,6 +371,7 @@
Simplified_Chinese:"真是美好的一天!我们宣布:两个文明间将彼此尊重、相互友善!"
French:"Nous avons publiquement signé une Déclaration d'Amitié"
Portuguese:"Assinamos uma declaração pública de amizade"
Russian:"Мы подписали публичную декларацию дружбы"
}
"You have declared friendship with our enemies!":{
@ -344,12 +379,14 @@
French:"Vous avez signé une Déclaration d'Amitié avec nos ennemis!"
Simplified_Chinese:"渡尽劫波兄弟在,相逢一笑泯恩仇!我们宣布:冰释前嫌、携手前进!"
Portuguese:"Voçê declarou amizade a um de nossos inimigos!"
Russian:"Вы дружите с нашими врагами!"
}
"You have declared friendship with our allies":{
Italian:"Hai dichiarato un'amicizia con i nostri alleati."
French:"Vous avez signé une Déclaration d'Amitié avec nos alliés"
Simplified_Chinese:"兄弟齐心、其利断金!我们宣布:我们与盟友间兄弟般的友谊永世长存!"
Portuguese:"Voçê declarou amizade a um de nossos aliados"
Russian:"Вы дружите с нашими союзниками"
}
"Our open borders have brought us closer together.":{
@ -357,6 +394,7 @@
French:"Notre Accord de libre passage nous a rapprochés"
Simplified_Chinese:"开放的边界促进了彼此的了解,让我们的人民心心相通!"
Portuguese:"Nossa fronteiras abertas nos fizeram mais próximos."
Russian:"Наши открытые границы сблизили нас"
}
@ -364,64 +402,77 @@
Italian:"La tua cosiddetta 'amicizia' non vale nulla!"
Portuguese:"Sua chamada 'amizade' não vale nada."
French:"Votre soi-disant 'amitié' ne vaut rien."
Russian:"Ваше так называемое дружелюбие ничего не значит."
}
"You have publicly denounced us!":{
Italian:"Ci hai denunciato pubblicamente di fronte al mondo!"
French:"Vous nous avez dénoncé publiquement!"
Russian:"Вы публично осудили нас!"
}
"You have denounced our allies":{
Italian:"Hai denunciato i nostri alleati!"
French:"Vous avez dénoncé nos alliées"
Russian:"Вы осудили наших союзников!"
}
"You have denounced our enemies":{
Italian:"Hai denunciato i nostri nemici!"
French:"Vous avez dénoncé nos ennemies"
Russian:"Вы осудили наших врагов"
}
// Demands
"Demands":{
Italian:"Richieste"
French:"Demandes"
Russian:"Требования"
}
"Please don't settle new cities near us.":{
Italian:"Smetti di fondare città vicino a noi."
French:"Veuillez ne pas construire de villes proches de nous."
Russian:"Пожалуйста, не закладывайте новых городов рядом с нами."
}
"Very well, we shall look for new lands to settle.":{
Italian:"Ti porgiamo le nostre scuse."
French:"Très bien, nous chercherons d'autres terres à coloniser"
Russian:"Хорошо, мы найдем другие земли для поселений"
}
"We shall do as we please.":{
Italian:"Colonizzeremo la terra che ci pare e piace."
French:"Nous faisons ce que nous voulons."
Russian:"Мы поступим, как сочтем нужным"
}
"You betrayed your promise to not settle cities near us":{
Italian:"Hai tradito la tua promessa di non fondare città nelle nostre vicinanze."
French:"Vous avez trahis votre promesse de ne pas fonder de ville proche de nous"
Russian:"Вы нарушили ваше обещание не закладывать города рядом с нами"
}
"You fulfilled your promise to stop settling cities near us!":{
Italian:"Hai mantenuto la tua promessa di non fondare città nelle nostre vicinanze."
French:"Vous avez tenu votre promesse de ne pas fonder de ville proche de nous!"
Russian:"Вы выполнили ваше обещание не закладывать города рядом с нами"
}
"You refused to stop settling cities near us":{
Italian:"Hai continuato a fondare città nelle nostre vicinanze."
French:"Vous avez refusez de ne pas fonder de villes proches de nous"
Russian:"Вы отказались не закладывать города рядом с нами"
}
"We noticed your new city near our borders, despite your promise. This will have....implications.":{
Italian:"Abbiamo notato la la tua nuova città vicino ai nostri confini. E questo avrà... ripercussioni sui nostri rapporti."
French:"Nous avons remarquez votre nouvelle ville à notre frontière, malgré votre promesse. Cela aura des... conséquences."
Russian:"Мы заметили ваш новый город около наших границ. Это может повлечь... последствия."
}
"Your arrogant demands are in bad taste":{
Italian:"Hai fatto una richiesta arrogante."
French:"Vos arrogantes demandes sont de mauvais goût"
Russian:"Ваши высокомерные требования раздражают"
}
@ -432,24 +483,28 @@
Italian:"Acculturata"
French:"Cultivée"
Simplified_Chinese:"文化型"
Russian:"Культурный"
}
"Maritime":{
Italian:"Marittima"
French:"Maritime" //same
Simplified_Chinese:"航海型"
Russian:"Морской"
}
"Mercantile":{
Italian:"Mercantile"
//same in french
Simplified_Chinese:"商业型"
Russian:"Торговый"
}
"Militaristic":{
Italian:"Militaristica"
French:"Militarisée"
Simplified_Chinese:"军事型"
Russian:"Воинственный"
}
////// Trade
@ -478,6 +533,7 @@
"Retract offer":{
Italian:"Ritira offerta"
Russian:"Отменить предложение"
}
"What do you have in mind?":{
@ -504,7 +560,7 @@
"Our trade offer":{
Italian:"La nostra offerta"
Russian:"Наше предложение\n обмена"
Russian:"Наше предложение"
French:"Notre offre d'échange"
Romanian:"Oferta noastră"
Spanish:"Nuestra oferta"
@ -515,7 +571,7 @@
"[otherCiv]'s trade offer":{
Italian:"Offerta di [otherCiv]"
Russian:"Предложение обмена \n цивилизации [otherCiv]"
Russian:"Предложение от [otherCiv]"
French:"L'offre d'échange de [otherCiv]"
Romanian:"Ofertă de schimb a [otherCiv]"
Spanish:"Oferta de [otherCiv]"
@ -584,6 +640,7 @@
French:"Continuer..."
Simplified_Chinese:"继续..."
Portuguese:"Prossiga"
Russian:"Продолжить"
}
"There's nothing on the table":{
@ -613,6 +670,7 @@
Simplified_Chinese:"协定"
French:"Accords"
Portuguese:"Acordos"
Russian:"Соглашения"
}
"Open Borders":{
@ -620,6 +678,7 @@
Simplified_Chinese:"开放边境"
French:"Accord de libre passage"
Portuguese:"Acordo de fronteiras abertas"
Russian:"Открытые границы"
}
"Gold per turn":{
@ -651,6 +710,7 @@
French:"Technologies"
Simplified_Chinese:"科技"
Portuguese:"Tecnologias"
Russian:"Технологии"
}
"Declarations of war":{
@ -658,6 +718,7 @@
French:"Déclarations de guerre"
Simplified_Chinese:"宣战"
Portuguese:"Declarações de guerra"
Russian:"Объявления войны"
}
"Introduction to [nation]":{
@ -669,6 +730,7 @@
French:"Ressources de luxes"
Simplified_Chinese:"奢侈资源"
Portuguese:"Recursos raros/luxuosos" //raros = rare luxuosos = luxurious
Russian:"Редкие ресуры"
}
"Strategic resources":{
@ -676,6 +738,7 @@
French:"Ressources stratégiques"
Simplified_Chinese:"战略资源"
Portuguese:"Recursos estratégicos"
Russian:"Стратегические ресуры"
}
@ -698,11 +761,13 @@
Simplified_Chinese:"无需战略资源[resourceName]"
French:"[resourceName] non requis"
Portuguese:"[resourceName] não requirido"
Russian:"[resourceName] не требуется"
}
"Lost ability":{ // as in Does not have +1 Visibility Range (or any other unit unique)
Italian:"Non possiede "
Simplified_Chinese:"失去能力"
Russian:"Не имеет "
}
"National ability":{ // the unique ability that each nation has
@ -712,7 +777,7 @@
German:"Nationalfähigkeit"
French:"Capacité de la civilisation"
Portuguese:"Habilidade nacional"
Russian:"Национальная способность"
Russian:"Национальная особенность"
Simplified_Chinese:"民族特性"
}
@ -733,7 +798,7 @@
German:"Ein kostenloser Großer Wissenschaftler erscheint, wenn Schrift erforscht wurde; Große Wissenschaftler erscheinen 50% häufiger"
French:"Gagner un scientifique illustre lorsque Ecriture est dévouvert, les scientifiques illustres apparaissent 50% plus vite"
Portuguese:"Receba gratuitamente um grande cientista quando você descobrir Escritura, ganhe grandes cientistas 50% mais rápido"
Russian:"Получите бесплатно великого ученого, когда откроете для себя написание, заработайте великих ученых на 50% быстрее"
Russian:"Бесплатный Великий Ученый при исследовании Письменности. Великие Ученые появляются на 50% быстрее"
Simplified_Chinese:"发明文字后立即获得一个大科学家,大科学家点数积累速率+50%"
Spanish:"Reciba un Gran Científico gratis cuando descubra Escribir, Gane Grandes Científicos 50% más rápido"
}
@ -742,6 +807,7 @@
Italian:"Nabucodonosor II"
French:"Nabuchodonosor II"
Simplified_Chinese:"尼布甲尼撒二世"
Russian:"Навуходоносор II"
}
"Greece":{
@ -759,11 +825,13 @@
Italian:"Alessandro"
French:"Alexandre le Grand"
Simplified_Chinese:"亚历山大"
Russian:"Александр Македонский"
},
"City-State Influence degrades at half and recovers at twice the normal rate": {
Simplified_Chinese:"对城邦影响力衰减速度减半,恢复速度加倍"
Italian:"L'influenza sulle città-stato diminuisce il doppio più lentamente e aumenta il doppio più velocemente."
Russian:"Влияние на города-государства снижается вдвое медленнее и увеличивается вдвое быстрее"
},
"China":{
@ -779,6 +847,7 @@
"Wu Zetian":{
Simplified_Chinese:"武则天"
Russian:"У Цзэтянь"
},
"Great general provides double combat bonus, and spawns 50% faster":{
@ -790,6 +859,7 @@
Portuguese:"Grande general fornece bônus de combate duplo e é gerado 50% mais rápido"
Russian:"Великий полководец дает двойной боевой бонус и появляется на 50% быстрее"
Spanish:"El gran general proporciona bonificación de combate doble y genera un 50% más rápido."
Russian:"Великий Полководец дает двойной бонус в бою и появляется на 50% быстрее"
}
"Egypt":{
@ -807,6 +877,7 @@
Italian:"Ramses II"
French:"Ramsès II"
Simplified_Chinese:"拉美西斯二世"
Russian:"Рамзес II"
}
"+20% production towards Wonder construction":{
@ -835,6 +906,7 @@
Italian:"Elisabetta"
//same in french
Simplified_Chinese:"伊丽莎白"
Russian:"Елизавета"
}
"+2 movement for all naval units":{
@ -863,6 +935,7 @@
Italian:"Napoleone"
French:"Napoléon"
Simplified_Chinese:"拿破仑"
Russian:"Наполеон"
}
"+2 Culture per turn from cities before discovering Steam Power":{
@ -872,7 +945,7 @@
Spanish:"+2 Cultura por turno desde las ciudades antes de descubrir la Energía de Vapor."
Romanian:"+2 Cultură pe turn de la orașe înainte de a descoperi puterea de abur"
Portuguese:"+2 Cultura por turno das cidades antes de descobrir o poder do vapor" //'poder do vapor' means the power of steam
Russian:"+2 Культура за ход из городов, прежде чем открыть для себя силу пара"
Russian:"+2 Культура за ход от городов до открытия Парового Двигателя"
Simplified_Chinese:"在发明蒸汽机之前,每座城市的文化+2"
}
@ -891,6 +964,7 @@
Italian:"Caterina II"
French:"Catherine II"
Simplified_Chinese:"叶卡捷琳娜二世"
Russian:"Екатерина Великая"
}
"Strategic Resources provide +1 Production, and Horses, Iron and Uranium Resources provide double quantity":{
@ -901,7 +975,7 @@
German:"Strategische Ressourcen geben +1 Produktion und Pferde, Eisen und Uran Ressourcen geben die doppelte Menge"
French:"Les ressources stratégiques donnent +1 production, et les quantités de chevaux, fer et uranium sont doublés"
Portuguese:"Recursos Estratégicos fornecem Produção de +1, recursos de cavalos, ferro e urânio fornecem quantidade dupla"
Russian:"Стратегические ресурсы дают +1 к добыче, а ресурсы для лошадей, железа и урана дают двойное количество"
Russian:"Стратегические ресурсы дают +1 к производству, а количество ресуров Лошади, Железо и Уран удваивается"
}
"Rome":{
@ -919,6 +993,7 @@
Italian:"Cesare Augusto"
French:"Jule César"
Simplified_Chinese:"奥古斯都·恺撒"
Russian:"Октавиан Август"
}
"+25% Production towards any buildings that already exist in the Capital":{
@ -948,6 +1023,7 @@
Italian:"Harun al-Rashid" //Same as Italian
French:"Hâroun ar-Rachîd"
Simplified_Chinese:"哈伦·拉希德"
Russian:"Гарун-аль-Рашид"
}
"+1 Gold from each Trade Route, Oil resources provide double quantity":{
@ -955,6 +1031,7 @@
Simplified_Chinese:"每条贸易路线+1金钱石油储量加倍"
Portuguese:"1 ouro adicional de rotas comerciais e recursos de petróleo geram o dobro" // óleo could mean normal kitchen oil and even fuel from sugar cane
French:"+1 Or pour chaque route commerciale, la quantité de pétrole est doublée"
Russian:"+1 Золото от каждого торгового маршрута, количество ресурса Нефть удваивается"
}
"America":{
@ -972,6 +1049,7 @@
Italian:"George Washington" //Same as Italian
//same in french
Simplified_Chinese:"乔治·华盛顿"
Russian:"Джордж Вашингтон"
}
"All land military units have +1 sight, 50% discount when purchasing tiles":{
@ -982,7 +1060,7 @@
German:"Alle militärischen Landeinheiten haben +1 Sicht; 50% niedrigerer Preis beim Kauf von Feldern"
French:"Toutes les unités terrestres ont +1 porté de vision, les cases coutent 50% de leurs prix à l'achat"
Portuguese:"Todas as unidades militares terrestres ganham +1 alcançe devisão e 50% de desconto na compra de terrenos" //i don't remember my translations being this bad? who was the monster?
Russian:"Все наземные воинские части имеют +1 прицел, скидка 50% при покупке плитки"
Russian:"Все наземные военные юниты имеют +1 обзор, скидка 50% при покупке клетки"
}
"Japan":{
@ -1000,6 +1078,7 @@
Italian:"Oda Nobunaga" //Same as Italian
//same in french
Simplified_Chinese:"织田信长"
Russian:"Ода Нобунага"
}
"Units fight as though they were at full strength even when damaged":{
@ -1010,7 +1089,7 @@
German:"Einheiten kämpfen so, als wären sie selbst bei Beschädigung in voller Stärke"
French:"Les unités combattent comme si elles étaient à pleine force même lorsqu'elles sont endommagées"
Portuguese:"Unidades lutam como se estivessem em força total mesmo quando danificadas"
Russian:"Юниты сражаются, как будто они в полной силе, даже когда повреждены"
Russian:"Юниты сражаются в полную силу, даже будучи ранеными"
}
"Germany":{
@ -1018,18 +1097,21 @@
French:"Allemagne"
Simplified_Chinese:"德意志"
Portuguese:"Alemanha"
Russian:"Германия"
}
"Otto von Bismark":{
Italian:"Otto von Bismark" //Same as Italian
French:"Otto von Bismarck"
Simplified_Chinese:"奥托·冯·俾斯麦"
Russian:"Отто фон Бисмарк"
}
"67% chance to earn 25 Gold and recruit a Barbarian unit from a conquered encampment, -25% land units maintenance.":{
Italian:"67% di probabilità di ottenere 25 Oro e reclutare un'unità barbara da un accampamento catturato. -25% mantenimento delle unità terrestri."
French:"67% de chance de gagner 25 or et d'enroler une unité barbare lors de la prise d'un campement barbare. -25% de coût de maintenance pour les unités terrestres."
Simplified_Chinese:"击败蛮族营地中的蛮族单位有67%几率得到25金钱并使其加入陆上单位维护费-25%"
Russian:"Шанс 67% получить 25 Золото и варварский юнит из захваченного лагеря. -25% к стоимости содержания наземных юнитов.
}
"India":{
@ -1037,12 +1119,14 @@
French:"Inde"
Portuguese:"Índia"
Simplified_Chinese:"印度"
Russian:"Индия"
}
"Gandhi":{
Italian:"Gandhi" //Same as Italian
//same in french
Simplified_Chinese:"甘地"
Russian:"Махатма Ганди"
}
"Unhappiness from number of Cities doubled, Unhappiness from number of Citizens halved.":{
@ -1050,6 +1134,7 @@
Portuguese:"Tristeza por número de cidades dobrada e tristeza por número de cidadões reduzida pela metade"
French:"Le mécontentement dut au nombre de villes est doublé. Le mécontentement dut au nombre de citoyens est réduit de moitié"
Simplified_Chinese:"城市数量导致的不满加倍,市民数量导致的不满减半"
Russian:"Удвоенное недовольство от числа городов. Недовольство от количества горожан в два раза меньше."
}
"The Ottomans":{
@ -1057,12 +1142,14 @@
French:"Turquie"
Portuguese:"Turquia"
Simplified_Chinese:"奥斯曼"
Russian:"Турция"
}
"Suleiman I":{
Italian:"Solimano I"
French:"Soliman le Magnifique"
Simplified_Chinese:"苏莱曼一世"
Russian:"Сулейман I"
}
"Pay only one third the usual cost for naval unit maintenance. Melee naval units have a 1/3 chance to capture defeated naval units.":{
@ -1070,6 +1157,7 @@
Portuguese:"50% de chance de converter uma unidade naval bárbara para ti e ganhar 25 ouro. Gaste apenas 1/3 do custo normal para manter unidades navais."
French:"50% de chance de convertir une unité barbare navale et de gagner 25 Or. Les unités navales coutent 3 fois moins à entretenir."
Simplified_Chinese:"海上单位维护费为正常值的1/3海军近战单位拥有1/3几率俘获战败的敌方海军单位"
Russian:"Содержание морских юнитов стоит треть обычной цены. Морские юниты ближнего боя имеют 1/3 шанс захвата побеждённых кораблей."
}
"Korea":{
@ -1077,6 +1165,7 @@
French:"Corée"
Portuguese:"Coréia"
Simplified_Chinese:"朝鲜"
Russian:"Корея"
}
"Sejong":{
@ -1087,6 +1176,13 @@
Simplified_Chinese:"所有专业人员和所有伟人设施+2科研"
}
"+1 Science for all Specialists and Great Person tile improvements. Receive a tech boost each time a scientific building/Wonder is built in the Korean Capital.":{
Italian:"+1 Scienza per ogni Specialista e miglioramento Grande Personaggio. Ricevi uno sprint tecnologico ogni volta che la tua Capitale costruisce un edificio o una Meraviglia scientifica."
Portuguese:"+1 ciência por todas as melhorias de terras de especialístas e grandes pessoas. Receba um bonus de pesquisa a cada construção/maravilha ciêntifica é construida na capital"
French:"+1 Science pour chaque spécialistes et amélioration de case de personnage illustre. Reçoit un bonus de science à chaque fois qu'un batiment ou une merveille scientifique est construit dans la capitale"
Russian:"+1 Наука для всех специалистов и улучшений клеток Великими людьми. Получите бонус к исследованию каждый раз при создании научного здания/чуда в Корейской столице"
}
/*
"Iroquois":{
@ -1201,7 +1297,7 @@
German:"Unikate"
French:"Uniques"
Portuguese:"Únicos(a)"
Russian:"уникальный"
Russian:"Уникальные юниты"
}
"Promotions":{
@ -1212,7 +1308,7 @@
German:"Beförderungen"
French:"Promotions"
Portuguese:"Promoções"
Russian:"промо акции"
Russian:"Повышения"
}
"units in rough terrain":{

View file

@ -251,7 +251,7 @@
EnemyCity: [
[
"You have encoutered an enemy city!",
"You have encountered an enemy city!",
"Cities can be conquered by reducing their health to 1,",
" and entering the city with a melee unit.",
"Since cities heal each turn, it is best to attack with ranged units"

View file

@ -20,9 +20,9 @@ android {
defaultConfig {
applicationId "com.unciv.app"
minSdkVersion 14
targetSdkVersion 28
versionCode 293
versionName "3.0.0"
targetSdkVersion 29
versionCode 294
versionName "3.0.1"
}
// Had to add this crap for Travis to build, it wanted to sign the app

View file

@ -8,6 +8,7 @@ buildscript {
repositories {
// Chinese mirrors for quicker loading for chinese devs
maven{ url 'https://maven.aliyun.com/repository/jcenter'}
maven{ url 'https://maven.aliyun.com/repository/google'}
maven{ url 'https://maven.aliyun.com/repository/gradle-plugin'}
@ -40,6 +41,7 @@ allprojects {
}
repositories {
// Chinese mirrors for quicker loading for chinese devs
maven{ url 'https://maven.aliyun.com/repository/jcenter'}
maven{ url 'https://maven.aliyun.com/repository/google'}
maven{ url 'https://maven.aliyun.com/repository/gradle-plugin'}

View file

@ -87,7 +87,7 @@ class TileMap {
// Only once we add the unit to the civ we can activate addPromotion, because it will try to update civ viewable tiles
for(promotion in unit.baseUnit.promotions)
unit.promotions.addPromotion(promotion,true)
unit.promotions.addPromotion(promotion, true)
// And update civ stats, since the new unit changes both unit upkeep and resource consumption
civInfo.updateStatsForNextTurn()

View file

@ -15,7 +15,7 @@ class UnitPromotions{
fun xpForNextPromotion() = (numberOfPromotions+1)*10
fun canBePromoted() = XP >= xpForNextPromotion()
fun addPromotion(promotionName:String, isFree:Boolean = false, updateViewableTiles:Boolean=true){
fun addPromotion(promotionName: String, isFree: Boolean = false){
if (!isFree) {
XP -= xpForNextPromotion()
numberOfPromotions++
@ -29,7 +29,6 @@ class UnitPromotions{
// Since some units get promotions upon construction, they will get the addPromotion from the unit.postBuildEvent
// upon creation, BEFORE they are assigned to a tile, so the updateViewableTiles() would crash.
// So, if the addPromotion was triggered from there, simply don't update
// if(updateViewableTiles)
unit.updateViewableTiles() // some promotions/uniques give the unit bonus sight
}

View file

@ -29,7 +29,7 @@ class TileImprovement : NamedStats(), ICivilopedia {
override val description: String
get() {
val stringBuilder = StringBuilder()
if (!this.clone().toString().isEmpty()) stringBuilder.appendln(this.clone().toString())
if (this.clone().toString().isNotEmpty()) stringBuilder.appendln(this.clone().toString())
if (!terrainsCanBeBuiltOn.isEmpty()) {
val terrainsCanBeBuiltOnString:ArrayList<String> = arrayListOf()
for (i in terrainsCanBeBuiltOn) {

View file

@ -3,6 +3,7 @@ package com.unciv.ui.mapeditor
import com.badlogic.gdx.graphics.Color
import com.badlogic.gdx.scenes.scene2d.Actor
import com.badlogic.gdx.scenes.scene2d.Group
import com.badlogic.gdx.scenes.scene2d.ui.Label
import com.badlogic.gdx.scenes.scene2d.ui.ScrollPane
import com.badlogic.gdx.scenes.scene2d.ui.Table
import com.badlogic.gdx.scenes.scene2d.ui.TextButton
@ -68,7 +69,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
onClick {
clearSelection()
clearImprovement = true
setCurrentHex(ImageGetter.getCircle().apply { setSize(60f,60f) })
setCurrentHex(getHex(Color.WHITE), "Clear improvements")
}
}).row()
@ -78,7 +79,8 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
improvementImage.onClick {
clearSelection()
selectedImprovement=improvement
setCurrentHex(getHex(Color.WHITE,ImageGetter.getImprovementIcon(improvement.name,40f)))
val improvementIcon = getHex(Color.WHITE,ImageGetter.getImprovementIcon(improvement.name,40f))
setCurrentHex(improvementIcon, improvement.name+"\n"+improvement.clone().toString())
}
improvementsTable.add(improvementImage).row()
}
@ -90,7 +92,8 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
nationImage.onClick {
clearSelection()
selectedImprovement=TileImprovement().apply { name="StartingLocation "+nation.name }
setCurrentHex(getHex(Color.WHITE,ImageGetter.getNationIndicator(nation,40f)))
val nationIcon = getHex(Color.WHITE,ImageGetter.getNationIndicator(nation,40f))
setCurrentHex(nationIcon, nation.name+" starting location")
}
nationsTable.add(nationImage).row()
}
@ -106,7 +109,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
onClick {
clearSelection()
clearTerrainFeature = true
setCurrentHex(ImageGetter.getCircle().apply { setSize(60f,60f) })
setCurrentHex(getHex(Color.WHITE), "Clear terrain features")
}
})
@ -127,7 +130,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
group.onClick {
clearSelection()
selectedTerrain = terrain
setCurrentHex(tileInfo)
setCurrentHex(tileInfo,terrain.name+"\n"+terrain.clone().toString())
}
if (terrain.type == TerrainType.TerrainFeature)
@ -141,7 +144,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
onClick {
clearSelection()
clearResource = true
setCurrentHex(ImageGetter.getCircle().apply { setSize(60f,60f) })
setCurrentHex(getHex(Color.WHITE),"Clear resource")
}
})
@ -162,7 +165,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
tileInfo.resource = resource.name
tileInfo.setTransients()
setCurrentHex(tileInfo)
setCurrentHex(tileInfo,resource.name+"\n"+resource.clone().toString())
}
resources.add(resourceHex)
}
@ -178,7 +181,7 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
val terrainFeaturesTable = Table().apply { defaults().pad(20f) }
for(terrainFeature in terrainFeatures) terrainFeaturesTable.add(terrainFeature).row()
terrainFeaturesTable.pack()
terrainsAndResourcesTable.add(terrainFeaturesTable)
terrainsAndResourcesTable.add(ScrollPane(terrainFeaturesTable).apply { setScrollingDisabled(true,false) }).height(mapEditorScreen.stage.height*0.7f)
val resourcesTable = Table()
for(resource in resources) resourcesTable.add(resource).row()
@ -244,19 +247,23 @@ class TileEditorOptionsTable(val mapEditorScreen: MapEditorScreen): Table(Camera
}
fun setCurrentHex(tileInfo: TileInfo){
fun setCurrentHex(tileInfo: TileInfo, text:String){
val tileGroup = TileGroup(tileInfo,TileSetStrings())
.apply {
showEntireMap=true
forMapEditorIcon=true
update()
}
setCurrentHex(tileGroup)
setCurrentHex(tileGroup,text)
}
fun setCurrentHex(actor:Actor){
fun setCurrentHex(actor:Actor, text:String){
currentHex.remove()
currentHex=actor
val currentHexTable = Table()
currentHexTable.add(Label(text,skin)).padRight(20f)
currentHexTable.add(actor).pad(10f)
currentHexTable.pack()
currentHex=currentHexTable
currentHex.setPosition(stage.width-currentHex.width-10, 10f)
stage.addActor(currentHex)
}

View file

@ -1,5 +1,6 @@
package com.unciv.ui.newgamescreen
import com.badlogic.gdx.Gdx
import com.badlogic.gdx.graphics.Color
import com.badlogic.gdx.scenes.scene2d.Touchable
import com.badlogic.gdx.scenes.scene2d.ui.ScrollPane
@ -60,11 +61,12 @@ class PlayerPickerTable(val newGameScreen: NewGameScreen, val newGameParameters:
playerIdTable.add("Player ID:".toLabel())
val playerIdTextfield = TextField(player.playerId, CameraStageBaseScreen.skin)
playerIdTable.add(playerIdTextfield)
playerIdTable.add(playerIdTextfield).colspan(2)
val errorLabel = "Not a valid user id!".toLabel().setFontColor(Color.RED)
errorLabel.isVisible=false
playerIdTable.add(errorLabel)
playerIdTextfield.addListener {
fun onPlayerIdTextUpdated(){
try {
val uuid = UUID.fromString(playerIdTextfield.text)
player.playerId = playerIdTextfield.text
@ -72,19 +74,27 @@ class PlayerPickerTable(val newGameScreen: NewGameScreen, val newGameParameters:
} catch (ex: Exception) {
errorLabel.isVisible=true
}
true
}
playerIdTextfield.addListener { onPlayerIdTextUpdated(); true }
playerIdTable.row()
val currentUserId = UnCivGame.Current.settings.userId
val setCurrentUserButton = TextButton("Set current user", CameraStageBaseScreen.skin)
val setCurrentUserButton = TextButton("Set current user".tr(), CameraStageBaseScreen.skin)
setCurrentUserButton.onClick {
playerIdTextfield.text = currentUserId
errorLabel.isVisible = false
onPlayerIdTextUpdated()
}
playerIdTable.add(setCurrentUserButton)
val copyFromClipboardButton = TextButton("Player ID from clipboard",CameraStageBaseScreen.skin)
copyFromClipboardButton.onClick {
playerIdTextfield.text = Gdx.app.clipboard.contents
onPlayerIdTextUpdated()
}
playerIdTable.add(copyFromClipboardButton).pad(5f)
playerTable.add(playerIdTable).colspan(playerTable.columns)
}

View file

@ -23,7 +23,7 @@ import com.unciv.ui.utils.*
import com.unciv.ui.worldscreen.optionstable.YesNoPopupTable
import kotlin.math.roundToInt
class DiplomacyScreen:CameraStageBaseScreen() {
class DiplomacyScreen(val viewingCiv:CivilizationInfo):CameraStageBaseScreen() {
val leftSideTable = Table().apply { defaults().pad(10f) }
val rightSideTable = Table()
@ -53,15 +53,14 @@ class DiplomacyScreen:CameraStageBaseScreen() {
private fun updateLeftSideTable() {
leftSideTable.clear()
val currentPlayerCiv = UnCivGame.Current.gameInfo.getCurrentPlayerCivilization()
for (civ in UnCivGame.Current.gameInfo.civilizations
.filterNot { it.isDefeated() || it == currentPlayerCiv || it.isBarbarian() }) {
if (!currentPlayerCiv.knows(civ)) continue
.filterNot { it.isDefeated() || it == viewingCiv || it.isBarbarian() }) {
if (!viewingCiv.knows(civ)) continue
val civIndicator = ImageGetter.getNationIndicator(civ.nation,100f)
val relationship = ImageGetter.getCircle()
if(currentPlayerCiv.isAtWarWith(civ)) relationship.color = Color.RED
if(viewingCiv.isAtWarWith(civ)) relationship.color = Color.RED
else relationship.color = Color.GREEN
relationship.setSize(30f,30f)
civIndicator.addActor(relationship)
@ -90,8 +89,7 @@ class DiplomacyScreen:CameraStageBaseScreen() {
private fun getCityStateDiplomacyTable(otherCiv: CivilizationInfo): Table {
val currentPlayerCiv = UnCivGame.Current.gameInfo.getCurrentPlayerCivilization()
val otherCivDiplomacyManager = otherCiv.getDiplomacyManager(currentPlayerCiv)
val otherCivDiplomacyManager = otherCiv.getDiplomacyManager(viewingCiv)
val diplomacyTable = Table()
diplomacyTable.defaults().pad(10f)
@ -102,7 +100,7 @@ class DiplomacyScreen:CameraStageBaseScreen() {
diplomacyTable.add(getRelationshipTable(otherCivDiplomacyManager)).row()
val friendBonusText = when (otherCiv.getCityStateType()) {
CityStateType.Cultured -> "Provides [" + (3 * (currentPlayerCiv.getEra().ordinal + 1)).toString() + "] culture at [30] Influence"
CityStateType.Cultured -> "Provides [" + (3 * (viewingCiv.getEra().ordinal + 1)).toString() + "] culture at [30] Influence"
CityStateType.Maritime -> "Provides 3 food in capital and 1 food in other cities at [30] Influence"
CityStateType.Mercantile -> "Provides 3 happiness at [30] Influence"
CityStateType.Militaristic -> "Provides land units every 20 turns at [30] Influence"
@ -124,19 +122,19 @@ class DiplomacyScreen:CameraStageBaseScreen() {
val influenceAmount = giftAmount / 10
val giftButton = TextButton("Gift [$giftAmount] gold (+[$influenceAmount] influence)".tr(), skin)
giftButton.onClick {
currentPlayerCiv.giveGoldGift(otherCiv, giftAmount)
viewingCiv.giveGoldGift(otherCiv, giftAmount)
updateRightSide(otherCiv)
}
diplomacyTable.add(giftButton).row()
if (currentPlayerCiv.gold < giftAmount || isNotPlayersTurn()) giftButton.disable()
if (viewingCiv.gold < giftAmount || isNotPlayersTurn()) giftButton.disable()
val diplomacyManager = currentPlayerCiv.getDiplomacyManager(otherCiv)
val diplomacyManager = viewingCiv.getDiplomacyManager(otherCiv)
if (currentPlayerCiv.isAtWarWith(otherCiv)) {
if (viewingCiv.isAtWarWith(otherCiv)) {
val peaceButton = TextButton("Negotiate Peace".tr(), skin)
peaceButton.onClick {
YesNoPopupTable("Peace with [${otherCiv.civName}]?".tr(), {
val tradeLogic = TradeLogic(currentPlayerCiv, otherCiv)
val tradeLogic = TradeLogic(viewingCiv, otherCiv)
tradeLogic.currentTrade.ourOffers.add(TradeOffer(Constants.peaceTreaty, TradeType.Treaty, 30))
tradeLogic.currentTrade.theirOffers.add(TradeOffer(Constants.peaceTreaty, TradeType.Treaty, 30))
tradeLogic.acceptTrade()
@ -155,8 +153,7 @@ class DiplomacyScreen:CameraStageBaseScreen() {
}
private fun getMajorCivDiplomacyTable(otherCiv: CivilizationInfo): Table {
val currentPlayerCiv = UnCivGame.Current.gameInfo.getCurrentPlayerCivilization()
val otherCivDiplomacyManager = otherCiv.getDiplomacyManager(currentPlayerCiv)
val otherCivDiplomacyManager = otherCiv.getDiplomacyManager(viewingCiv)
val diplomacyTable = Table()
diplomacyTable.defaults().pad(10f)
@ -169,7 +166,7 @@ class DiplomacyScreen:CameraStageBaseScreen() {
diplomacyTable.add(translatedNation.neutralHello.toLabel()).row()
diplomacyTable.addSeparator()
if(!currentPlayerCiv.isAtWarWith(otherCiv)) {
if(!viewingCiv.isAtWarWith(otherCiv)) {
val tradeButton = TextButton("Trade".tr(), skin)
tradeButton.onClick { setTrade(otherCiv) }
diplomacyTable.add(tradeButton).row()
@ -190,11 +187,11 @@ class DiplomacyScreen:CameraStageBaseScreen() {
diplomacyTable.add(negotiatePeaceButton).row()
}
val diplomacyManager = currentPlayerCiv.getDiplomacyManager(otherCiv)
val diplomacyManager = viewingCiv.getDiplomacyManager(otherCiv)
if (!currentPlayerCiv.isAtWarWith(otherCiv)) {
if (!viewingCiv.isAtWarWith(otherCiv)) {
if(otherCivDiplomacyManager.relationshipLevel() > RelationshipLevel.Neutral
&& !diplomacyManager.hasFlag(DiplomacyFlags.DeclarationOfFriendship)
&& !diplomacyManager.hasFlag(DiplomacyFlags.Denunceation)){
@ -226,7 +223,7 @@ class DiplomacyScreen:CameraStageBaseScreen() {
val demandsButton = TextButton("Demands".tr(),skin)
demandsButton.onClick {
rightSideTable.clear()
rightSideTable.add(getDemandsTable(currentPlayerCiv,otherCiv))
rightSideTable.add(getDemandsTable(viewingCiv,otherCiv))
}
diplomacyTable.add(demandsButton).row()
if(isNotPlayersTurn()) demandsButton.disable()
@ -270,15 +267,15 @@ class DiplomacyScreen:CameraStageBaseScreen() {
return diplomacyModifiersTable
}
private fun getDemandsTable(currentPlayerCiv: CivilizationInfo, otherCiv: CivilizationInfo): Table {
private fun getDemandsTable(viewingCiv: CivilizationInfo, otherCiv: CivilizationInfo): Table {
val demandsTable = Table()
demandsTable.defaults().pad(10f)
val dontSettleCitiesButton = TextButton("Please don't settle new cities near us.".tr(),skin)
if(otherCiv.popupAlerts.any { it.type==AlertType.DemandToStopSettlingCitiesNear && it.value==currentPlayerCiv.civName })
if(otherCiv.popupAlerts.any { it.type==AlertType.DemandToStopSettlingCitiesNear && it.value==viewingCiv.civName })
dontSettleCitiesButton.disable()
dontSettleCitiesButton.onClick {
otherCiv.popupAlerts.add(PopupAlert(AlertType.DemandToStopSettlingCitiesNear, currentPlayerCiv.civName))
otherCiv.popupAlerts.add(PopupAlert(AlertType.DemandToStopSettlingCitiesNear, viewingCiv.civName))
dontSettleCitiesButton.disable()
}
demandsTable.add(dontSettleCitiesButton).row()

View file

@ -15,8 +15,8 @@ import kotlin.math.max
class TradePopup(worldScreen: WorldScreen): PopupTable(worldScreen){
init{
val currentPlayerCiv = worldScreen.viewingCiv
val tradeRequest = currentPlayerCiv.tradeRequests.first()
val viewingCiv = worldScreen.viewingCiv
val tradeRequest = viewingCiv.tradeRequests.first()
val requestingCiv = worldScreen.gameInfo.getCivilization(tradeRequest.requestingCiv)
val translatedNation = requestingCiv.getTranslatedNation()
@ -39,10 +39,10 @@ class TradePopup(worldScreen: WorldScreen): PopupTable(worldScreen){
addGoodSizedLabel(translatedNation.tradeRequest).colspan(columns).row()
addButton("Sounds good!"){
val tradeLogic = TradeLogic(currentPlayerCiv, requestingCiv)
val tradeLogic = TradeLogic(viewingCiv, requestingCiv)
tradeLogic.currentTrade.set(trade)
tradeLogic.acceptTrade()
currentPlayerCiv.tradeRequests.remove(tradeRequest)
viewingCiv.tradeRequests.remove(tradeRequest)
close()
PopupTable(worldScreen).apply {
add(otherCivLeaderName.toLabel()).colspan(2)
@ -56,12 +56,12 @@ class TradePopup(worldScreen: WorldScreen): PopupTable(worldScreen){
}
open()
}
requestingCiv.addNotification("[${currentPlayerCiv.civName}] has accepted your trade request", Color.GOLD)
requestingCiv.addNotification("[${viewingCiv.civName}] has accepted your trade request", Color.GOLD)
}
addButton("Not this time.".tr()){
currentPlayerCiv.tradeRequests.remove(tradeRequest)
viewingCiv.tradeRequests.remove(tradeRequest)
val diplomacyManager = requestingCiv.getDiplomacyManager(currentPlayerCiv)
val diplomacyManager = requestingCiv.getDiplomacyManager(viewingCiv)
if(trade.ourOffers.all { it.type==TradeType.Luxury_Resource } && trade.theirOffers.all { it.type==TradeType.Luxury_Resource })
diplomacyManager.setFlag(DiplomacyFlags.DeclinedLuxExchange,20) // offer again in 20 turns
@ -69,15 +69,15 @@ class TradePopup(worldScreen: WorldScreen): PopupTable(worldScreen){
diplomacyManager.setFlag(DiplomacyFlags.DeclinedPeace,5)
close()
requestingCiv.addNotification("[${currentPlayerCiv.civName}] has denied your trade request", Color.GOLD)
requestingCiv.addNotification("[${viewingCiv.civName}] has denied your trade request", Color.GOLD)
worldScreen.shouldUpdate=true
}
addButton("How about something else...".tr()){
currentPlayerCiv.tradeRequests.remove(tradeRequest)
viewingCiv.tradeRequests.remove(tradeRequest)
close()
val diplomacyScreen= DiplomacyScreen()
val diplomacyScreen= DiplomacyScreen(viewingCiv)
val tradeTable = diplomacyScreen.setTrade(requestingCiv)
tradeTable.tradeLogic.currentTrade.set(trade)
tradeTable.offerColumnsTable.update()

View file

@ -231,7 +231,7 @@ class WorldScreen(val viewingCiv:CivilizationInfo) : CameraStageBaseScreen() {
.any()) {
displayTutorials("OtherCivEncountered")
val btn = TextButton("Diplomacy".tr(), skin)
btn.onClick { UnCivGame.Current.screen = DiplomacyScreen() }
btn.onClick { UnCivGame.Current.screen = DiplomacyScreen(viewingCiv) }
btn.label.setFontSize(30)
btn.labelCell.pad(10f)
diplomacyButtonWrapper.add(btn)

View file

@ -96,9 +96,9 @@ class WorldScreenMenuTable(val worldScreen: WorldScreen) : PopupTable(worldScree
val badGameIdLabel = "".toLabel().setFontColor(Color.RED)
badGameIdLabel.isVisible = false
multiplayerPopup.addButton("Join Game") {
val gameId = Gdx.app.clipboard.contents.trim()
val gameId = Gdx.app.clipboard.contents
try {
UUID.fromString(gameId)
UUID.fromString(gameId.trim())
} catch (ex: Exception) {
badGameIdLabel.setText("Invalid game ID!")
badGameIdLabel.isVisible = true

View file

@ -96,7 +96,7 @@ class UnitActions {
for(promotion in unit.baseUnit.promotions)
if(promotion !in newunit.promotions.promotions)
newunit.promotions.addPromotion(promotion,true)
newunit.promotions.addPromotion(promotion, true)
newunit.updateUniques()
newunit.updateViewableTiles()