2020-01-03 00:14:26 +00:00
|
|
|
|
using System;
|
2020-01-04 00:54:35 +00:00
|
|
|
|
|
2020-01-03 00:14:26 +00:00
|
|
|
|
using Unity.Mathematics;
|
2020-04-13 00:03:23 +00:00
|
|
|
|
using Svelto.ECS;
|
2020-01-03 00:14:26 +00:00
|
|
|
|
|
2020-01-04 00:54:35 +00:00
|
|
|
|
using GamecraftModdingAPI.Utility;
|
|
|
|
|
|
2020-01-03 00:14:26 +00:00
|
|
|
|
namespace GamecraftModdingAPI.Blocks
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2020-02-25 23:05:13 +00:00
|
|
|
|
/// Common block placement operations.
|
|
|
|
|
/// The functionality in this class is for build mode.
|
2020-01-03 00:14:26 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
public static class Placement
|
|
|
|
|
{
|
|
|
|
|
private static PlacementEngine placementEngine = new PlacementEngine();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-02-25 23:05:13 +00:00
|
|
|
|
/// Place a new block at the given position. If scaled, position means the center of the block. The default block size is 0.2 in terms of position.
|
2020-01-03 00:14:26 +00:00
|
|
|
|
/// Place blocks next to each other to connect them.
|
2020-02-25 23:05:13 +00:00
|
|
|
|
/// The placed block will be a complete block with a placement grid and collision which will be saved along with the game.
|
2020-01-03 00:14:26 +00:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="block">The block's type</param>
|
|
|
|
|
/// <param name="color">The block's color</param>
|
|
|
|
|
/// <param name="darkness">The block color's darkness (0-9) - 0 is default color</param>
|
|
|
|
|
/// <param name="position">The block's position in the grid - default block size is 0.2</param>
|
2020-01-15 19:41:50 +00:00
|
|
|
|
/// <param name="rotation">The block's rotation in degrees</param>
|
2020-01-03 00:14:26 +00:00
|
|
|
|
/// <param name="uscale">The block's uniform scale - default scale is 1 (with 0.2 width)</param>
|
2020-01-03 13:38:59 +00:00
|
|
|
|
/// <param name="scale">The block's non-uniform scale - 0 means <paramref name="uscale"/> is used</param>
|
2020-01-03 00:14:26 +00:00
|
|
|
|
/// <param name="playerId">The player who placed the block</param>
|
2020-04-13 00:03:23 +00:00
|
|
|
|
/// <returns>The placed block's ID or null if failed</returns>
|
|
|
|
|
public static EGID? PlaceBlock(BlockIDs block, float3 position,
|
2020-01-15 19:41:50 +00:00
|
|
|
|
float3 rotation = default, BlockColors color = BlockColors.Default, byte darkness = 0,
|
|
|
|
|
int uscale = 1, float3 scale = default, uint playerId = 0)
|
2020-01-03 00:14:26 +00:00
|
|
|
|
{
|
|
|
|
|
if (placementEngine.IsInGame && GameState.IsBuildMode())
|
|
|
|
|
{
|
2020-01-04 00:54:35 +00:00
|
|
|
|
try
|
|
|
|
|
{
|
2020-04-13 00:03:23 +00:00
|
|
|
|
return placementEngine.PlaceBlock(block, color, darkness, position, uscale, scale, playerId, rotation);
|
2020-01-04 00:54:35 +00:00
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
2020-04-13 00:03:23 +00:00
|
|
|
|
Logging.MetaDebugLog(e);
|
|
|
|
|
}
|
2020-01-03 00:14:26 +00:00
|
|
|
|
}
|
2020-04-13 00:03:23 +00:00
|
|
|
|
return null;
|
2020-01-03 00:14:26 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void Init()
|
|
|
|
|
{
|
|
|
|
|
GameEngineManager.AddGameEngine(placementEngine);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|