mirror of
https://gitgud.io/c0ffeeeeeeee/rimworld-animations.git
synced 2024-08-15 00:43:45 +00:00
graphic severity variants, bugfix with not having any of a specific hediff
This commit is contained in:
parent
9290ea05c4
commit
319979b0f3
6 changed files with 173 additions and 1 deletions
Binary file not shown.
|
@ -0,0 +1,33 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Verse;
|
||||||
|
|
||||||
|
namespace Rimworld_Animations
|
||||||
|
{
|
||||||
|
public class PawnRenderNodeProperties_GraphicHediffSeverityVariants : PawnRenderNodeProperties_GraphicVariants
|
||||||
|
{
|
||||||
|
|
||||||
|
public BodyPartDef bodyPart = null;
|
||||||
|
public List<HediffWithSeverity> hediffSeverityVariants;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public class HediffWithSeverity
|
||||||
|
{
|
||||||
|
public HediffDef hediff;
|
||||||
|
public List<TexPathVariants_Severity> severityVariants;
|
||||||
|
}
|
||||||
|
|
||||||
|
public class TexPathVariants_Severity
|
||||||
|
{
|
||||||
|
public int severity;
|
||||||
|
public TexPathVariantsDef texPathVariantsDef;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace Rimworld_Animations
|
||||||
|
{
|
||||||
|
public class PawnRenderNodeWorker_GraphicHediffSeverityVariants : PawnRenderNodeWorker_GraphicVariants
|
||||||
|
{
|
||||||
|
//same functionality as graphicvariants worker
|
||||||
|
//just here for readability
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,121 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Verse;
|
||||||
|
|
||||||
|
namespace Rimworld_Animations
|
||||||
|
{
|
||||||
|
public class PawnRenderNode_GraphicHediffSeverityVariants : PawnRenderNode_GraphicVariants
|
||||||
|
{
|
||||||
|
|
||||||
|
protected HediffDef hediffWithSeverity;
|
||||||
|
protected float curSeverity;
|
||||||
|
|
||||||
|
protected new PawnRenderNodeProperties_GraphicHediffSeverityVariants props;
|
||||||
|
private HediffDef curHediff;
|
||||||
|
|
||||||
|
public PawnRenderNode_GraphicHediffSeverityVariants(Pawn pawn, PawnRenderNodeProperties props, PawnRenderTree tree) : base(pawn, props, tree)
|
||||||
|
{
|
||||||
|
|
||||||
|
this.props = (PawnRenderNodeProperties_GraphicHediffSeverityVariants)props;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Dictionary<int, Graphic> GraphicHediffSeverityVariantsFor(Pawn pawn)
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
if (props.hediffSeverityVariants == null)
|
||||||
|
{
|
||||||
|
Log.Error("[Anims] Error: Tried to use GraphicBodyPartHediffSeverityVariants node, but hediffSeverityVariants weren't given");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Hediff idealHediff = null;
|
||||||
|
HediffWithSeverity idealHediffSeverity = null;
|
||||||
|
|
||||||
|
if (props.bodyPart == null)
|
||||||
|
{
|
||||||
|
//search the entire body for the hediff because no bodypart was set
|
||||||
|
for (int i = 0; i < props.hediffSeverityVariants.Count; i++)
|
||||||
|
{
|
||||||
|
idealHediff = pawn.health.hediffSet.hediffs.Find((Hediff hediffWithSeverity) =>
|
||||||
|
hediffWithSeverity.def == props.hediffSeverityVariants[i].hediff);
|
||||||
|
|
||||||
|
if (idealHediff != null)
|
||||||
|
{
|
||||||
|
//get the ideal hediff severity variants, to iterate through and find the right one for the severity
|
||||||
|
idealHediffSeverity = props.hediffSeverityVariants[i];
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//search for a hediff with a specific body part
|
||||||
|
|
||||||
|
for (int i = 0; i < props.hediffSeverityVariants.Count; i++)
|
||||||
|
{
|
||||||
|
//right hediff with the right hediff and right body part
|
||||||
|
|
||||||
|
idealHediff = pawn.health.hediffSet.hediffs.Find((Hediff hediffWithSeverity) =>
|
||||||
|
hediffWithSeverity.def == props.hediffSeverityVariants[i].hediff
|
||||||
|
&& hediffWithSeverity.Part.def == props.bodyPart);
|
||||||
|
|
||||||
|
if (idealHediff != null) {
|
||||||
|
|
||||||
|
//get the ideal hediff severity variants, to iterate through and find the right one for the severity
|
||||||
|
idealHediffSeverity = props.hediffSeverityVariants[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (idealHediff != null)
|
||||||
|
{
|
||||||
|
//set severity so that recache when this is different
|
||||||
|
curSeverity = idealHediff.Severity;
|
||||||
|
|
||||||
|
//look for the right severity-based texpathvariants
|
||||||
|
TexPathVariants_Severity texPathVariants_Severity = idealHediffSeverity.severityVariants.Find((TexPathVariants_Severity texPathVariants) =>
|
||||||
|
texPathVariants.severity < idealHediff.Severity);
|
||||||
|
|
||||||
|
//if null, assume value is really too small
|
||||||
|
if (texPathVariants_Severity == null)
|
||||||
|
{
|
||||||
|
//return largest value
|
||||||
|
return GenerateVariants(pawn, idealHediffSeverity.severityVariants.First().texPathVariantsDef);
|
||||||
|
}
|
||||||
|
|
||||||
|
//return right severity variants
|
||||||
|
return GenerateVariants(pawn, texPathVariants_Severity.texPathVariantsDef);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//there is no graphic hediff variants appropriate
|
||||||
|
curHediff = null;
|
||||||
|
return null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void EnsureMaterialsInitialized()
|
||||||
|
{
|
||||||
|
//if pawn no longer has the hediff,
|
||||||
|
if (variants == null ||
|
||||||
|
!(this.tree.pawn.health?.hediffSet?.hediffs is List<Hediff> hediffs
|
||||||
|
&& hediffs.Any((Hediff hediff) => hediff.def == curHediff && hediff.Severity == curSeverity)))
|
||||||
|
{
|
||||||
|
//do graphicvariantsfor
|
||||||
|
variants = GraphicHediffSeverityVariantsFor(this.tree.pawn);
|
||||||
|
}
|
||||||
|
|
||||||
|
//call this in case variants wasn't set, and there is no graphic hediff variants appropriate; it'll set variants based on default
|
||||||
|
base.EnsureMaterialsInitialized();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -57,7 +57,7 @@ namespace Rimworld_Animations
|
||||||
{
|
{
|
||||||
//if pawn no longer has the hediff,
|
//if pawn no longer has the hediff,
|
||||||
if (variants == null ||
|
if (variants == null ||
|
||||||
(this.tree.pawn.health?.hediffSet?.hediffs is List<Hediff> hediffs
|
!(this.tree.pawn.health?.hediffSet?.hediffs is List<Hediff> hediffs
|
||||||
&& hediffs.Any((Hediff hediff) => hediff.def == curHediff)))
|
&& hediffs.Any((Hediff hediff) => hediff.def == curHediff)))
|
||||||
{
|
{
|
||||||
//do graphicvariantsfor
|
//do graphicvariantsfor
|
||||||
|
|
|
@ -121,6 +121,9 @@
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNodeProperties_GraphicBodyTypeVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNodeProperties_GraphicBodyTypeVariants.cs" />
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNodeWorker_GraphicBodyTypeVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNodeWorker_GraphicBodyTypeVariants.cs" />
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNode_GraphicBodyTypeVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicBodyTypeVariants\PawnRenderNode_GraphicBodyTypeVariants.cs" />
|
||||||
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffSeverityVariants\PawnRenderNodeProperties_GraphicHediffSeverityVariants.cs" />
|
||||||
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffSeverityVariants\PawnRenderNodeWorker_GraphicHediffSeverityVariants.cs" />
|
||||||
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffSeverityVariants\PawnRenderNode_GraphicHediffSeverityVariants.cs" />
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNodeProperties_GraphicHediffVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNodeProperties_GraphicHediffVariants.cs" />
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNodeWorker_GraphicHediffVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNodeWorker_GraphicHediffVariants.cs" />
|
||||||
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNode_GraphicHediffVariants.cs" />
|
<Compile Include="1.5\Source\PawnRenderNode\GraphicHediffVariants\PawnRenderNode_GraphicHediffVariants.cs" />
|
||||||
|
|
Loading…
Reference in a new issue