Drafts for more extra-genitalia

This commit is contained in:
Vegapnk 2022-11-14 17:47:43 +01:00
parent bb679527af
commit fa07b9365c
14 changed files with 514 additions and 38 deletions

View file

@ -0,0 +1,59 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_ExtraAnus : Gene
{
internal Hediff additional_anus;
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
if (additional_anus == null)
{
CreateAndAddAnus();
}
}
public override void PostAdd()
{
base.PostAdd();
if (additional_anus == null)
{
CreateAndAddAnus();
}
}
public override void PostRemove()
{
base.PostRemove();
if(additional_anus != null)
pawn.health.RemoveHediff(additional_anus);
}
internal void CreateAndAddAnus()
{
var correctGene = GenitaliaUtility.GetGenitaliaTypeGeneForPawn(pawn);
var anusDef = GenitaliaUtility.GetAnusForGene(correctGene);
var partBPR = Genital_Helper.get_anusBPR(pawn);
additional_anus = HediffMaker.MakeHediff(anusDef, pawn);
var CompHediff = additional_anus.TryGetComp<rjw.CompHediffBodyPart>();
if (CompHediff != null)
{
CompHediff.initComp(pawn);
CompHediff.updatesize();
}
pawn.health.AddHediff(additional_anus, partBPR);
}
}
}

View file

@ -0,0 +1,61 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_ExtraBreasts : Gene
{
internal Hediff additional_breasts;
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
// Penis are only added for female pawns!
if (pawn.gender == Gender.Female && additional_breasts == null)
{
createAndAddPenis();
}
}
public override void PostAdd()
{
base.PostAdd();
// Penis are only added for female pawns!
if (pawn.gender == Gender.Female && additional_breasts == null)
{
createAndAddPenis();
}
}
public override void PostRemove()
{
base.PostRemove();
if(additional_breasts != null)
pawn.health.RemoveHediff(additional_breasts);
}
internal void createAndAddPenis()
{
var correctGene = GenitaliaUtility.GetGenitaliaTypeGeneForPawn(pawn);
var breastDef = GenitaliaUtility.GetBreastsForGene(correctGene);
var partBPR = Genital_Helper.get_breastsBPR(pawn);
additional_breasts = HediffMaker.MakeHediff(breastDef, pawn);
var CompHediff = additional_breasts.TryGetComp<rjw.CompHediffBodyPart>();
if (CompHediff != null)
{
CompHediff.initComp(pawn);
CompHediff.updatesize();
}
pawn.health.AddHediff(additional_breasts, partBPR);
}
}
}

View file

@ -43,7 +43,7 @@ namespace RJW_Genes
internal void createAndAddPenis()
{
var correctGene = GenitaliaUtility.GetGenitaliaTypeGeneForPawn(pawn);
var penisDef = GenitaliaUtility.GetPenisForGene(correctGene);
HediffDef penisDef = GenitaliaUtility.GetPenisForGene(correctGene);
var partBPR = Genital_Helper.get_genitalsBPR(pawn);
additional_penis = HediffMaker.MakeHediff(penisDef, pawn);

View file

@ -0,0 +1,66 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_ExtraVagina : Gene
{
internal Hediff additional_vagina;
//TODO: This works ingame when genes are added, but if there is
//a gene (e.g. ovipositor) in creation it does not work as expected (only has one genital)
//Penis works as expected
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
// Vaginas are only added for female pawns!
if (pawn.gender == Gender.Female && additional_vagina == null)
{
CreateAndAddVagina();
}
}
public override void PostAdd()
{
base.PostAdd();
// Vaginas are only added for female pawns!
if (pawn.gender == Gender.Female && additional_vagina == null)
{
CreateAndAddVagina();
}
}
public override void PostRemove()
{
base.PostRemove();
if(additional_vagina != null)
pawn.health.RemoveHediff(additional_vagina);
}
internal void CreateAndAddVagina()
{
var correctGene = GenitaliaUtility.GetGenitaliaTypeGeneForPawn(pawn);
HediffDef vaginaDef = GenitaliaUtility.GetVaginaForGene(correctGene);
var partBPR = Genital_Helper.get_genitalsBPR(pawn);
additional_vagina = HediffMaker.MakeHediff(vaginaDef, pawn);
var CompHediff = additional_vagina.TryGetComp<rjw.CompHediffBodyPart>();
if (CompHediff != null)
{
CompHediff.initComp(pawn);
CompHediff.updatesize();
}
pawn.health.AddHediff(additional_vagina, partBPR);
}
}
}

View file

@ -0,0 +1,57 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_NoAnus : Gene
{
internal Hediff removed_anus;
// TODO: This gene only works if another Gene was set specifying the genitalia.
// If it is added later, it still works, but on creation it needs a different
// TODO: If all Genitalia are removed by genes, RJW adds some to the pawns at spawn
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
if (removed_anus == null)
{
RemoveButStoreAnus();
}
}
public override void PostAdd()
{
base.PostAdd();
if (removed_anus == null)
{
RemoveButStoreAnus();
}
}
public override void PostRemove()
{
base.PostRemove();
if(removed_anus != null)
pawn.health.AddHediff(removed_anus);
}
internal void RemoveButStoreAnus()
{
var partBPR = Genital_Helper.get_anusBPR(pawn);
Hediff anusToRemove = Genital_Helper.get_AllPartsHediffList(pawn).FindLast(x => GenitaliaChanger.IsAnus(x));
if(anusToRemove != null)
{
removed_anus = anusToRemove;
pawn.health.RemoveHediff(anusToRemove);
}
}
}
}

View file

@ -0,0 +1,59 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_NoBreasts : Gene
{
internal Hediff removed_breasts;
// TODO: This gene only works if another Gene was set specifying the genitalia.
// If it is added later, it still works, but on creation it needs a different
// TODO: If all Genitalia are removed by genes, RJW adds some to the pawns at spawn. IDEA: Add male-nipples ?
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
// Breasts are removed for female pawns!
if (pawn.gender == Gender.Female && removed_breasts == null)
{
RemoveButStoreBreasts();
}
}
public override void PostAdd()
{
base.PostAdd();
// Breasts are removed for female pawns!
if (pawn.gender == Gender.Female && removed_breasts == null)
{
RemoveButStoreBreasts();
}
}
public override void PostRemove()
{
base.PostRemove();
if(removed_breasts != null)
pawn.health.AddHediff(removed_breasts);
}
internal void RemoveButStoreBreasts()
{
var partBPR = Genital_Helper.get_breastsBPR(pawn);
Hediff breastsToRemove = Genital_Helper.get_AllPartsHediffList(pawn).FindLast(x => GenitaliaUtility.IsBreasts(x));
if(breastsToRemove != null)
{
removed_breasts = breastsToRemove;
pawn.health.RemoveHediff(breastsToRemove);
}
}
}
}

View file

@ -11,6 +11,7 @@ namespace RJW_Genes
// TODO: This gene only works if another Gene was set specifying the genitalia.
// If it is added later, it still works, but on creation it needs a different
// TODO: If all Genitalia are removed by genes, RJW adds some to the pawns at spawn
public override void PostMake()
{
base.PostMake();

View file

@ -0,0 +1,59 @@
using Verse;
using rjw;
using RimWorld;
namespace RJW_Genes
{
public class Gene_NoVagina : Gene
{
internal Hediff removed_vagina;
// TODO: This gene only works if another Gene was set specifying the genitalia.
// If it is added later, it still works, but on creation it needs a different
// TODO: If all Genitalia are removed by genes, RJW adds some to the pawns at spawn
public override void PostMake()
{
base.PostMake();
if (GenitaliaUtility.PawnStillNeedsGenitalia(pawn))
Sexualizer.sexualize_pawn(pawn);
// Vaginas are only removed for female pawns!
if (pawn.gender == Gender.Female && removed_vagina == null)
{
RemoveButStoreVagina();
}
}
public override void PostAdd()
{
base.PostAdd();
// Vaginas are only removed for female pawns!
if (pawn.gender == Gender.Female && removed_vagina == null)
{
RemoveButStoreVagina();
}
}
public override void PostRemove()
{
base.PostRemove();
if(removed_vagina != null)
pawn.health.AddHediff(removed_vagina);
}
internal void RemoveButStoreVagina()
{
var partBPR = Genital_Helper.get_genitalsBPR(pawn);
Hediff vaginaToRemove = Genital_Helper.get_AllPartsHediffList(pawn).FindLast(x => Genital_Helper.is_vagina(x));
if(vaginaToRemove != null)
{
removed_vagina = vaginaToRemove;
pawn.health.RemoveHediff(vaginaToRemove);
}
}
}
}

View file

@ -70,11 +70,11 @@ namespace RJW_Genes
}
private static bool IsAnus(Hediff candidate)
public static bool IsAnus(Hediff candidate)
{
return candidate.def.defName.ToLower().Contains("anus"); }
private static bool IsArtificial(Hediff candidate)
public static bool IsArtificial(Hediff candidate)
{
return candidate.def.defName.ToLower().Contains("bionic") || candidate.def.defName.ToLower().Contains("archo");
}