Changed Local Global Props to be based on Main Path Extender
This commit is contained in:
parent
7b4977c131
commit
075f3b5d85
|
@ -9,6 +9,7 @@ using DunGen.Graph;
|
||||||
using DunGenPlus.Generation;
|
using DunGenPlus.Generation;
|
||||||
using LethalLevelLoader;
|
using LethalLevelLoader;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
using static DunGenPlus.Components.DoorwayCleanupScripting.DCSConnectorBlockerSpawnedPrefab;
|
||||||
|
|
||||||
namespace DunGenPlus
|
namespace DunGenPlus
|
||||||
{
|
{
|
||||||
|
@ -128,6 +129,8 @@ namespace DunGenPlus
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// DO NOT USE!
|
/// DO NOT USE!
|
||||||
|
///
|
||||||
|
/// Registers the connection between <see cref="TileProxy"/> to <see cref="Tile"/> that's specifically created during <see cref="DunGen.Dungeon.FromProxy(DungeonProxy, DungeonGenerator)"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="dictionary"></param>
|
/// <param name="dictionary"></param>
|
||||||
public static void AddTileToMainPathDictionary(Dictionary<TileProxy, Tile> dictionary){
|
public static void AddTileToMainPathDictionary(Dictionary<TileProxy, Tile> dictionary){
|
||||||
|
|
|
@ -17,8 +17,7 @@ namespace DunGenPlus.Collections {
|
||||||
internal const string MainRoomTilePrefabTooltip = "The Tile prefab where the additional main paths will start from.\n\nCannot be null if MainPathCount is more than 1.";
|
internal const string MainRoomTilePrefabTooltip = "The Tile prefab where the additional main paths will start from.\n\nCannot be null if MainPathCount is more than 1.";
|
||||||
internal const string CopyNodeBehaviourTooltip = "Defines how the nodes list is copied onto the additional main paths.\n\nCopyFromMainPathPosition: nodes will copy based on the MainRoomTilePrefab's position in the main path.\nCopyFromNodeList: nodes will copy based on the MainRoomTilePrefab's position in the node list + 1.";
|
internal const string CopyNodeBehaviourTooltip = "Defines how the nodes list is copied onto the additional main paths.\n\nCopyFromMainPathPosition: nodes will copy based on the MainRoomTilePrefab's position in the main path.\nCopyFromNodeList: nodes will copy based on the MainRoomTilePrefab's position in the node list + 1.";
|
||||||
internal const string MainPathDetailsTooltip = "Overrides certain DungeonFlow values during the main path generation.\n\nThe order of items in this list correspond to the order of the main paths being generated.\nThe first item in this list will activate for the first main path, the second item for the second main path, and so on. If there are more main paths than items in this list, the last item is used instead.";
|
internal const string MainPathDetailsTooltip = "Overrides certain DungeonFlow values during the main path generation.\n\nThe order of items in this list correspond to the order of the main paths being generated.\nThe first item in this list will activate for the first main path, the second item for the second main path, and so on. If there are more main paths than items in this list, the last item is used instead.";
|
||||||
internal const string LocalMainPathGlobalPropsTooltip = "Limits the amount of Global Props that can spawn on a single main path.\n\nThis does not afffect the global limit defined in DungeonFlow.";
|
|
||||||
|
|
||||||
|
|
||||||
[Tooltip(MainPathCountTooltip)]
|
[Tooltip(MainPathCountTooltip)]
|
||||||
[Range(1, 9)]
|
[Range(1, 9)]
|
||||||
|
@ -29,8 +28,6 @@ namespace DunGenPlus.Collections {
|
||||||
public CopyNodeBehaviour CopyNodeBehaviour = CopyNodeBehaviour.CopyFromMainPathPosition;
|
public CopyNodeBehaviour CopyNodeBehaviour = CopyNodeBehaviour.CopyFromMainPathPosition;
|
||||||
[Tooltip(MainPathDetailsTooltip)]
|
[Tooltip(MainPathDetailsTooltip)]
|
||||||
public List<MainPathExtender> MainPathDetails = new List<MainPathExtender>();
|
public List<MainPathExtender> MainPathDetails = new List<MainPathExtender>();
|
||||||
[Tooltip(LocalMainPathGlobalPropsTooltip)]
|
|
||||||
public List<DungeonFlow.GlobalPropSettings> LocalMainPathGlobalProps = new List<DungeonFlow.GlobalPropSettings>();
|
|
||||||
|
|
||||||
public MainPathExtender GetMainPathDetails(int index) {
|
public MainPathExtender GetMainPathDetails(int index) {
|
||||||
var count = MainPathDetails.Count;
|
var count = MainPathDetails.Count;
|
||||||
|
@ -44,7 +41,6 @@ namespace DunGenPlus.Collections {
|
||||||
MainRoomTilePrefab = props.MainRoomTilePrefab;
|
MainRoomTilePrefab = props.MainRoomTilePrefab;
|
||||||
CopyNodeBehaviour = props.CopyNodeBehaviour;
|
CopyNodeBehaviour = props.CopyNodeBehaviour;
|
||||||
MainPathDetails = props.MainPathDetails;
|
MainPathDetails = props.MainPathDetails;
|
||||||
LocalMainPathGlobalProps = props.LocalMainPathGlobalProps;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal MainPathProperties Copy() {
|
internal MainPathProperties Copy() {
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
using DunGen;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
|
namespace DunGenPlus.Collections {
|
||||||
|
[System.Serializable]
|
||||||
|
public class LocalGlobalPropSettings {
|
||||||
|
|
||||||
|
internal const string GlobalPropLimitTooltip = "If true, when PostProcess reaches the local limit of Global Props for all main paths but does not reach the global limit, use the remaining props in this main path to reach the global limit.";
|
||||||
|
|
||||||
|
public int ID;
|
||||||
|
public IntRange Count;
|
||||||
|
[Tooltip(GlobalPropLimitTooltip)]
|
||||||
|
public bool UseToReachGlobalPropLimit;
|
||||||
|
|
||||||
|
public LocalGlobalPropSettings(int id, IntRange count, bool useToReachGlobalPropLimit) {
|
||||||
|
ID = id;
|
||||||
|
Count = count;
|
||||||
|
UseToReachGlobalPropLimit = useToReachGlobalPropLimit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -134,6 +134,7 @@
|
||||||
<Compile Include="Collections\DunGenExtenderPropertiesCollection.cs" />
|
<Compile Include="Collections\DunGenExtenderPropertiesCollection.cs" />
|
||||||
<Compile Include="Collections\ExtenderEvent.cs" />
|
<Compile Include="Collections\ExtenderEvent.cs" />
|
||||||
<Compile Include="Collections\ForcedTileSetList.cs" />
|
<Compile Include="Collections\ForcedTileSetList.cs" />
|
||||||
|
<Compile Include="Collections\LocalGlobalPropSettings.cs" />
|
||||||
<Compile Include="Collections\NodeArchetype.cs" />
|
<Compile Include="Collections\NodeArchetype.cs" />
|
||||||
<Compile Include="Collections\NullObject.cs" />
|
<Compile Include="Collections\NullObject.cs" />
|
||||||
<Compile Include="Components\DoorwayCleanup.cs" />
|
<Compile Include="Components\DoorwayCleanup.cs" />
|
||||||
|
|
Binary file not shown.
|
@ -126,6 +126,8 @@ namespace DunGenPlus.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void AddTileToMainPathDictionary(Dictionary<TileProxy, Tile> dictionary){
|
public static void AddTileToMainPathDictionary(Dictionary<TileProxy, Tile> dictionary){
|
||||||
|
if (!DunGenPlusGenerator.Active) return;
|
||||||
|
|
||||||
foreach(var pair in dictionary){
|
foreach(var pair in dictionary){
|
||||||
tileMainPath.Add(pair.Value, GetMainPathIndexFromTileProxy(pair.Key));
|
tileMainPath.Add(pair.Value, GetMainPathIndexFromTileProxy(pair.Key));
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,7 +98,7 @@ namespace DunGenPlus.Generation {
|
||||||
|
|
||||||
// Copied and pasted from DunGen
|
// Copied and pasted from DunGen
|
||||||
public static void ProcessGlobalPropsPerMainPath(DungeonGenerator dungeonGenerator){
|
public static void ProcessGlobalPropsPerMainPath(DungeonGenerator dungeonGenerator){
|
||||||
var localIDs = Properties.MainPathProperties.LocalMainPathGlobalProps.Select(x => x.ID).ToHashSet();
|
var localIDs = Properties.MainPathProperties.MainPathDetails.SelectMany(d => d.LocalGroupProps).Select(x => x.ID).ToHashSet();
|
||||||
|
|
||||||
// first parameter int is the GlobalProp ID
|
// first parameter int is the GlobalProp ID
|
||||||
// second parameter is the List of GameObjectChanceTable indexed by the main path index
|
// second parameter is the List of GameObjectChanceTable indexed by the main path index
|
||||||
|
@ -166,6 +166,19 @@ namespace DunGenPlus.Generation {
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int ProcessRemainingGlobalPropID(GameObjectChanceTable[] tables, int count){
|
||||||
|
count = Mathf.Clamp(count, 0, tables.Sum(t => t.Weights.Count));
|
||||||
|
var i = 0;
|
||||||
|
while(i < count){
|
||||||
|
var random = GameObjectChanceTable.GetCombinedRandom(dungeonGenerator.RandomStream, true, 0f, tables);
|
||||||
|
if (random != null) {
|
||||||
|
random.SetActive(true);
|
||||||
|
}
|
||||||
|
++i;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
using(var enumerator = globalDictionary.GetEnumerator()){
|
using(var enumerator = globalDictionary.GetEnumerator()){
|
||||||
while(enumerator.MoveNext()){
|
while(enumerator.MoveNext()){
|
||||||
var pair = enumerator.Current;
|
var pair = enumerator.Current;
|
||||||
|
@ -178,12 +191,12 @@ namespace DunGenPlus.Generation {
|
||||||
.Where(x => x.ID == pair.Key)
|
.Where(x => x.ID == pair.Key)
|
||||||
.FirstOrDefault();
|
.FirstOrDefault();
|
||||||
|
|
||||||
if (globalPropSettings != null){
|
if (globalPropSettings != null){
|
||||||
var tableClone = pair.Value.Clone();
|
var tableClone = pair.Value.Clone();
|
||||||
var globalMax = globalPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
var globalMax = globalPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
||||||
|
|
||||||
var spawned = ProcessGlobalPropID(tableClone, globalMax, 0, globalMax);
|
var spawned = ProcessGlobalPropID(tableClone, globalMax, 0, globalMax);
|
||||||
//Plugin.logger.LogError($"Spawned {spawned} ({spawned}/{globalMax})");
|
Plugin.logger.LogDebug($"Global ID: {pair.Key} ({spawned} / {globalMax})");
|
||||||
list.Add(pair.Key);
|
list.Add(pair.Key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -193,29 +206,65 @@ namespace DunGenPlus.Generation {
|
||||||
using(var enumerator = localDictionary.GetEnumerator()){
|
using(var enumerator = localDictionary.GetEnumerator()){
|
||||||
while(enumerator.MoveNext()){
|
while(enumerator.MoveNext()){
|
||||||
var pair = enumerator.Current;
|
var pair = enumerator.Current;
|
||||||
if (list.Contains(pair.Key)){
|
var globalPropId = pair.Key;
|
||||||
|
if (list.Contains(globalPropId)){
|
||||||
Plugin.logger.LogWarning("Dungeon Flow contains multiple entries for the global prop group ID: " + pair.Key.ToString() + ". Only the first entry will be used.");
|
Plugin.logger.LogWarning("Dungeon Flow contains multiple entries for the global prop group ID: " + pair.Key.ToString() + ". Only the first entry will be used.");
|
||||||
} else {
|
} else {
|
||||||
//Plugin.logger.LogWarning($"{pair.Key}: Local");
|
//Plugin.logger.LogWarning($"{pair.Key}: Local");
|
||||||
|
|
||||||
var globalPropSettings = dungeonGenerator.DungeonFlow.GlobalProps
|
var globalPropSettings = dungeonGenerator.DungeonFlow.GlobalProps
|
||||||
.Where(x => x.ID == pair.Key)
|
.Where(x => x.ID == globalPropId)
|
||||||
.FirstOrDefault();
|
.FirstOrDefault();
|
||||||
var localPropSettings = Properties.MainPathProperties.LocalMainPathGlobalProps
|
|
||||||
.Where(x => x.ID == pair.Key)
|
if (globalPropSettings != null){
|
||||||
.FirstOrDefault();
|
|
||||||
|
|
||||||
if (globalPropSettings != null && localPropSettings != null){
|
|
||||||
var globalCount = 0;
|
var globalCount = 0;
|
||||||
foreach(var path in pair.Value.Values){
|
var globalMax = globalPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
||||||
var tableClone = path.Clone();
|
var pathDictionary = pair.Value;
|
||||||
var globalMax = globalPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
Plugin.logger.LogDebug($"Local ID: {pair.Key} (Max {globalMax})");
|
||||||
|
|
||||||
|
var toRemoveKeys = new List<int>();
|
||||||
|
|
||||||
|
foreach(var pathPair in pathDictionary){
|
||||||
|
// try and get local main path properites based on key of Dictionary<MainPathIndex (int), GlobalProps (GameObjectChanceTable)>
|
||||||
|
var mainPathIndex = pathPair.Key;
|
||||||
|
var localGroupProps = Properties.MainPathProperties.GetMainPathDetails(mainPathIndex).LocalGroupProps;
|
||||||
|
var localPropSettings = localGroupProps
|
||||||
|
.Where(x => x.ID == globalPropId)
|
||||||
|
.FirstOrDefault();
|
||||||
|
|
||||||
|
if (localPropSettings == null) {
|
||||||
|
Plugin.logger.LogDebug($"Main Path {mainPathIndex}: No local ID defined, skipping");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
var tableClone = pathPair.Value.Clone();
|
||||||
var localMax = localPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
var localMax = localPropSettings.Count.GetRandom(dungeonGenerator.RandomStream);
|
||||||
|
|
||||||
var spawned = ProcessGlobalPropID(tableClone, localMax, globalCount, globalMax);
|
var spawned = ProcessGlobalPropID(tableClone, localMax, globalCount, globalMax);
|
||||||
globalCount += spawned;
|
globalCount += spawned;
|
||||||
|
Plugin.logger.LogDebug($"Main Path {mainPathIndex}: Local ({spawned} / {localMax}), Global ({globalCount} / {globalMax})");
|
||||||
|
|
||||||
|
// all dictionaries that we done using get throw out
|
||||||
|
if (!localPropSettings.UseToReachGlobalPropLimit) toRemoveKeys.Add(mainPathIndex);
|
||||||
|
|
||||||
//Plugin.logger.LogError($"Spawned {spawned} ({globalCount}/{globalMax})");
|
//Plugin.logger.LogError($"Spawned {spawned} ({globalCount}/{globalMax})");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach(var key in toRemoveKeys){
|
||||||
|
pathDictionary.Remove(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
// spawn the last remaining global props if possible
|
||||||
|
if (globalCount < globalMax && pathDictionary.Count > 0) {
|
||||||
|
var combine = string.Join(", ", pathDictionary.Keys);
|
||||||
|
Plugin.logger.LogDebug($"Combining main paths ({combine}) into one GameObjectChanceTable");
|
||||||
|
|
||||||
|
var combinedTable = pathDictionary.Select(d => d.Value).ToArray();
|
||||||
|
var spawned = ProcessRemainingGlobalPropID(combinedTable, globalMax - globalCount);
|
||||||
|
globalCount += spawned;
|
||||||
|
Plugin.logger.LogDebug($"Spawned remaining props ({globalCount} / {globalMax})");
|
||||||
|
}
|
||||||
|
|
||||||
list.Add(pair.Key);
|
list.Add(pair.Key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
using DunGenPlus.Collections;
|
||||||
|
|
||||||
namespace DunGenPlus {
|
namespace DunGenPlus {
|
||||||
|
|
||||||
|
@ -24,6 +25,8 @@ namespace DunGenPlus {
|
||||||
[CreateAssetMenu(fileName = "Main Path Extender", menuName = "DunGenExtender/Main Path Extender", order = 2)]
|
[CreateAssetMenu(fileName = "Main Path Extender", menuName = "DunGenExtender/Main Path Extender", order = 2)]
|
||||||
public class MainPathExtender : ScriptableObject {
|
public class MainPathExtender : ScriptableObject {
|
||||||
|
|
||||||
|
internal const string LocalMainPathGlobalPropsTooltip = "Limits the amount of Global Props that can spawn on a single main path.\n\nThis does not afffect the global limit defined in DungeonFlow.";
|
||||||
|
|
||||||
public PropertyOverride<IntRange> Length = new PropertyOverride<IntRange>(false, new IntRange(5, 10));
|
public PropertyOverride<IntRange> Length = new PropertyOverride<IntRange>(false, new IntRange(5, 10));
|
||||||
|
|
||||||
public PropertyOverride<BranchMode> BranchMode = new PropertyOverride<BranchMode>(false, DunGen.BranchMode.Local);
|
public PropertyOverride<BranchMode> BranchMode = new PropertyOverride<BranchMode>(false, DunGen.BranchMode.Local);
|
||||||
|
@ -32,6 +35,9 @@ namespace DunGenPlus {
|
||||||
public PropertyOverride<List<GraphNode>> Nodes = new PropertyOverride<List<GraphNode>>(false, new List<GraphNode>());
|
public PropertyOverride<List<GraphNode>> Nodes = new PropertyOverride<List<GraphNode>>(false, new List<GraphNode>());
|
||||||
public PropertyOverride<List<GraphLine>> Lines = new PropertyOverride<List<GraphLine>>(false, new List<GraphLine>());
|
public PropertyOverride<List<GraphLine>> Lines = new PropertyOverride<List<GraphLine>>(false, new List<GraphLine>());
|
||||||
|
|
||||||
|
[Tooltip(LocalMainPathGlobalPropsTooltip)]
|
||||||
|
public List<LocalGlobalPropSettings> LocalGroupProps = new List<LocalGlobalPropSettings>();
|
||||||
|
|
||||||
[Header("DEV ONLY: DON'T TOUCH")]
|
[Header("DEV ONLY: DON'T TOUCH")]
|
||||||
[Attributes.ReadOnly]
|
[Attributes.ReadOnly]
|
||||||
public string Version = "0";
|
public string Version = "0";
|
||||||
|
|
|
@ -373,14 +373,10 @@ namespace DunGenPlus.Patches {
|
||||||
[HarmonyPrefix]
|
[HarmonyPrefix]
|
||||||
[HarmonyPatch(typeof(DungeonGenerator), "ProcessGlobalProps")]
|
[HarmonyPatch(typeof(DungeonGenerator), "ProcessGlobalProps")]
|
||||||
public static bool ProcessGlobalPropsPatch(ref DungeonGenerator __instance){
|
public static bool ProcessGlobalPropsPatch(ref DungeonGenerator __instance){
|
||||||
if (DunGenPlusGenerator.Active){
|
if (DunGenPlusGenerator.Active && DunGenPlusGenerator.Properties.MainPathProperties.MainPathDetails.Any(d => d.LocalGroupProps.Count > 0)){
|
||||||
var list = DunGenPlusGenerator.Properties.MainPathProperties.LocalMainPathGlobalProps;
|
Plugin.logger.LogDebug("Performing Local Global Props algorithm");
|
||||||
if (list != null && list.Count > 0) {
|
DunGenPlusGenerator.ProcessGlobalPropsPerMainPath(__instance);
|
||||||
Plugin.logger.LogDebug("Performing Local Global Props algorithm");
|
return false;
|
||||||
DunGenPlusGenerator.ProcessGlobalPropsPerMainPath(__instance);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ namespace DunGenPlus {
|
||||||
|
|
||||||
internal const string modGUID = "dev.ladyalice.dungenplus";
|
internal const string modGUID = "dev.ladyalice.dungenplus";
|
||||||
private const string modName = "Dungeon Generation Plus";
|
private const string modName = "Dungeon Generation Plus";
|
||||||
private const string modVersion = "1.2.1";
|
private const string modVersion = "1.3.0";
|
||||||
|
|
||||||
internal readonly Harmony Harmony = new Harmony(modGUID);
|
internal readonly Harmony Harmony = new Harmony(modGUID);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue