From 4a7798386d87718ee92dd21d5a0d297c0d7e63a6 Mon Sep 17 00:00:00 2001 From: c0ffee Date: Sat, 24 Jul 2021 08:25:43 -0700 Subject: [PATCH] code tidying --- 1.3/Assemblies/Rimworld-Animations.dll | Bin 59904 -> 59904 bytes Source/Patches/HarmonyPatch_AlienRace.cs | 166 ----------------------- 2 files changed, 166 deletions(-) diff --git a/1.3/Assemblies/Rimworld-Animations.dll b/1.3/Assemblies/Rimworld-Animations.dll index eb9e47683f9324248fda933691f68822f6ca97e9..086d4372596f9c876a7265d9bcb1e1863edc9c40 100644 GIT binary patch delta 1649 zcmY+FU2GIp6vzK}yKGx}V<-?W@h_R8GWgYp~2wBiyzI#Pp%RJ@pE;eA|XWaqOcHHl_(56o!BXg#mPj!@Ski^ zztLx_x&l~)R6nrA2SnognaX5s;Qq#3flMW40l8SYxD=sv$rI0Qf8Kw+j`~IrEm|&L z!XVQ?xH3P4DhxBl!~625a;lI@SLVwqyjnlsw_aAGK24kCHhg8MIQ)A~EvC|1jogm1 zo%4OWD=HdEo5Tyj5ZY1H1oGDw?I>#^QQuQLjxmvTJF^|5Op|CR zSRU%YrDm#}#ObF(h~lQ9rEANBQOq&vnNd7sib05R8AaAX>Wksez!iB2Em4qv3~Ms3 z$WEM4NK~unFwQaQFkQI7q=$ClvZ-8*aoL3*41J?4-o{Uc_6Ek~5&WF)6X=FGL=MxU zCntoX2om`U-(ORx@Q=eRW|u@J5S zD5y}>W;8Oi&|!%DEc|+erufrrXyHENG#gs@TT?a}S_pP87+R<{M1~e>n6#mVHlvZD zjSfR(XyX~1r)0N9Zb%y&H2G|3W3v&-(8d-`;)}dns`R)aGPE(oqz}f%_5aZ=CVfmc zW|?A$fWox)kbMlt@Qa$+%QO)7X;D2GVbmw%VAK%hb}-nxklVqKCXVgkQ=?IA2V+K~ z*bZh4QEUglG3h-y$ntom=<(H}Tx>N+hAzh5A+aCl1!f(V>A_Xv-A*AFKc=%D5-~1CY{tnC6hi;4=*z5pdPL!KX4z^EUA8F z!(7Rdl9xX}d#3!~Wgp&74u5+yymXKGN1)LbeJ_X?t`IGWPiCA%!R)5w6Zihf2n;@( M%$=PR@v_YS0QY`&p#T5? delta 1697 zcmYk7Urd`-7{;H|mQv^uH$zxQQHNcn8Czu8;+(Q%kVWMRaGBlM@DETNLRZn!ul@M8 z4CG@Yh&qCEQ7#tc!o)Nz(F>O)DiTeMp7*?mYLlfX%3gRRhh{o-MI%pn6xppQ;1=&7v+? zxpOOOeE#u=0bi_BiLoyAHQA^pVT)`=U_uzZuE;U$ViNt0RJzw_bCEsNXtciiuT`aMXuZBeY15k6a10lWMur(&G(>(G+><6h zmkl%6p|PY5GuX{kMTQx)8jTDya1D`R2Gg3@FoO$5BSQ-p4UwURgvAGZHu9ackYsYT zp@p;&$FA(`~nY;+nTdmC|0yeAv|nkbA* z79$#YQ8sQGqD9&Gr(7y9j(YvR;5|8LFhsG{2_`uV1$7W$(m@^EZZrz&AY?SPr&d*Z z+#n@&(65P;I!I~a8+DM?#6cbWSv+E|cW!#@Y;Do j{F6|oj|*+9VKH0iUCkA1Zv5r-EbK0B{`r>3w^aTM1VVH{ diff --git a/Source/Patches/HarmonyPatch_AlienRace.cs b/Source/Patches/HarmonyPatch_AlienRace.cs index 1fb5887..353a717 100644 --- a/Source/Patches/HarmonyPatch_AlienRace.cs +++ b/Source/Patches/HarmonyPatch_AlienRace.cs @@ -39,22 +39,6 @@ namespace Rimworld_Animations { GenDraw.DrawMeshNowOrLater(mesh, loc, quat, mat, drawNow); } } - /* - public static Rot4 AdjustRotationValueForHeadAddon(Rot4 rotation, AlienPartGenerator.BodyAddon bodyAddon, Pawn pawn) - { - CompBodyAnimator anim = pawn.TryGetComp(); - - if (anim.isAnimating && (bodyAddon.alignWithHead || bodyAddon.drawnInBed)) - { - return anim.headFacing; - } - else - { - return rotation; - } - - - }*/ public static IEnumerable Transpiler(IEnumerable instructions) @@ -80,15 +64,6 @@ namespace Rimworld_Animations { yield return new CodeInstruction(OpCodes.Call, AccessTools.DeclaredMethod(typeof(HarmonyPatch_AlienRace), "RenderHeadAddonInAnimation")); } - /* - else if(ins[i].opcode == OpCodes.Ldarg_S && ins[i].OperandIs((object)5)) //rotation - { - yield return ins[i]; - yield return new CodeInstruction(OpCodes.Ldloc, (object)4); //bodyAddon - yield return new CodeInstruction(OpCodes.Ldarg, (object)3); //pawn - yield return new CodeInstruction(OpCodes.Call, AccessTools.DeclaredMethod(typeof(HarmonyPatch_AlienRace), "AdjustRotationValueForHeadAddon")); - - }*/ else { @@ -99,147 +74,6 @@ namespace Rimworld_Animations { } } - public static bool Prefix(PawnRenderFlags renderFlags, ref Vector3 vector, ref Vector3 headOffset, Pawn pawn, ref Quaternion quat, ref Rot4 rotation) { - /* old patch for 1.2 - if (portrait || pawn.TryGetComp() == null || !pawn.TryGetComp().isAnimating) return true; - if (!(pawn.def is ThingDef_AlienRace alienProps) || invisible) return false; - - List addons = alienProps.alienRace.generalSettings.alienPartGenerator.bodyAddons; - AlienPartGenerator.AlienComp alienComp = pawn.GetComp(); - CompBodyAnimator pawnAnimator = pawn.TryGetComp(); - - for (int i = 0; i < addons.Count; i++) { - AlienPartGenerator.BodyAddon ba = addons[index: i]; - if (!ba.CanDrawAddon(pawn: pawn)) continue; - - AlienPartGenerator.RotationOffset offset = ba.defaultOffsets.GetOffset((ba.drawnInBed || ba.alignWithHead) ? pawnAnimator.headFacing : rotation); - Vector3 a = (offset != null) ? offset.GetOffset(renderFlags.FlagSet(PawnRenderFlags.Portrait), pawn.story.bodyType, comp.crownType) : Vector3.zero; - - - Vector2 bodyOffset = (portrait ? offset?.portraitBodyTypes ?? offset?.bodyTypes : offset?.bodyTypes)?.FirstOrDefault(predicate: to => to.bodyType == pawn.story.bodyType) - ?.offset ?? Vector2.zero; - Vector2 crownOffset = (portrait ? offset?.portraitCrownTypes ?? offset?.crownTypes : offset?.crownTypes)?.FirstOrDefault(predicate: to => to.crownType == alienComp.crownType) - ?.offset ?? Vector2.zero; - - //Defaults for tails - //south 0.42f, -0.3f, -0.22f - //north 0f, 0.3f, -0.55f - //east -0.42f, -0.3f, -0.22f - - float moffsetX = 0.42f; - float moffsetZ = -0.22f; - - float layerOffset = offset?.layerOffset ?? ba.layerOffset; - - float moffsetY = ba.inFrontOfBody ? 0.3f + ba.layerOffset : -0.3f - ba.layerOffset; - float num = ba.angle; - - if (((ba.drawnInBed || ba.alignWithHead) ? pawnAnimator.headFacing : rotation) == Rot4.North) { - moffsetX = 0f; - if (ba.layerInvert) - moffsetY = -moffsetY; - - moffsetZ = -0.55f; - num = 0; - } - - moffsetX += bodyOffset.x + crownOffset.x; - moffsetZ += bodyOffset.y + crownOffset.y; - - if (((ba.drawnInBed || ba.alignWithHead) ? pawnAnimator.headFacing : rotation) == Rot4.East) { - moffsetX = -moffsetX; - num = -num; //Angle - } - - Vector3 offsetVector = new Vector3(x: moffsetX, y: moffsetY, z: moffsetZ); - - //Angle calculation to not pick the shortest, taken from Quaternion.Angle and modified - - //assume drawnInBed means headAddon - Graphic addonGraphic = alienComp.addonGraphics[i]; - addonGraphic.drawSize = (portrait && ba.drawSizePortrait != Vector2.zero ? ba.drawSizePortrait : ba.drawSize) * (ba.scaleWithPawnDrawsize ? alienComp.customDrawSize : Vector2.one) * 1.5f; - - if ((ba.drawnInBed || ba.alignWithHead) && pawn.TryGetComp() != null && pawn.TryGetComp().isAnimating) { - - Quaternion headQuatInAnimation = Quaternion.AngleAxis(pawnAnimator.headAngle, Vector3.up); - Rot4 headRotInAnimation = pawnAnimator.headFacing; - Vector3 headPositionInAnimation = pawnAnimator.getPawnHeadPosition() - pawn.Drawer.renderer.BaseHeadOffsetAt(pawnAnimator.headFacing).RotatedBy(angle: Mathf.Acos(f: Quaternion.Dot(a: Quaternion.identity, b: headQuatInAnimation)) * 2f * 57.29578f); - - - GenDraw.DrawMeshNowOrLater(mesh: addonGraphic.MeshAt(rot: headRotInAnimation), loc: headPositionInAnimation + (ba.alignWithHead ? headOffset : Vector3.zero) + offsetVector.RotatedBy(angle: Mathf.Acos(f: Quaternion.Dot(a: Quaternion.identity, b: headQuatInAnimation)) * 2f * 57.29578f), - quat: Quaternion.AngleAxis(angle: num, axis: Vector3.up) * headQuatInAnimation, mat: addonGraphic.MatAt(rot: pawnAnimator.headFacing), drawNow: portrait); - - } - - else { - - Quaternion addonRotation = quat; - if (AnimationSettings.controlGenitalRotation && pawnAnimator.controlGenitalAngle && ba?.hediffGraphics != null && ba.hediffGraphics.Count != 0 && ba.hediffGraphics[0]?.path != null && (ba.hediffGraphics[0].path.Contains("Penis") || ba.hediffGraphics[0].path.Contains("penis"))) { - addonRotation = Quaternion.AngleAxis(angle: pawnAnimator.genitalAngle, axis: Vector3.up); - } - - GenDraw.DrawMeshNowOrLater(mesh: addonGraphic.MeshAt(rot: rotation), loc: vector + offsetVector.RotatedBy(angle: Mathf.Acos(f: Quaternion.Dot(a: Quaternion.identity, b: quat)) * 2f * 57.29578f), - quat: Quaternion.AngleAxis(angle: num, axis: Vector3.up) * addonRotation, mat: addonGraphic.MatAt(rot: rotation), drawNow: portrait); - - } - - - } - - - CompBodyAnimator pawnAnimator = pawn.TryGetComp(); - - ThingDef_AlienRace thingDef_AlienRace = pawn.def as ThingDef_AlienRace; - if (thingDef_AlienRace == null || renderFlags.FlagSet(PawnRenderFlags.Invisible)) - { - return false; - } - List bodyAddons = thingDef_AlienRace.alienRace.generalSettings.alienPartGenerator.bodyAddons; - AlienPartGenerator.AlienComp comp = pawn.GetComp(); - for (int i = 0; i < bodyAddons.Count; i++) - { - AlienPartGenerator.BodyAddon bodyAddon = bodyAddons[i]; - if (bodyAddon.CanDrawAddon(pawn)) - { - AlienPartGenerator.RotationOffset offset = bodyAddon.defaultOffsets.GetOffset((bodyAddon.drawnInBed || bodyAddon.alignWithHead) ? pawnAnimator.headFacing : rotation); - Vector3 a = (offset != null) ? offset.GetOffset(renderFlags.FlagSet(PawnRenderFlags.Portrait), pawn.story.bodyType, comp.crownType) : Vector3.zero; - AlienPartGenerator.RotationOffset offset2 = bodyAddon.offsets.GetOffset((bodyAddon.drawnInBed || bodyAddon.alignWithHead) ? pawnAnimator.headFacing : rotation); - Vector3 vector2 = a + ((offset2 != null) ? offset2.GetOffset(renderFlags.FlagSet(PawnRenderFlags.Portrait), pawn.story.bodyType, comp.crownType) : Vector3.zero); - vector2.y = (bodyAddon.inFrontOfBody ? (0.3f + vector2.y) : (-0.3f - vector2.y)); - float num = bodyAddon.angle; - if (rotation == Rot4.North) - { - if (bodyAddon.layerInvert) - { - vector2.y = -vector2.y; - } - num = 0f; - } - if (rotation == Rot4.East) - { - num = -num; - vector2.x = -vector2.x; - } - Graphic graphic = comp.addonGraphics[i]; - graphic.drawSize = ((renderFlags.FlagSet(PawnRenderFlags.Portrait) && bodyAddon.drawSizePortrait != Vector2.zero) ? bodyAddon.drawSizePortrait : bodyAddon.drawSize) * (bodyAddon.scaleWithPawnDrawsize ? (bodyAddon.alignWithHead ? (renderFlags.FlagSet(PawnRenderFlags.Portrait) ? comp.customPortraitHeadDrawSize : comp.customHeadDrawSize) : (renderFlags.FlagSet(PawnRenderFlags.Portrait) ? comp.customPortraitDrawSize : comp.customDrawSize)) : Vector2.one) * 1.5f; - GenDraw.DrawMeshNowOrLater(graphic.MeshAt(rotation), vector + (bodyAddon.alignWithHead ? headOffset : Vector3.zero) + vector2.RotatedBy(Mathf.Acos(Quaternion.Dot(Quaternion.identity, quat)) * 2f * 57.29578f), Quaternion.AngleAxis(num, Vector3.up) * quat, graphic.MatAt(rotation, null), renderFlags.FlagSet(PawnRenderFlags.DrawNow)); - } - } - - */ - - - CompBodyAnimator anim = pawn.TryGetComp(); - if (!renderFlags.FlagSet(PawnRenderFlags.Portrait) && anim.isAnimating) - { - //headOffset = anim.getPawnHeadOffset(); - quat = Quaternion.AngleAxis(anim.bodyAngle, Vector3.up); - } - - return true; - - - } } [HarmonyPatch(typeof(PawnGraphicSet), "ResolveApparelGraphics")]