87 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using Unity.Collections;
 | |
| using UnityEngine;
 | |
| 
 | |
| namespace UnityEngine.Rendering.Universal
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Class <c>ShadowShape2D</c> stores outline geometry for use with a shadow caster.
 | |
|     /// </summary>
 | |
|     public abstract class ShadowShape2D
 | |
|     {
 | |
|         /// <summary>
 | |
|         /// Used when calling SetShape to describe the supplied indicies
 | |
|         /// </summary>
 | |
|         public enum OutlineTopology
 | |
|         {
 | |
|             /// <summary>
 | |
|             /// Describes an index array where a set of two consecutive points describes a line segment.
 | |
|             /// </summary>
 | |
|             Lines,
 | |
|             /// <summary>
 | |
|             /// Describes an index array where a set of three consecutive points describes a triangle.
 | |
|             /// </summary>
 | |
|             Triangles
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Used when calling SetShape to describe the winding direction of the supplied geometry
 | |
|         /// </summary>
 | |
|         public enum WindingOrder
 | |
|         {
 | |
|             /// <summary>
 | |
|             /// Describes an index array where all polygons have vertices in a clockwise order
 | |
|             /// </summary>
 | |
|             Clockwise,
 | |
|             /// <summary>
 | |
|             /// Describes an index array where all polygons have vertices in a counterclockwise order
 | |
|             /// </summary>
 | |
|             CounterClockwise
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// SetFlip specifies how the shadow shape should be flipped when rendered
 | |
|         /// </summary>
 | |
|         /// <param name="flipX"> Specifies flipping on the local x-axis </param>
 | |
|         /// <param name="flipY"> Specifies flipping on the local y-axis </param>
 | |
|         public abstract void SetFlip(bool flipX, bool flipY);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// GetFlip returns how the shadow shape should be flipped when rendered
 | |
|         /// </summary>
 | |
|         /// <param name="flipX"> Returns flipping on the local x-axis </param>
 | |
|         /// <param name="flipY"> Returns flipping on the local y-axis </param>
 | |
|         public abstract void GetFlip(out bool flipX, out bool flipY);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// The value to initialize the trim when created
 | |
|         /// </summary>
 | |
|         /// <param name="trim"> Specifies the starting trim value.</param>
 | |
|         public abstract void SetDefaultTrim(float trim);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// SetShape creates shadow geometry using the supplied geometry
 | |
|         /// </summary>
 | |
|         /// <param name="vertices">The vertices used to create the shadow geometry.</param>
 | |
|         /// <param name="indices">The indices used to create the shadow geometry (Lines topology) </param>
 | |
|         /// <param name="radii">The radius at the vertex. Can be used to describe a capsule.</param>
 | |
|         /// <param name="transform"> The transform used to create the shadow geometry.</param>
 | |
|         /// <param name="windingOrder">The winding order of the supplied geometry.</param>
 | |
|         /// <param name="allowContraction">Specifies if the ShadowCaster2D is allowed to contract the supplied shape(s).</param>
 | |
|         /// <param name="createInteriorGeometry">Specifies if the ShadowCaster2D should create interior geometry. Required for shadow casters that do not use renderers as their source.</param>
 | |
|         public abstract void SetShape(NativeArray<Vector3> vertices, NativeArray<int> indices, NativeArray<float> radii, Matrix4x4 transform, WindingOrder windingOrder = WindingOrder.Clockwise, bool allowContraction = true, bool createInteriorGeometry = false);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// SetShape creates shadow geometry using the supplied geometry
 | |
|         /// </summary>
 | |
|         /// <param name="vertices">The vertices used to create the shadow geometry.</param>
 | |
|         /// <param name="indices">The indices used to create the shadow geometry (Lines topology) </param>
 | |
|         /// <param name="outlineTopology">The settings to create the renderer with.</param>
 | |
|         /// <param name="windingOrder">The winding order of the supplied geometry.</param>
 | |
|         /// <param name="allowContraction">Specifies if the ShadowCaster2D is allowed to contract the supplied shape(s).</param>
 | |
|         /// <param name="createInteriorGeometry">Specifies if the ShadowCaster2D should create interior geometry. Required for shadow casters that do not use renderers as their source.</param>
 | |
|         public abstract void SetShape(NativeArray<Vector3> vertices, NativeArray<int> indices, OutlineTopology outlineTopology, WindingOrder windingOrder = WindingOrder.Clockwise, bool allowContraction = true, bool createInteriorGeometry = false);
 | |
|     }
 | |
| }
 |