mirror of
https://github.com/vegapnk/RJW-Genes.git
synced 2024-08-15 00:23:31 +00:00
Anal/Vaginal Cumabsorption genes, fertilin category, pussyheal requires fertilin now
This commit is contained in:
parent
0d15873bd2
commit
e642942c1e
13 changed files with 300 additions and 39 deletions
|
@ -48,5 +48,24 @@ namespace RJW_Genes
|
|||
}
|
||||
return any_wound_tended;
|
||||
}
|
||||
|
||||
public static float LifeForceCost(Ability ability)
|
||||
{
|
||||
if (ability.comps != null)
|
||||
{
|
||||
using (List<AbilityComp>.Enumerator enumerator = ability.comps.GetEnumerator())
|
||||
{
|
||||
while (enumerator.MoveNext())
|
||||
{
|
||||
CompAbilityEffect_LifeForceCost compAbilityEffect_HemogenCost;
|
||||
if ((compAbilityEffect_HemogenCost = (enumerator.Current as CompAbilityEffect_LifeForceCost)) != null)
|
||||
{
|
||||
return compAbilityEffect_HemogenCost.Props.fertilinCost;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return 0f;
|
||||
}
|
||||
}
|
||||
}
|
118
Source/Genes/Life_Force/CompAbilityEffect_LifeForceCost.cs
Normal file
118
Source/Genes/Life_Force/CompAbilityEffect_LifeForceCost.cs
Normal file
|
@ -0,0 +1,118 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Runtime.CompilerServices;
|
||||
using System.Text;
|
||||
using Verse;
|
||||
using Verse.AI;
|
||||
using RimWorld;
|
||||
namespace RJW_Genes
|
||||
{
|
||||
// Token: 0x02000F66 RID: 3942
|
||||
public class CompAbilityEffect_LifeForceCost : CompAbilityEffect
|
||||
{
|
||||
// Token: 0x17000FFB RID: 4091
|
||||
// (get) Token: 0x06005D18 RID: 23832 RVA: 0x001FA767 File Offset: 0x001F8967
|
||||
public new CompProperties_AbilityLifeForceCost Props
|
||||
{
|
||||
get
|
||||
{
|
||||
return (CompProperties_AbilityLifeForceCost)this.props;
|
||||
}
|
||||
}
|
||||
|
||||
// Token: 0x17000FFC RID: 4092
|
||||
// (get) Token: 0x06005D19 RID: 23833 RVA: 0x001FA774 File Offset: 0x001F8974
|
||||
private bool HasEnoughFertilin
|
||||
{
|
||||
get
|
||||
{
|
||||
Pawn_GeneTracker genes = this.parent.pawn.genes;
|
||||
Gene_LifeForce gene_lifeforce = (genes != null) ? genes.GetFirstGeneOfType < Gene_LifeForce>() : null;
|
||||
return gene_lifeforce != null && gene_lifeforce.Value >= this.Props.fertilinCost;
|
||||
}
|
||||
}
|
||||
|
||||
// Token: 0x06005D1A RID: 23834 RVA: 0x001FA7B7 File Offset: 0x001F89B7
|
||||
public override void Apply(LocalTargetInfo target, LocalTargetInfo dest)
|
||||
{
|
||||
base.Apply(target, dest);
|
||||
GeneUtility.OffsetLifeForce(this.parent.pawn, -this.Props.fertilinCost, true);
|
||||
}
|
||||
|
||||
// Token: 0x06005D1B RID: 23835 RVA: 0x001FA7E0 File Offset: 0x001F89E0
|
||||
public override bool GizmoDisabled(out string reason)
|
||||
{
|
||||
Pawn_GeneTracker genes = this.parent.pawn.genes;
|
||||
Gene_LifeForce gene_LifeForce = (genes != null) ? genes.GetFirstGeneOfType<Gene_LifeForce>() : null;
|
||||
if (gene_LifeForce == null)
|
||||
{
|
||||
reason = "AbilityDisabledNoFertilinGene".Translate(this.parent.pawn);
|
||||
return true;
|
||||
}
|
||||
if (gene_LifeForce.Value < this.Props.fertilinCost)
|
||||
{
|
||||
reason = "AbilityDisabledNoFertilin".Translate(this.parent.pawn);
|
||||
return true;
|
||||
}
|
||||
float num = this.TotalLifeForceCostOfQueuedAbilities();
|
||||
float num2 = this.Props.fertilinCost + num;
|
||||
if (this.Props.fertilinCost > 1E-45f && num2 > gene_LifeForce.Value)
|
||||
{
|
||||
reason = "AbilityDisabledNoFertilin".Translate(this.parent.pawn);
|
||||
return true;
|
||||
}
|
||||
reason = null;
|
||||
return false;
|
||||
}
|
||||
|
||||
public override bool AICanTargetNow(LocalTargetInfo target)
|
||||
{
|
||||
return this.HasEnoughFertilin;
|
||||
}
|
||||
|
||||
private float TotalLifeForceCostOfQueuedAbilities()
|
||||
{
|
||||
Pawn_JobTracker jobs = this.parent.pawn.jobs;
|
||||
object obj;
|
||||
if (jobs == null)
|
||||
{
|
||||
obj = null;
|
||||
}
|
||||
else
|
||||
{
|
||||
Job curJob = jobs.curJob;
|
||||
obj = ((curJob != null) ? curJob.verbToUse : null);
|
||||
}
|
||||
Verb_CastAbility verb_CastAbility = obj as Verb_CastAbility;
|
||||
float num;
|
||||
if (verb_CastAbility == null)
|
||||
{
|
||||
num = 0f;
|
||||
}
|
||||
else
|
||||
{
|
||||
Ability ability = verb_CastAbility.ability;
|
||||
num = ((ability != null) ? AbilityUtility.LifeForceCost(ability) : 0f);
|
||||
}
|
||||
float num2 = num;
|
||||
if (this.parent.pawn.jobs != null)
|
||||
{
|
||||
for (int i = 0; i < this.parent.pawn.jobs.jobQueue.Count; i++)
|
||||
{
|
||||
Verb_CastAbility verb_CastAbility2;
|
||||
if ((verb_CastAbility2 = (this.parent.pawn.jobs.jobQueue[i].job.verbToUse as Verb_CastAbility)) != null)
|
||||
{
|
||||
float num3 = num2;
|
||||
Ability ability2 = verb_CastAbility2.ability;
|
||||
num2 = num3 + ((ability2 != null) ? AbilityUtility.LifeForceCost(ability2) : 0f);
|
||||
}
|
||||
}
|
||||
}
|
||||
return num2;
|
||||
}
|
||||
|
||||
//Modified version of HemogenCost in Ability
|
||||
|
||||
}
|
||||
}
|
|
@ -0,0 +1,28 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
using Verse;
|
||||
using RimWorld;
|
||||
|
||||
namespace RJW_Genes
|
||||
{
|
||||
// Token: 0x02000F65 RID: 3941
|
||||
public class CompProperties_AbilityLifeForceCost : CompProperties_AbilityEffect
|
||||
{
|
||||
// Token: 0x06005D16 RID: 23830 RVA: 0x001FA73F File Offset: 0x001F893F
|
||||
public CompProperties_AbilityLifeForceCost()
|
||||
{
|
||||
this.compClass = typeof(CompAbilityEffect_LifeForceCost);
|
||||
}
|
||||
|
||||
// Token: 0x06005D17 RID: 23831 RVA: 0x001FA757 File Offset: 0x001F8957
|
||||
public override IEnumerable<string> ExtraStatSummary()
|
||||
{
|
||||
yield return "AbilityFertilinCost" + ": " + Mathf.RoundToInt(this.fertilinCost * 100f);
|
||||
yield break;
|
||||
}
|
||||
|
||||
// Token: 0x040038CD RID: 14541
|
||||
public float fertilinCost;
|
||||
}
|
||||
}
|
|
@ -30,11 +30,11 @@ namespace RJW_Genes
|
|||
{
|
||||
if (this.gene.targetValue <= 0f)
|
||||
{
|
||||
text += "NeverConsumeCum";
|
||||
text += "NeverSeekFertilin";
|
||||
}
|
||||
else
|
||||
{
|
||||
text = text + ("ConsumeCumBelow" + ": ") + this.gene.PostProcessValue(this.gene.targetValue);
|
||||
text = text + ("SeekFertilinBelow" + ": ") + this.gene.PostProcessValue(this.gene.targetValue);
|
||||
}
|
||||
}
|
||||
if (!this.drainGenes.NullOrEmpty<IGeneResourceDrain>())
|
||||
|
|
|
@ -10,7 +10,7 @@ using Verse;
|
|||
|
||||
namespace RJW_Genes
|
||||
{
|
||||
|
||||
|
||||
[HarmonyPatch(typeof(SexUtility), nameof(SexUtility.SatisfyPersonal))]
|
||||
public static class Patch_LifeForce
|
||||
{
|
||||
|
@ -20,16 +20,43 @@ namespace RJW_Genes
|
|||
if (props.pawn == null || !props.hasPartner())
|
||||
return;
|
||||
|
||||
float factor = 1f;
|
||||
if (GeneUtility.HasLifeForce(props.pawn))
|
||||
{
|
||||
if (props.sexType == xxx.rjwSextype.Oral || props.sexType == xxx.rjwSextype.Fellatio || props.sexType == xxx.rjwSextype.Sixtynine)
|
||||
{
|
||||
Pawn_GeneTracker genes = props.pawn.genes;
|
||||
Gene_LifeForce gene = genes.GetFirstGeneOfType<Gene_LifeForce>();
|
||||
gene.Resource.Value += CumUtility.GetTotalFluidAmount(props.partner); //total amount may need to be modified to be balanced or maybe I should just consider one at random
|
||||
{
|
||||
AbsorbFertilin(props, factor);
|
||||
//Currently taking the sum of all penises, maybe I should just consider one at random
|
||||
}
|
||||
}
|
||||
else if (props.sexType == xxx.rjwSextype.Vaginal && GeneUtility.HasGeneNullCheck(props.pawn, GeneDefOf.rjw_genes_vaginal_absorber))
|
||||
{
|
||||
AbsorbFertilin(props, factor);
|
||||
}
|
||||
else if (props.sexType == xxx.rjwSextype.Anal && GeneUtility.HasGeneNullCheck(props.pawn, GeneDefOf.rjw_genes_anal_absorber))
|
||||
{
|
||||
AbsorbFertilin(props, factor);
|
||||
}
|
||||
else if (props.sexType == xxx.rjwSextype.DoublePenetration)
|
||||
{
|
||||
if (GeneUtility.HasGeneNullCheck(props.pawn, GeneDefOf.rjw_genes_vaginal_absorber))
|
||||
{
|
||||
AbsorbFertilin(props, 0.5f);
|
||||
}
|
||||
if (GeneUtility.HasGeneNullCheck(props.pawn, GeneDefOf.rjw_genes_anal_absorber))
|
||||
{
|
||||
AbsorbFertilin(props, 0.5f);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void AbsorbFertilin(SexProps props, float factor = 1f)
|
||||
{
|
||||
Pawn_GeneTracker genes = props.pawn.genes;
|
||||
Gene_LifeForce gene = genes.GetFirstGeneOfType<Gene_LifeForce>();
|
||||
gene.Resource.Value += CumUtility.GetTotalFluidAmount(props.partner) / 100 * factor;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue