diff --git a/Assemblies/MoreFactionInteraction.dll b/Assemblies/MoreFactionInteraction.dll index 7ec5784..0a092ff 100644 Binary files a/Assemblies/MoreFactionInteraction.dll and b/Assemblies/MoreFactionInteraction.dll differ diff --git a/Defs/RuleDefs/SymbolResolver_Rules_BasePart_Outdoors.xml b/Defs/RuleDefs/SymbolResolver_Rules_BasePart_Outdoors.xml index 6bd62c8..63b4292 100644 --- a/Defs/RuleDefs/SymbolResolver_Rules_BasePart_Outdoors.xml +++ b/Defs/RuleDefs/SymbolResolver_Rules_BasePart_Outdoors.xml @@ -72,6 +72,9 @@
  • 0.01
  • +
  • 0.65
  • diff --git a/Defs/Sites/Parts/MigratoryHerd.xml b/Defs/Sites/Parts/MigratoryHerd.xml index 5930b71..bf90816 100644 --- a/Defs/Sites/Parts/MigratoryHerd.xml +++ b/Defs/Sites/Parts/MigratoryHerd.xml @@ -33,7 +33,7 @@ MFI_HuntersLodgePart 451 - false + true diff --git a/Languages/English/Keyed/Incidents.xml b/Languages/English/Keyed/Incidents.xml index bc7e69b..e45da61 100644 --- a/Languages/English/Keyed/Incidents.xml +++ b/Languages/English/Keyed/Incidents.xml @@ -16,7 +16,7 @@ Help wanted A nearby settlement, {0}, contacts you with a special request. Their fields have yielded far more than originally expected, and they could really use your help with the harvest.\n\nThis request expires after: {1}\n\nIf you want to help them, send a caravan with capable growers. You can review this offer by selecting {0} on the world map. - Offer your help in harvesting? {0} will spend some time here. + Offer your help in harvesting? {0} will temporarily be unable to move while harvesting takes place. No conscious, capable grower. Requesting help with harvesting. ({0} left) Help harvest @@ -32,7 +32,7 @@ Someone who claims to be a representative of {0} contacts us with a tall tale of a mystical shaman who has mastered the "healer's hand" to cure any injury or missing part. They'll tell us the location of this mysterious and normally reclusive person for a small fee of {1} silver. Mystical Shaman - The Shaman emerges from his polyester teepee just before your caravan announces their presence. He judges you silently with one crossed eye that penetrates through each of your caravan members deepest vitae and one eye that quivers more and more as he assesses your groups health. He orders you to wait a respectable distance while he retreats back in his teepee. Moments later you hear the rustling of fabric and the sound of a muffalo being spurred on.\n\nIt seems the mystical shaman packed up and left. - The Shaman seems to have been expecting you, and with great practice regales you the tale of his "healer's hands". When he's down he invites {0} in to his teepee. There is a brief shake of the screen before {0} re-emerges, feeling much better. + The Shaman emerges from his polyester teepee just before your caravan announces their presence. He judges your group silently, passing one quivering eye over your decidedly healthy group, the other eye crossed in apparent meditation. Visibly sweating, he orders you to wait a respectable distance while he retreats back in his teepee. Moments later you hear the rustling of fabric and the sound of a muffalo being spurred on.\n\nIt seems the mystical shaman packed up and left. + The Shaman seems to have been expecting you, and with great practice regales you the tale of his "healer's hands". Once finished, he invites {0} into his teepee. There is a brief shake of the screen before {0} re-emerges, feeling much better. \ No newline at end of file diff --git a/Languages/English/Keyed/Keys.xml b/Languages/English/Keyed/Keys.xml index 7b4bd5e..1beb2f1 100644 --- a/Languages/English/Keyed/Keys.xml +++ b/Languages/English/Keyed/Keys.xml @@ -4,15 +4,15 @@ Time until pirates upgrade their outposts to bases Time modifier between faction interaction - Modifier to silver brought by traders (scales with interaction-frequency) + Modifier to silver brought by traders (scales with interaction frequency) Bandit outpost upgraded - Pirates from {0} have upgraded a nearby outpost of theirs to a base!\n\nThey'll sent out occasional raiding parties to test your defences, and to settle new outposts that may become bases. + Pirates from {0} have upgraded a nearby outpost to a base!\n\nThey'll sent out occasional raiding parties to test your defences, and to settle new outposts that may become bases. Desperate trader {0} thanks you. Their trade caravan will arrive in about {1}. trader - Caravan is working. + Caravan can't move during harvesting work. The two opposing faction leaders {0} and {1} each made quarters in opposite corners of the make-shift camp. Tensions are high as your negotiator {2} walks in. The past few days have been taxing on all parties involved, and your negotiator knows that what they'll say can have far reaching consequences.\n\n{2} has the following options: @@ -21,25 +21,25 @@ Broker peace between the two factions - The talks were a disaster. Neither faction appreciated your negotiator's attempt to butter up {0} and efforts to seek out a victor in the strife were considered an act of aggression and the peace talks broke down as a result.\n\nRelations with {0} have deteriorated somewhat.\n\nRelations with {1} have deteriorated massively. - The talks have backfired. While faction delegates discussed key differences, dissuasions your negotiator made were seen as unconstructive towards the goals and the talks soon devolved.\n\nRelations with {0} deteriorated.\n\nRelations with {1} have deteriorated massively. - The talks floundered. As faction delegates communicated clearly on their most important issues, your negotiator was not able to make any meaningful contributions to the peace talks.\n\nRelations with {0} have increased somewhat.\n\nRelations with {1} deteriorated considerably. - The talks were a success. Delegates of both factions hammered out a basic treaty, and your negotiator managed to sway the talks and convince {1} to make amends with {0}.\n\nRelations with {0} increased considerably.\n\nRelations with {1} deteriorated somewhat. + The talks were a disaster. Neither faction appreciated your negotiator's attempt to butter up {0}. Efforts to seek out a victor in the strife were considered an act of aggression and the peace talks broke down as a result.\n\nRelations with {0} have deteriorated somewhat.\n\nRelations with {1} have deteriorated massively. + The talks have backfired. While faction delegates discussed key differences, dissuasions your negotiator made were seen as unconstructive towards the goals and the talks soon broke down.\n\nRelations with {0} deteriorated.\n\nRelations with {1} have deteriorated massively. + The talks floundered. Faction delegates expressed their key issues clearly, but your negotiator was not able to make any meaningful contributions to the peace talks.\n\nRelations with {0} have increased somewhat.\n\nRelations with {1} deteriorated considerably. + The talks were a success. Your negotiator managed to convince {1} to make amends with {0}, and their delegates hammered out a basic treaty.\n\nRelations with {0} increased considerably.\n\nRelations with {1} deteriorated somewhat. The talks were a great triumph! Your negotiator played a large role in convincing {1} to pay reparations for past aggressions, much to the delight of {0}.\n\nRelations with {0} increased massively.\n\nRelations with {1} deteriorated. - The sabotage was a massive failure. The delegates quickly uncovered your negotiator's intent to sabotage and both factions turned against you! As your caravan made a hurried departure, warriors from both factions caught up with it and attacked!\n\nRelations with {0} have broken down. They are now hostile towards you.\n\nRelations with {1} have broken down. They are now hostile towards you. - The sabotage has backfired. As delegates exchanged pleasantries and subsequently got down to business, they soon realised the unconstructive nature of your negotiator and excluded them from the talks.\n\nRelations with {0} deteriorated massively.\n\nRelations with {1} deteriorated massively. - The sabotage floundered. Your negotiator proved unable to get a word in edge-wise or provide meaningful contributions to the peace talks one way or the other.\n\nRelations with {0} and {1} remain unchanged. - The sabotage was a dubious success. While delegates bickered over important issues, your negotiator navigated the political minefield and left an amicable impression on both factions while ensuring no actual progress was made.\n\nRelations with {0} increased considerably.\n\nRelations with {1} increased considerably. - The sabotage was a great triumph of sorts! Delegates of both factions were expertly played out against one another, and not long after the initial greetings the discussion broke down into insults and recriminations while both aggressors were left with a very favourable impression of your faction.\n\nRelations with {0} have increased immensely.\n\nRelations with {1} have increased immensely. + The sabotage was a massive failure. The delegates quickly uncovered your negotiator's intent and both factions turned against you! Your caravan made a hurried departure, but warriors from both factions caught up with it and attacked!\n\nRelations with {0} have broken down. They are now hostile towards you.\n\nRelations with {1} have broken down. They are now hostile towards you. + The sabotage has backfired. Not long after delegates exchanged pleasantries, they caught on to the unconstructive nature of your negotiator and excluded them from the talks.\n\nRelations with {0} deteriorated massively.\n\nRelations with {1} deteriorated massively. + The sabotage floundered. Your negotiator proved unable to get a word in or provide meaningful contributions to the peace talks one way or the other.\n\nRelations with {0} and {1} remain unchanged. + The sabotage was a dubious success. While delegates bickered over important issues, your negotiator navigated the political minefield and left an amicable impression on both factions while ensuring no actual progress was made.\n\nRelations with {0} increased considerably.\n\nRelations with {1} increased considerably. + The sabotage was a great triumph of sorts! Delegates were expertly played out against one another, and not long after the initial greetings, the discussion broke down into insults and recriminations while both aggressors were left with a very favourable impression of your faction.\n\nRelations with {0} have increased immensely.\n\nRelations with {1} have increased immensely. The talks were a disaster. The delegates barely got past their initial greetings before the discussion broke down into insults and recriminations. Nothing your negotiator said was met with any approval, and relations with both opposing factions are worse than before.\n\nRelations with {0} deteriorated.\n\nRelations with {1} deteriorated. The talks have backfired. Despite exchanging some pleasantries, the delegates made no progress on substantive issues, and multiple statements were interpreted as insults. They've decided to resume and reschedule the peace talks for a later date.\n\nRelations with {0} remain unchanged.\n\nRelations with {1} remain unchanged. The talks floundered. Delegates managed to communicate clearly and with basic respect, but were not able to make progress on any genuine issues until your negotiator arrived. They played a large part in assuaging fears and smoothing over ruffled feathers.\n\nRelations with {0} have increased somewhat.\n\nRelations with {1} have increased somewhat. - The talks were a success. Thanks in no small part to your negotiator, delegates reached new mutual understanding on several substantial issues.\n\nRelations with {0} have increased considerably.\n\nRelations with {1} have increased considerably. - The talks were a great triumph! Your negotiator quickly connected the delegates and paved the way to truly see each others' perspective on the most difficult issues of the day.\n\nRelations with {0} have increased immensely.\n\nRelations with {1} have increased immensely. + The talks were a success. Thanks in no small part to your negotiator, delegates reached new mutual understanding on several substantial issues.\n\nRelations with {0} have increased considerably.\n\nRelations with {1} have increased considerably. + The talks were a great triumph! Your negotiator quickly connected the delegates and paved the way to truly see each others' perspective on the most difficult issues of the day.\n\nRelations with {0} have increased immensely.\n\nRelations with {1} have increased immensely. Faction war progress Faction unrest is brewing diff --git a/MoreFactionInteraction/General/HarmonyPatches.cs b/MoreFactionInteraction/General/HarmonyPatches.cs index d9aa179..c5d0119 100644 --- a/MoreFactionInteraction/General/HarmonyPatches.cs +++ b/MoreFactionInteraction/General/HarmonyPatches.cs @@ -42,8 +42,8 @@ static HarmonyPatches() postfix: new HarmonyMethod(type: typeof(HarmonyPatches), name: nameof(WorldReachUtility_PostFix))); #endregion - harmony.Patch(original: AccessTools.Method(type: typeof(DebugWindowsOpener), name: "ToggleDebugActionsMenu"), prefix: null, postfix: null, - transpiler: new HarmonyMethod(type: typeof(HarmonyPatches), name: nameof(DebugWindowsOpener_ToggleDebugActionsMenu_Patch))); + //harmony.Patch(original: AccessTools.Method(type: typeof(DebugWindowsOpener), name: "ToggleDebugActionsMenu"), prefix: null, postfix: null, + // transpiler: new HarmonyMethod(type: typeof(HarmonyPatches), name: nameof(DebugWindowsOpener_ToggleDebugActionsMenu_Patch))); harmony.Patch(original: AccessTools.Method(type: typeof(Tradeable), name: "InitPriceDataIfNeeded"), prefix: null, postfix: null, transpiler: new HarmonyMethod(type: typeof(HarmonyPatches), name: nameof(ErrorSuppressionSssh))); @@ -65,13 +65,13 @@ private static IEnumerable ErrorSuppressionSssh(IEnumerable DebugWindowsOpener_ToggleDebugActionsMenu_Patch(IEnumerable instructions) - { - ConstructorInfo from = AccessTools.Constructor(type: typeof(Dialog_DebugActionsMenu)); - ConstructorInfo to = AccessTools.Constructor(type: typeof(Dialog_MFIDebugActionMenu)); - return instructions.MethodReplacer(from: from, to: to); - } + ////thx Brrainz + //private static IEnumerable DebugWindowsOpener_ToggleDebugActionsMenu_Patch(IEnumerable instructions) + //{ + // ConstructorInfo from = AccessTools.Constructor(type: typeof(Dialog_DebugActionsMenu)); + // ConstructorInfo to = AccessTools.Constructor(type: typeof(Dialog_MFIDebugActionMenu)); + // return instructions.MethodReplacer(from: from, to: to); + //} #region MoreTraders private static void TraderStocker_OverStockerPostFix(ref List __result, ref ThingSetMakerParams parms) diff --git a/MoreFactionInteraction/More Flavour/IncidentWorker_DiplomaticMarriage.cs b/MoreFactionInteraction/More Flavour/IncidentWorker_DiplomaticMarriage.cs index f09e276..e975378 100644 --- a/MoreFactionInteraction/More Flavour/IncidentWorker_DiplomaticMarriage.cs +++ b/MoreFactionInteraction/More Flavour/IncidentWorker_DiplomaticMarriage.cs @@ -51,6 +51,7 @@ protected override bool TryExecuteWorker(IncidentParms parms) } private bool TryFindBetrothed(out Pawn betrothed) => (from potentialPartners in PawnsFinder.AllMapsCaravansAndTravelingTransportPods_Alive_FreeColonistsAndPrisoners_NoCryptosleep + // where !LovePartnerRelationUtility.HasAnyLovePartner(potentialPartners) || LovePartnerRelationUtility.ExistingMostLikedLovePartner(potentialPartners, false) == this.marriageSeeker //to consider: Y/N ? select potentialPartners).TryRandomElementByWeight(weightSelector: (Pawn marriageSeeker2) => this.marriageSeeker.relations.SecondaryLovinChanceFactor(otherPawn: marriageSeeker2), result: out betrothed); private static bool TryFindMarriageSeeker(out Pawn marriageSeeker) => (from x in Find.WorldPawns.AllPawnsAlive diff --git a/MoreFactionInteraction/More Flavour/MysticalShaman.cs b/MoreFactionInteraction/More Flavour/MysticalShaman.cs index 943991b..95c6159 100644 --- a/MoreFactionInteraction/More Flavour/MysticalShaman.cs +++ b/MoreFactionInteraction/More Flavour/MysticalShaman.cs @@ -62,7 +62,11 @@ internal class WorstCaravanPawnUtility public static Pawn FindSickestPawn(Caravan caravan) { tempPawns.Clear(); - foreach (Pawn pawn in caravan.PawnsListForReading) tempPawns.Add(key: pawn, value: CalcHealthThreatenedScore(usedBy: pawn)); + //Muffalo 1 deserves a chance to get healed too. + foreach (Pawn pawn in caravan.PawnsListForReading) + tempPawns.Add(key: pawn, + value: CalcHealthThreatenedScore(usedBy: pawn) / ( pawn.RaceProps.Humanlike ? 1 : 2 )); + tempPawns.RemoveAll(predicate: x => x.Value == 0); return tempPawns.FirstOrDefault(predicate: x => x.Value.Equals(obj: tempPawns.Values.Max())).Key; } diff --git a/MoreFactionInteraction/More Traders/MapComponent_GoodWillTraders.cs b/MoreFactionInteraction/More Traders/MapComponent_GoodWillTraders.cs index 6ee4d38..64dd1c2 100644 --- a/MoreFactionInteraction/More Traders/MapComponent_GoodWillTraders.cs +++ b/MoreFactionInteraction/More Traders/MapComponent_GoodWillTraders.cs @@ -55,7 +55,7 @@ public Dictionary NextFactionInteraction } //if a faction became hostile, remove //TODO: remove priorly scheduled incidents involving said faction - //nextFactionInteraction.RemoveAll(x => x.Key.HostileTo(Faction.OfPlayerSilentFail)); + nextFactionInteraction.RemoveAll(x => x.Key.HostileTo(Faction.OfPlayerSilentFail)); //and the opposite while ((from faction in Find.FactionManager.AllFactionsVisible @@ -90,7 +90,7 @@ public override void MapComponentTick() incidentParms.forced = true; //trigger incident somewhere between half a day and 3 days from now - Find.Storyteller.incidentQueue.Add(def: IncidentDef(), + Find.Storyteller.incidentQueue.Add(def: IncomingIncidentDef(), fireTick: Find.TickManager.TicksGame + Rand.Range(min: GenDate.TicksPerDay / 2, max: GenDate.TicksPerDay * 3), parms: incidentParms); @@ -106,27 +106,30 @@ public override void MapComponentTick() } } - private static IncidentDef IncidentDef() + private static IncidentDef IncomingIncidentDef() { switch (Rand.RangeInclusive(min: 0, max: 50)) { case int n when n <= 6: return MFI_DefOf.MFI_QuestSpreadingPirateCamp; - case int n when n <= 10: + case int n when n <= 8: + return MFI_DefOf.MFI_DiplomaticMarriage; + + case int n when n <= 17: return MFI_DefOf.MFI_ReverseTradeRequest; - case int n when n <= 20: + case int n when n <= 25: return MFI_DefOf.MFI_BumperCropRequest; - case int n when n <= 24: + case int n when n <= 29: return MFI_DefOf.MFI_HuntersLodge; - case int n when n <= 26: - return MFI_DefOf.MFI_DiplomaticMarriage; + case int n when n <= 31: + return IncidentDef.Named("MFI_MysticalShaman"); - case int n when n <= 30: - return RimWorld.IncidentDef.Named("Quest_ItemStash"); + case int n when n <= 35: + return IncidentDef.Named("Quest_ItemStash"); case int n when n <= 40: return IncidentDefOf.Quest_TradeRequest; @@ -140,10 +143,10 @@ private static IncidentDef IncidentDef() //working lists for ExposeData. - List factionsListforInteraction = new List(); - List factionsListforTimesTraded = new List(); - List intListForInteraction = new List(); - List intListforTimesTraded = new List(); + private List factionsListforInteraction = new List(); + private List factionsListforTimesTraded = new List(); + private List intListForInteraction = new List(); + private List intListforTimesTraded = new List(); public override void ExposeData() { diff --git a/MoreFactionInteraction/Properties/AssemblyInfo.cs b/MoreFactionInteraction/Properties/AssemblyInfo.cs index dacd97a..aab78a1 100644 --- a/MoreFactionInteraction/Properties/AssemblyInfo.cs +++ b/MoreFactionInteraction/Properties/AssemblyInfo.cs @@ -31,5 +31,5 @@ // You can specify all the values or you can default the Build and Revision Numbers // by using the '*' as shown below: // [assembly: AssemblyVersion("1.0.*")] -[assembly: AssemblyVersion("0.1.0.2")] -[assembly: AssemblyFileVersion("0.1.0.2")] +[assembly: AssemblyVersion("0.1.0.3")] +[assembly: AssemblyFileVersion("0.1.0.3")] diff --git a/MoreFactionInteraction/Spreading Pirates/IncidentWorker_SpreadingOutpost.cs b/MoreFactionInteraction/Spreading Pirates/IncidentWorker_SpreadingOutpost.cs index 0a27420..0b3e8f0 100644 --- a/MoreFactionInteraction/Spreading Pirates/IncidentWorker_SpreadingOutpost.cs +++ b/MoreFactionInteraction/Spreading Pirates/IncidentWorker_SpreadingOutpost.cs @@ -33,6 +33,7 @@ protected override bool TryExecuteWorker(IncidentParms parms) if (!TileFinder.TryFindNewSiteTile(tile: out int tile, minDist: 2, maxDist: 8, allowCaravans: false, preferCloserTiles: true, nearThisTile: pirateTile)) return false; Site site = SiteMaker.MakeSite(core: SiteCoreDefOf.Nothing, sitePart: SitePartDefOf.Outpost, tile: tile, faction: this.faction); site.Tile = tile; + site.sitePartsKnown = true; Find.WorldObjects.Add(o: site); this.SendStandardLetter(lookTargets: site, relatedFaction: this.faction, textArgs: new string[] { diff --git a/README.md b/README.md index 7a186cb..1339f83 100644 --- a/README.md +++ b/README.md @@ -45,18 +45,24 @@ Adds more interaction with and between factions, bringing the world to life. - erdelf, erdelf. - ShotgunFrenzy, art. - Halno, art. +- Ian, text revisions. - My testers. You know who you are. Thanks to [Eviltrick](https://twitch.tv/Eviltrick) in particular, check 'em out on twitch. Shoutout to [Albion of Sparkling Worlds](https://steamcommunity.com/sharedfiles/filedetails/?id=1123043922), for the inspiration and support. -## Links +## Language + +- Japanese, courtesy of Proxyer -- Steam: https://steamcommunity.com/sharedfiles/filedetails/?id=1454024362 -- GitHub: https://github.com/Mehni/MoreFactionInteraction/releases -- Ludeon: https://ludeon.com/forums/index.php?topic=35832 +## Links +- Steam: [https://steamcommunity.com/sharedfiles/filedetails/?id=1454024362](https://steamcommunity.com/sharedfiles/filedetails/?id=1454024362) +- GitHub: [https://github.com/Mehni/MoreFactionInteraction/releases](https://github.com/Mehni/MoreFactionInteraction/releases) +- Ludeon: [https://ludeon.com/forums/index.php?topic=35832](https://ludeon.com/forums/index.php?topic=35832) +  +  If you like this mod, please considering buying me a coffee. diff --git a/Textures/Expanding/HealerHand.png b/Textures/Expanding/HealerHand.png index 9ece685..4cc482a 100644 Binary files a/Textures/Expanding/HealerHand.png and b/Textures/Expanding/HealerHand.png differ