This commit is contained in:
2025-12-06 11:28:06 +08:00
47 changed files with 100 additions and 315 deletions

View File

@@ -100,14 +100,13 @@
</BodyPartDef> </BodyPartDef>
<BodyPartDef> <BodyPartDef>
<defName>WULA_Mobile_Bunker_Bodypart</defName> <defName>WULA_Mobile_Bunker_Bodypart</defName>
<label>地堡</label> <label>地堡外壳</label>
<hitPoints>250</hitPoints> <hitPoints>250</hitPoints>
<permanentInjuryChanceFactor>0</permanentInjuryChanceFactor> <permanentInjuryChanceFactor>0</permanentInjuryChanceFactor>
<skinCovered>false</skinCovered> <skinCovered>false</skinCovered>
<!-- <solid>true</solid> --> <!-- <solid>true</solid> -->
<frostbiteVulnerability>1</frostbiteVulnerability> <frostbiteVulnerability>1</frostbiteVulnerability>
<bleedRate>0</bleedRate> <bleedRate>0</bleedRate>
<destroyableByDamage>false</destroyableByDamage>
</BodyPartDef> </BodyPartDef>
<BodyPartDef> <BodyPartDef>
<defName>WULA_Shield_Field_Maintainer_Bodypart</defName> <defName>WULA_Shield_Field_Maintainer_Bodypart</defName>

View File

@@ -1078,6 +1078,7 @@
<portraitPath>Wula/Events/Portraits/WULA_Legion_1</portraitPath> <portraitPath>Wula/Events/Portraits/WULA_Legion_1</portraitPath>
<characterName>「军团」,P.I.A</characterName> <characterName>「军团」,P.I.A</characterName>
<descriptions> <descriptions>
<li>要找活吗?</li>
</descriptions> </descriptions>
<conditionalDescriptions> <conditionalDescriptions>
<li> <li>

View File

@@ -38,7 +38,6 @@
<li Class="QuestNode_GetFaction"> <li Class="QuestNode_GetFaction">
<storeAs>siteFaction</storeAs> <storeAs>siteFaction</storeAs>
<allowEnemy>true</allowEnemy> <allowEnemy>true</allowEnemy>
<mustBeHostileToFactionOf>$asker</mustBeHostileToFactionOf>
<mustBePermanentEnemy>true</mustBePermanentEnemy> <mustBePermanentEnemy>true</mustBePermanentEnemy>
</li> </li>

View File

@@ -673,7 +673,7 @@
<ResearchProjectDef ParentName="WULAtechBase"> <ResearchProjectDef ParentName="WULAtechBase">
<defName>WULA_Building_Teleporter_Technology</defName> <defName>WULA_Building_Teleporter_Technology</defName>
<researchViewX>10.00</researchViewX> <researchViewX>10.00</researchViewX>
<researchViewY>2.70</researchViewY> <researchViewY>3.80</researchViewY>
<label>建筑传送许可</label> <label>建筑传送许可</label>
<description>允许通过传送将乌拉帝国的建筑直接传送到空投区,这使得建筑可以立刻部署到目标地点,且无视厚岩顶阻挡。</description> <description>允许通过传送将乌拉帝国的建筑直接传送到空投区,这使得建筑可以立刻部署到目标地点,且无视厚岩顶阻挡。</description>
<baseCost>2000</baseCost> <baseCost>2000</baseCost>

View File

@@ -73,7 +73,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WulaWall</buildingToSpawn> <buildingToSpawn>WulaWall</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -258,7 +258,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WulaDoor</buildingToSpawn> <buildingToSpawn>WulaDoor</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -429,7 +429,7 @@
<li>BuildingsMisc</li> <li>BuildingsMisc</li>
</thingCategories> </thingCategories>
<graphicData> <graphicData>
<texPath>Wula/Building/Linked/WulaWall/WulaWall_Atlas</texPath> <texPath>Wula/Building/Linked/WulaShelter/WulaShelter_Atlas</texPath>
<graphicClass>Graphic_Multi</graphicClass> <graphicClass>Graphic_Multi</graphicClass>
<drawSize>(1,1)</drawSize> <drawSize>(1,1)</drawSize>
<color>(73,185,254,155)</color> <color>(73,185,254,155)</color>
@@ -485,7 +485,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WulaShelter</buildingToSpawn> <buildingToSpawn>WulaShelter</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -660,7 +660,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_MaintenancePod</buildingToSpawn> <buildingToSpawn>WULA_MaintenancePod</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -865,7 +865,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_WeaponArmor_Productor</buildingToSpawn> <buildingToSpawn>WULA_WeaponArmor_Productor</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -1468,7 +1468,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_Machine_Recharger</buildingToSpawn> <buildingToSpawn>WULA_Machine_Recharger</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -1646,7 +1646,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_Charging_Station_Synth</buildingToSpawn> <buildingToSpawn>WULA_Charging_Station_Synth</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -1819,7 +1819,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_Cube_Productor</buildingToSpawn> <buildingToSpawn>WULA_Cube_Productor</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -2014,7 +2014,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_DarkEnergy_Generators</buildingToSpawn> <buildingToSpawn>Wula_DarkEnergy_Generators</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -2224,7 +2224,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_Fusion_Generators</buildingToSpawn> <buildingToSpawn>Wula_Fusion_Generators</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>

View File

@@ -75,7 +75,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_Sonar_Mine</buildingToSpawn> <buildingToSpawn>Wula_Sonar_Mine</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -338,7 +338,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>WULA_Cat_Bunker</buildingToSpawn> <buildingToSpawn>WULA_Cat_Bunker</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -606,7 +606,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_Base_ATGun_Turret</buildingToSpawn> <buildingToSpawn>Wula_Base_ATGun_Turret</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -907,7 +907,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_Base_Laser_Turret</buildingToSpawn> <buildingToSpawn>Wula_Base_Laser_Turret</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>
@@ -1210,7 +1210,7 @@
</li> </li>
<li Class="WulaFallenEmpire.CompProperties_BuildingSpawner"> <li Class="WulaFallenEmpire.CompProperties_BuildingSpawner">
<buildingToSpawn>Wula_Base_Mortar_Turret</buildingToSpawn> <buildingToSpawn>Wula_Base_Mortar_Turret</buildingToSpawn>
<destroyBuilding>true</destroyBuilding> <destroyBuilding>false</destroyBuilding>
<spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter> <spawnEffecter>WULA_Psi_Skip_Entry</spawnEffecter>
<spawnSound>VoidStructure_Emerge</spawnSound> <spawnSound>VoidStructure_Emerge</spawnSound>
<inheritFaction>true</inheritFaction> <inheritFaction>true</inheritFaction>

View File

@@ -74,6 +74,30 @@
<WULA_RequiresBuildingDropperFlyOver>需要拥有-建筑空投设施-的战舰部署在殖民地轨道上才能空投</WULA_RequiresBuildingDropperFlyOver> <WULA_RequiresBuildingDropperFlyOver>需要拥有-建筑空投设施-的战舰部署在殖民地轨道上才能空投</WULA_RequiresBuildingDropperFlyOver>
<WULA_MissingBuildingDropperFlyOver>没有拥有-建筑空投设施-的战舰部署在殖民地轨道上</WULA_MissingBuildingDropperFlyOver> <WULA_MissingBuildingDropperFlyOver>没有拥有-建筑空投设施-的战舰部署在殖民地轨道上</WULA_MissingBuildingDropperFlyOver>
<!-- 消息翻译 -->
<WULA_BuildingIncomingFromGlobal>从全局储存器中呼叫的建筑将在{0}后到达</WULA_BuildingIncomingFromGlobal>
<WULA_BuildingIncoming>呼叫的建筑将在{0}后到达</WULA_BuildingIncoming>
<WULA_MissingResearch>需要研究:{0}</WULA_MissingResearch>
<WULA_NoBuildingDropperFlyOver>需要建筑投放飞行器在区域上空</WULA_NoBuildingDropperFlyOver>
<!-- 屋顶阻挡消息 -->
<WULA_RoofBlocking_thick>厚重的屋顶阻挡了建筑投放</WULA_RoofBlocking_thick>
<WULA_RoofBlocking_thin>屋顶阻挡了建筑投放</WULA_RoofBlocking_thin>
<!-- 命令按钮 -->
<WULA_CancelBuilding>取消建筑呼叫</WULA_CancelBuilding>
<WULA_CancelBuildingDesc>取消正在呼叫的建筑投放</WULA_CancelBuildingDesc>
<WULA_TeleportBuilding>传送建筑</WULA_TeleportBuilding>
<WULA_TeleportBuildingDesc>使用乌拉帝国的传送网络,将{0}传送到指定位置——这是空投建筑的替代品,可以在厚岩顶下完成建造,并且响应速度更快。</WULA_TeleportBuildingDesc>
<WULA_NonPlayerCannotCall>非玩家派系无法手动呼叫建筑</WULA_NonPlayerCannotCall>
<WULA_RequiresResearch>需要研究:{0}</WULA_RequiresResearch>
<WULA_AutoBuildingArrivingIn>自动建筑将在{0}后到达</WULA_AutoBuildingArrivingIn>
<WULA_BuildingArrivingInFromGlobal>从全局储存器呼叫的建筑将在{0}后到达</WULA_BuildingArrivingInFromGlobal>
<WULA_BuildingArrivingIn>建筑将在{0}后到达</WULA_BuildingArrivingIn>
<WULA_AutoBuildingReady>自动建筑准备就绪</WULA_AutoBuildingReady>
<WULA_ReadyToCallBuilding>准备呼叫{0}</WULA_ReadyToCallBuilding>
<!-- 新增的空投资源来源相关翻译 --> <!-- 新增的空投资源来源相关翻译 -->
<WULA_ReadyToCallSkyfaller>准备召唤空投建筑</WULA_ReadyToCallSkyfaller> <WULA_ReadyToCallSkyfaller>准备召唤空投建筑</WULA_ReadyToCallSkyfaller>
<WULA_CallSkyfaller>召唤空投建筑</WULA_CallSkyfaller> <WULA_CallSkyfaller>召唤空投建筑</WULA_CallSkyfaller>
@@ -418,5 +442,5 @@
<WULA_Designator_CallSkyfallerInArea>区域空投</WULA_Designator_CallSkyfallerInArea> <WULA_Designator_CallSkyfallerInArea>区域空投</WULA_Designator_CallSkyfallerInArea>
<WULA_Designator_CallSkyfallerInAreaDesc>标记一块区域,激活其中所有需要空投的乌拉帝国建筑和战争机械体。\n\n区域空投依然需要计算材料消耗如果材料不足则不会进行空投。</WULA_Designator_CallSkyfallerInAreaDesc> <WULA_Designator_CallSkyfallerInAreaDesc>标记一块区域,激活其中所有需要空投的乌拉帝国建筑和战争机械体。\n\n区域空投依然需要计算材料消耗如果材料不足则不会进行空投。</WULA_Designator_CallSkyfallerInAreaDesc>
<WULA_AreaCallInitiated>区域空投已下达</WULA_AreaCallInitiated> <WULA_AreaCallInitiated>区域空投已下达</WULA_AreaCallInitiated>
<WULA_NoCallableBuildingsInArea>区域内没有可接受空投质量的乌拉帝国空投区</WULA_NoCallableBuildingsInArea> <WULA_NoCallableBuildingsInArea>区域内没有可接受空投指令的乌拉帝国空投区</WULA_NoCallableBuildingsInArea>
</LanguageData> </LanguageData>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 32 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 33 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 28 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 27 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 30 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 32 KiB

After

Width:  |  Height:  |  Size: 83 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 21 KiB

After

Width:  |  Height:  |  Size: 82 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 19 KiB

After

Width:  |  Height:  |  Size: 72 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.7 KiB

After

Width:  |  Height:  |  Size: 4.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 MiB

After

Width:  |  Height:  |  Size: 2.6 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.7 KiB

View File

@@ -79,8 +79,6 @@ namespace WulaFallenEmpire
} }
} }
Log.Message($"[BuildingSpawner] Found {allFlyOvers.Count} FlyOvers on map");
foreach (var thing in allFlyOvers) foreach (var thing in allFlyOvers)
{ {
if (thing is FlyOver flyOver && !flyOver.Destroyed) if (thing is FlyOver flyOver && !flyOver.Destroyed)
@@ -94,13 +92,11 @@ namespace WulaFallenEmpire
if (facilitiesComp.HasFacility("BuildingdropperFacility")) if (facilitiesComp.HasFacility("BuildingdropperFacility"))
{ {
Log.Message($"[BuildingSpawner] Found valid FlyOver at {flyOver.Position} with BuildingdropperFacility");
return true; return true;
} }
} }
} }
Log.Message("[BuildingSpawner] No FlyOver with BuildingdropperFacility found");
return false; return false;
} }
catch (System.Exception ex) catch (System.Exception ex)
@@ -146,8 +142,6 @@ namespace WulaFallenEmpire
autoCallScheduled = true; autoCallScheduled = true;
callTick = Find.TickManager.TicksGame + Props.autoCallDelayTicks; callTick = Find.TickManager.TicksGame + Props.autoCallDelayTicks;
calling = true; calling = true;
Log.Message($"[BuildingSpawner] Scheduled auto-call for non-player building {parent.Label} at tick {callTick}");
} }
} }
@@ -195,8 +189,6 @@ namespace WulaFallenEmpire
{ {
try try
{ {
Log.Message($"[BuildingSpawner] Executing auto building spawn for non-player building at {parent.Position}");
if (Props.buildingToSpawn == null) if (Props.buildingToSpawn == null)
{ {
Log.Error("[BuildingSpawner] Building def is null!"); Log.Error("[BuildingSpawner] Building def is null!");
@@ -246,10 +238,6 @@ namespace WulaFallenEmpire
// 重置状态 // 重置状态
ResetCall(); ResetCall();
autoCallScheduled = false; autoCallScheduled = false;
// 显示消息
Messages.Message("WULA_AutoBuildingSpawned".Translate(Props.buildingToSpawn.label, parent.Faction.Name),
MessageTypeDefOf.NeutralEvent);
} }
catch (System.Exception ex) catch (System.Exception ex)
{ {
@@ -264,7 +252,6 @@ namespace WulaFallenEmpire
// 非玩家派系不能手动呼叫 // 非玩家派系不能手动呼叫
if (IsNonPlayerFaction && !isAutoCall) if (IsNonPlayerFaction && !isAutoCall)
{ {
Messages.Message("WULA_NonPlayerCannotCall".Translate(), parent, MessageTypeDefOf.RejectInput);
return; return;
} }
@@ -274,8 +261,6 @@ namespace WulaFallenEmpire
return; return;
} }
Log.Message($"[BuildingSpawner] Starting building spawn from {parent.Label} at {parent.Position}");
calling = true; calling = true;
used = true; used = true;
int delay = isAutoCall ? Props.autoCallDelayTicks : Props.delayTicks; int delay = isAutoCall ? Props.autoCallDelayTicks : Props.delayTicks;
@@ -329,8 +314,6 @@ namespace WulaFallenEmpire
// 执行建筑生成 // 执行建筑生成
protected virtual void ExecuteBuildingSpawn() protected virtual void ExecuteBuildingSpawn()
{ {
Log.Message($"[BuildingSpawner] Executing building spawn at {parent.Position}");
if (Props.buildingToSpawn == null) if (Props.buildingToSpawn == null)
{ {
Log.Error("[BuildingSpawner] Building def is null!"); Log.Error("[BuildingSpawner] Building def is null!");
@@ -341,7 +324,6 @@ namespace WulaFallenEmpire
var resourceCheck = CheckAndConsumeMaterials(); var resourceCheck = CheckAndConsumeMaterials();
if (!resourceCheck.HasEnoughMaterials) if (!resourceCheck.HasEnoughMaterials)
{ {
Log.Message($"[BuildingSpawner] Aborting building spawn due to insufficient materials.");
ResetCall(); ResetCall();
return; return;
} }
@@ -426,7 +408,6 @@ namespace WulaFallenEmpire
if (roof != null && !roof.isThickRoof && Props.allowThinRoof) if (roof != null && !roof.isThickRoof && Props.allowThinRoof)
{ {
Log.Message($"[BuildingSpawner] Destroying thin roof at {targetPos}");
parent.Map.roofGrid.SetRoof(targetPos, null); parent.Map.roofGrid.SetRoof(targetPos, null);
// 生成屋顶破坏效果 // 生成屋顶破坏效果
@@ -510,9 +491,6 @@ namespace WulaFallenEmpire
powerComp.PowerOn = true; powerComp.PowerOn = true;
} }
} }
// 记录日志
Log.Message($"[BuildingSpawner] Successfully spawned {Props.buildingToSpawn.label} at {newBuilding.Position}");
} }
// 资源管理与SkyfallerCaller类似 // 资源管理与SkyfallerCaller类似
@@ -824,7 +802,6 @@ namespace WulaFallenEmpire
callTick = -1; callTick = -1;
usedGlobalStorage = false; usedGlobalStorage = false;
autoCallScheduled = false; autoCallScheduled = false;
Messages.Message("WULA_BuildingCallCancelled".Translate(), parent, MessageTypeDefOf.NeutralEvent);
} }
public override IEnumerable<Gizmo> CompGetGizmosExtra() public override IEnumerable<Gizmo> CompGetGizmosExtra()
@@ -853,9 +830,9 @@ namespace WulaFallenEmpire
string reason = GetDisabledReason(); string reason = GetDisabledReason();
Command_Action callCommand = new Command_Action Command_Action callCommand = new Command_Action
{ {
defaultLabel = "WULA_CallBuilding".Translate(), defaultLabel = "WULA_TeleportBuilding".Translate(),
defaultDesc = GetCallDescription(), defaultDesc = GetCallDescription(),
icon = ContentFinder<Texture2D>.Get("Wula/UI/Commands/WULA_SpawnBuilding"), icon = ContentFinder<Texture2D>.Get("Wula/UI/Commands/WULA_TeleportBuilding"),
action = () => CallBuilding(false), action = () => CallBuilding(false),
disabledReason = reason disabledReason = reason
}; };
@@ -904,7 +881,7 @@ namespace WulaFallenEmpire
private string GetCallDescription() private string GetCallDescription()
{ {
var sb = new StringBuilder(); var sb = new StringBuilder();
sb.Append("WULA_CallBuildingDesc".Translate(Props.buildingToSpawn.label)); sb.Append("WULA_TeleportBuildingDesc".Translate(Props.buildingToSpawn.label));
if (Props.requiredResearch != null) if (Props.requiredResearch != null)
{ {
@@ -932,117 +909,7 @@ namespace WulaFallenEmpire
} }
} }
string costString = GetCostString();
if (!string.IsNullOrEmpty(costString))
{
sb.AppendLine().AppendLine().Append("WULA_RequiredMaterials".Translate());
sb.Append(costString);
}
return sb.ToString(); return sb.ToString();
} }
// 获取成本字符串
private string GetCostString()
{
var costList = CostList;
if (costList.NullOrEmpty())
{
return "";
}
var sb = new StringBuilder();
foreach (var cost in costList)
{
sb.AppendLine($" - {cost.thingDef.LabelCap}: {cost.count}");
}
return sb.ToString();
}
// 检查字符串
public override string CompInspectStringExtra()
{
if (parent?.Map == null)
{
return base.CompInspectStringExtra();
}
var sb = new StringBuilder();
// 显示自动呼叫状态
if (autoCallScheduled && calling)
{
int ticksLeft = callTick - Find.TickManager.TicksGame;
sb.Append("WULA_AutoBuildingArrivingIn".Translate(ticksLeft.ToStringTicksToPeriod()));
}
else if (calling)
{
int ticksLeft = callTick - Find.TickManager.TicksGame;
if (ticksLeft > 0)
{
string messageKey = usedGlobalStorage ?
"WULA_BuildingArrivingInFromGlobal" :
"WULA_BuildingArrivingIn";
sb.Append(messageKey.Translate(ticksLeft.ToStringTicksToPeriod()));
}
}
else if (!used)
{
if (IsNonPlayerFaction && Props.canAutoCall)
{
sb.Append("WULA_AutoBuildingReady".Translate());
}
else
{
sb.Append("WULA_ReadyToCallBuilding".Translate(Props.buildingToSpawn.label));
}
// 显示科技需求
if (Props.requiredResearch != null && !HasRequiredResearch)
{
sb.AppendLine().Append("WULA_MissingResearch".Translate(Props.requiredResearch.label));
}
// 显示FlyOver需求
if (Props.requireFlyOver && !HasRequiredFlyOver)
{
sb.AppendLine().Append("WULA_MissingBuildingDropperFlyOver".Translate());
}
// 显示屋顶状态
RoofDef roof = parent.Position.GetRoof(parent.Map);
if (roof != null)
{
if (roof.isThickRoof && !Props.allowThickRoof)
{
sb.AppendLine().Append("WULA_BlockedByThickRoof".Translate());
}
else if (!roof.isThickRoof && !Props.allowThinRoof)
{
sb.AppendLine().Append("WULA_BlockedByRoof".Translate());
}
}
// 显示成本
string costString = GetCostString();
if (!string.IsNullOrEmpty(costString))
{
sb.AppendLine().AppendLine("WULA_RequiredMaterials".Translate());
sb.Append(costString);
}
}
string baseInspectString = base.CompInspectStringExtra();
if (!string.IsNullOrEmpty(baseInspectString))
{
if (sb.Length > 0)
{
sb.AppendLine();
}
sb.Append(baseInspectString);
}
return sb.Length > 0 ? sb.ToString().TrimEnd() : null;
}
} }
} }

View File

@@ -10,22 +10,18 @@ namespace WulaFallenEmpire
{ {
// 记录已经处理过的建筑(避免重复) // 记录已经处理过的建筑(避免重复)
private HashSet<Thing> processedBuildings = new HashSet<Thing>(); private HashSet<Thing> processedBuildings = new HashSet<Thing>();
// 组件类型过滤
public bool includeBuildingSpawner = true;
public bool includeSkyfallerCaller = true;
public Designator_CallSkyfallerInArea() public Designator_CallSkyfallerInArea()
{ {
defaultLabel = "WULA_Designator_CallInArea".Translate(); defaultLabel = "WULA_Designator_CallSkyfallerInArea".Translate();
defaultDesc = "WULA_Designator_CallInAreaDesc".Translate(); defaultDesc = "WULA_Designator_CallSkyfallerInAreaDesc".Translate();
icon = ContentFinder<Texture2D>.Get("Wula/UI/Designators/Designator_CallInArea"); icon = ContentFinder<Texture2D>.Get("Wula/UI/Designators/Designator_CallSkyfallerInArea");
soundDragSustain = SoundDefOf.Designate_DragStandard; soundDragSustain = SoundDefOf.Designate_DragStandard;
soundDragChanged = SoundDefOf.Designate_DragStandard_Changed; soundDragChanged = SoundDefOf.Designate_DragStandard_Changed;
useMouseIcon = true; useMouseIcon = true;
soundSucceeded = SoundDefOf.Designate_Claim; soundSucceeded = SoundDefOf.Designate_Claim;
hotKey = KeyBindingDefOf.Misc12; hotKey = KeyBindingDefOf.Misc12;
tutorTag = "CallInArea"; tutorTag = "CallSkyfallerInArea";
} }
public override DrawStyleCategoryDef DrawStyleCategory => DrawStyleCategoryDefOf.FilledRectangle; public override DrawStyleCategoryDef DrawStyleCategory => DrawStyleCategoryDefOf.FilledRectangle;
@@ -39,13 +35,13 @@ namespace WulaFallenEmpire
if (c.Fogged(Map)) if (c.Fogged(Map))
return false; return false;
// 检查单元格内是否有符合条件的玩家建筑 // 只要单元格内有玩家建筑,就允许选择
var things = Map.thingGrid.ThingsListAt(c); var things = Map.thingGrid.ThingsListAt(c);
foreach (var thing in things) foreach (var thing in things)
{ {
if (thing.def.category == ThingCategory.Building && if (thing.def.category == ThingCategory.Building &&
thing.Faction == Faction.OfPlayer && thing.Faction == Faction.OfPlayer &&
HasValidComponent(thing)) thing.TryGetComp<CompSkyfallerCaller>() != null)
{ {
return true; return true;
} }
@@ -54,28 +50,6 @@ namespace WulaFallenEmpire
// 即使单元格内没有符合条件的建筑,也允许选择(这样用户可以拖动区域) // 即使单元格内没有符合条件的建筑,也允许选择(这样用户可以拖动区域)
return true; return true;
} }
// 检查建筑是否有有效的组件
private bool HasValidComponent(Thing thing)
{
// 检查 Building Spawner 组件
if (includeBuildingSpawner)
{
var buildingSpawner = thing.TryGetComp<CompBuildingSpawner>();
if (buildingSpawner != null && buildingSpawner.CanCallBuilding)
return true;
}
// 检查 Skyfaller Caller 组件
if (includeSkyfallerCaller)
{
var skyfallerCaller = thing.TryGetComp<CompSkyfallerCaller>();
if (skyfallerCaller != null && skyfallerCaller.CanCallSkyfaller)
return true;
}
return false;
}
public override void DesignateSingleCell(IntVec3 c) public override void DesignateSingleCell(IntVec3 c)
{ {
@@ -89,53 +63,32 @@ namespace WulaFallenEmpire
processedBuildings.Clear(); processedBuildings.Clear();
int totalBuildings = 0; int totalBuildings = 0;
int buildingSpawnerCount = 0;
int skyfallerCallerCount = 0;
// 处理所有选中的单元格 // 处理所有选中的单元格
foreach (var cell in cells) foreach (var cell in cells)
{ {
if (cell.InBounds(Map)) if (cell.InBounds(Map))
{ {
// 统计该单元格处理的建筑数量
int cellCount = processedBuildings.Count; int cellCount = processedBuildings.Count;
ProcessCell(cell); ProcessCell(cell);
int newBuildings = processedBuildings.Count - cellCount; int newBuildings = processedBuildings.Count - cellCount;
// 统计每个组件类型的调用数量
foreach (var building in processedBuildings)
{
if (building.Destroyed) continue;
if (building.TryGetComp<CompBuildingSpawner>()?.calling == true)
buildingSpawnerCount++;
else if (building.TryGetComp<CompSkyfallerCaller>()?.calling == true)
skyfallerCallerCount++;
}
totalBuildings += newBuildings; totalBuildings += newBuildings;
} }
} }
// 显示结果消息 // 计算成功和失败的数量
// 这里需要跟踪每个建筑的调用结果
// 由于我们直接调用CallSkyfaller需要知道哪些失败了
// 简化处理在ProcessCell中统计
// 显示简单的结果消息
if (totalBuildings > 0) if (totalBuildings > 0)
{ {
string message = "WULA_AreaCallInitiated".Translate(totalBuildings); Messages.Message("WULA_AreaCallInitiated".Translate(totalBuildings),
MessageTypeDefOf.PositiveEvent);
if (buildingSpawnerCount > 0 && skyfallerCallerCount > 0)
{
message += "\n" + "WULA_BothComponentsCalled".Translate(
buildingSpawnerCount, skyfallerCallerCount);
}
else if (buildingSpawnerCount > 0)
{
message += "\n" + "WULA_BuildingSpawnerCalled".Translate(buildingSpawnerCount);
}
else if (skyfallerCallerCount > 0)
{
message += "\n" + "WULA_SkyfallerCallerCalled".Translate(skyfallerCallerCount);
}
Messages.Message(message, MessageTypeDefOf.PositiveEvent);
} }
else else
{ {
@@ -162,44 +115,21 @@ namespace WulaFallenEmpire
if (processedBuildings.Contains(thing)) if (processedBuildings.Contains(thing))
continue; continue;
// 标记为已处理 // 获取空投组件
processedBuildings.Add(thing); var comp = thing.TryGetComp<CompSkyfallerCaller>();
if (comp == null)
continue;
// 尝试调用两种组件(如果有且可以调用) // 尝试呼叫空投
bool anyCalled = false; if (comp.CanCallSkyfaller)
// 1. 先尝试 Building Spawner
if (includeBuildingSpawner)
{ {
var buildingSpawner = thing.TryGetComp<CompBuildingSpawner>(); comp.CallSkyfaller(false);
if (buildingSpawner != null && buildingSpawner.CanCallBuilding) processedBuildings.Add(thing);
{
buildingSpawner.CallBuilding(false);
anyCalled = true;
// 如果建筑被销毁,记录日志
if (thing.Destroyed)
{
Log.Message($"[Designator] Building destroyed after BuildingSpawner call at {cell}");
}
}
} }
// 即使不能呼叫,也添加到已处理列表,避免重复尝试
// 2. 尝试 Skyfaller Caller如果建筑还存在 else
if (!thing.Destroyed && includeSkyfallerCaller)
{ {
var skyfallerCaller = thing.TryGetComp<CompSkyfallerCaller>(); processedBuildings.Add(thing);
if (skyfallerCaller != null && skyfallerCaller.CanCallSkyfaller)
{
skyfallerCaller.CallSkyfaller(false);
anyCalled = true;
}
}
// 如果没有任何组件被调用,从处理列表中移除(防止重复尝试)
if (!anyCalled)
{
processedBuildings.Remove(thing);
} }
} }
} }
@@ -213,43 +143,20 @@ namespace WulaFallenEmpire
if (t.Faction != Faction.OfPlayer) if (t.Faction != Faction.OfPlayer)
return false; return false;
return HasValidComponent(t); var comp = t.TryGetComp<CompSkyfallerCaller>();
if (comp == null)
return false;
return true;
} }
public override void DesignateThing(Thing t) public override void DesignateThing(Thing t)
{ {
// 用于反向设计器(右键菜单) // 用于反向设计器(右键菜单)
processedBuildings.Add(t); var comp = t.TryGetComp<CompSkyfallerCaller>();
if (comp != null && comp.CanCallSkyfaller)
// 尝试调用两种组件
bool anyCalled = false;
// 1. 先尝试 Building Spawner
if (includeBuildingSpawner)
{ {
var buildingSpawner = t.TryGetComp<CompBuildingSpawner>(); comp.CallSkyfaller(false);
if (buildingSpawner != null && buildingSpawner.CanCallBuilding)
{
buildingSpawner.CallBuilding(false);
anyCalled = true;
}
}
// 2. 尝试 Skyfaller Caller如果建筑还存在
if (!t.Destroyed && includeSkyfallerCaller)
{
var skyfallerCaller = t.TryGetComp<CompSkyfallerCaller>();
if (skyfallerCaller != null && skyfallerCaller.CanCallSkyfaller)
{
skyfallerCaller.CallSkyfaller(false);
anyCalled = true;
}
}
if (!anyCalled)
{
Messages.Message("WULA_NoComponentCanCall".Translate(),
t, MessageTypeDefOf.RejectInput);
} }
} }
@@ -257,32 +164,6 @@ namespace WulaFallenEmpire
{ {
// 参考Designator_Deconstruct只绘制鼠标悬停方框 // 参考Designator_Deconstruct只绘制鼠标悬停方框
GenUI.RenderMouseoverBracket(); GenUI.RenderMouseoverBracket();
// 可以添加额外的视觉效果来显示哪些建筑将被影响
if (Find.DesignatorManager.SelectedDesignator == this)
{
DrawAffectedBuildings();
} }
} }
}
// 绘制受影响的建筑
private void DrawAffectedBuildings()
{
if (Map == null) return;
// 这里可以绘制高亮显示哪些建筑会被影响
// 但由于性能考虑,只在特定条件下绘制
if (DebugSettings.godMode)
{
foreach (var building in Map.listerBuildings.allBuildingsColonist)
{
if (HasValidComponent(building))
{
GenDraw.DrawFieldEdges(new List<IntVec3> { building.Position },
building.Destroyed ? Color.red : Color.green);
}
}
}
}
}
}

View File

@@ -164,12 +164,24 @@ namespace WulaFallenEmpire
private static void AddQuad(LayerSubMesh sm, Vector3 c, float scale, float altitude, Color color) private static void AddQuad(LayerSubMesh sm, Vector3 c, float scale, float altitude, Color color)
{ {
int count = sm.verts.Count; int count = sm.verts.Count;
// 添加微小的UV偏移来避免单像素黑边
const float uvOffset = 0.001f;
Vector2[] adjustedUVs = new Vector2[]
{
new Vector2(uvOffset, uvOffset),
new Vector2(uvOffset, 1f - uvOffset),
new Vector2(1f - uvOffset, 1f - uvOffset),
new Vector2(1f - uvOffset, uvOffset)
};
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
sm.verts.Add(new Vector3(c.x + UVs[i].x * scale, altitude, c.z + UVs[i].y * scale)); sm.verts.Add(new Vector3(c.x + UVs[i].x * scale, altitude, c.z + UVs[i].y * scale));
sm.uvs.Add(UVs[i % 4]); sm.uvs.Add(adjustedUVs[i]); // 使用调整后的UV坐标
sm.colors.Add(color); sm.colors.Add(color);
} }
sm.tris.Add(count); sm.tris.Add(count);
sm.tris.Add(count + 1); sm.tris.Add(count + 1);
sm.tris.Add(count + 2); sm.tris.Add(count + 2);
@@ -178,6 +190,7 @@ namespace WulaFallenEmpire
sm.tris.Add(count + 3); sm.tris.Add(count + 3);
} }
private static bool IsCornerIndoorMasked(IntVec3 c, CornerType cornerType, Map map) private static bool IsCornerIndoorMasked(IntVec3 c, CornerType cornerType, Map map)
{ {
switch (cornerType) switch (cornerType)

View File

@@ -269,6 +269,7 @@
<Compile Include="QuestNodes\QuestNode_Hyperlinks.cs" /> <Compile Include="QuestNodes\QuestNode_Hyperlinks.cs" />
<Compile Include="QuestNodes\QuestNode_SpawnPrefabSkyfallerCaller.cs" /> <Compile Include="QuestNodes\QuestNode_SpawnPrefabSkyfallerCaller.cs" />
<Compile Include="QuestNodes\QuestPart_GlobalResourceCheck.cs" /> <Compile Include="QuestNodes\QuestPart_GlobalResourceCheck.cs" />
<Compile Include="SectionLayer_WulaHull.cs" />
<Compile Include="Stat\StatWorker_Energy.cs" /> <Compile Include="Stat\StatWorker_Energy.cs" />
<Compile Include="Stat\StatWorker_Maintenance.cs" /> <Compile Include="Stat\StatWorker_Maintenance.cs" />
<Compile Include="Stat\StatWorker_NanoRepair.cs" /> <Compile Include="Stat\StatWorker_NanoRepair.cs" />

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

After

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.7 KiB