本文整理汇总了C#中System.Collections.SortedList.TrimExcess方法的典型用法代码示例。如果您正苦于以下问题:C# SortedList.TrimExcess方法的具体用法?C# SortedList.TrimExcess怎么用?C# SortedList.TrimExcess使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Collections.SortedList
的用法示例。
在下文中一共展示了SortedList.TrimExcess方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetClosestActiveLights
internal RLIGHT[] GetClosestActiveLights(Vector3 Position)
{
BoundingSphere posSphere = new BoundingSphere(Position, 1.0f);
SortedList<float,RLIGHT> lights = new SortedList<float,RLIGHT>(32);
Hashtable distances = new Hashtable(32);
foreach (RLIGHT light in _LightList.Values)
{
float Distance = Vector3.Distance(light.Position.vector, Position);
if (light.Enabled)
{
switch (light.LightType)
{
case 0:
lights.Add(Distance, light);
break;
case 1:
if(lights.Count >= 32)
{
int i = 0;
foreach(float d in lights.Keys)
{
if(lights[d].LightType != 0)
{
if(Distance < d)
{
lights.RemoveAt(i);
break;
}
}
i++;
}
}
BoundingSphere sphere = new BoundingSphere(light.Position.vector, light.Radius);
if (sphere.Intersects(posSphere))
{
lights.Add(Distance, light);
}
break;
case 2:
lights.Add(Distance, light);
break;
default:
break;
}
}
}
lights.TrimExcess();
List<RLIGHT> l = new List<RLIGHT>(lights.Values);
return l.ToArray();
}