fix PlaceAlongSpaceEdges requirement
This commit is contained in:
@@ -9,22 +9,15 @@ namespace EscapeRoomEngine.Engine.Runtime.Requirements
|
||||
{
|
||||
protected override List<Placement> FilterCandidates(List<Placement> candidates, Module module, Space space)
|
||||
{
|
||||
var right = space.rrPlacement.size.x - 1;
|
||||
var top = space.rrPlacement.size.y - 1;
|
||||
var sizeMinusOne = space.rrPlacement.size - Vector2Int.one;
|
||||
|
||||
candidates.RemoveAll(candidate =>
|
||||
{
|
||||
var keep = false;
|
||||
|
||||
candidate.ForEachPosition(position =>
|
||||
{
|
||||
if (!keep)
|
||||
{
|
||||
keep = position.x == 0 || position.x == right || position.z == 0 || position.z == top;
|
||||
}
|
||||
});
|
||||
|
||||
return !keep;
|
||||
var (left, right) = candidate.BackCorners;
|
||||
return !(left.x == 0 && right.x == 0 ||
|
||||
left.z == 0 && right.z == 0 ||
|
||||
left.x == sizeMinusOne.x && right.x == sizeMinusOne.x ||
|
||||
left.z == sizeMinusOne.y && right.z == sizeMinusOne.y);
|
||||
});
|
||||
|
||||
return candidates;
|
||||
|
||||
Reference in New Issue
Block a user