Unity 求出多个物体的中心点

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class GetCenterPointFunction
{
    /// 
    /// 获取不规则多边形几何中心点
    /// 
    /// 
    /// 
    public static Vector2 GetCenterPoint(List mPoints)
    {
        float cx = (GetMinX(mPoints) + GetMaxX(mPoints)) / 2;
        float cy = (GetMinY(mPoints) + GetMaxY(mPoints)) / 2;
        return new Vector2(cx, cy);
    }

    /// 
    /// 获取最小X值
    /// 
    /// 
    /// 
    public static float GetMinX(List mPoints)
    {
        float minX = 0;
        if (mPoints.Count > 0)
        {
            minX = mPoints[0].x;
            foreach (Vector2 point in mPoints)
            {
                if (point.x < minX)
                    minX = point.x;
            }
        }
        return minX;
    }
    /// 
    /// 获取最大X值
    /// 
    /// 
    /// 
    public static float GetMaxX(List mPoints)
    {
        float maxX = 0;
        if (mPoints.Count > 0)
        {
            maxX = mPoints[0].x;
            foreach (Vector2 point in mPoints)
            {
                if (point.x > maxX)
                    maxX = point.x;
            }
        }
        return maxX;
    }
    /// 
    /// 获取最小Y值
    /// 
    /// 
    /// 
    public static float GetMinY(List mPoints)
    {
        float minY = 0;
        if (mPoints.Count > 0)
        {
            minY = mPoints[0].y;
            foreach (Vector2 point in mPoints)
            {
                if (point.y < minY)
                    minY = point.y;
            }
        }
        return minY;
    }
    /// 
    /// 获取最大Y值
    /// 
    /// 
    /// 
    public static float GetMaxY(List mPoints)
    {
        float maxY = 0;
        if (mPoints.Count > 0)
        {
            maxY = mPoints[0].y;
            foreach (Vector2 point in mPoints)
            {
                if (point.y > maxY)
                    maxY = point.y;
            }
        }
        return maxY;
    }


    /// 
    /// 获取不规则多边形重心点
    /// 
    /// 
    /// 
    public static Vector2 GetCenterOfGravityPoint(List mPoints)
    {
        float area = 0.0f;//多边形面积
        float gx = 0.0f, gy = 0.0f;// 重心的x、y
        for (int i = 1; i <= mPoints.Count; i++)
        {
            float iX = mPoints[i % mPoints.Count].x;
            float iY = mPoints[i % mPoints.Count].y;
            float nextX = mPoints[i - 1].x;
            float nextY = mPoints[i - 1].y;
            float temp = (iX * nextY - iY * nextX) / 2.0f;
            area += temp;
            gx += temp * (iX + nextX) / 3.0f;
            gy += temp * (iY + nextY) / 3.0f;
        }
        gx = gx / area;
        gy = gy / area;
        Vector2 v2 = new Vector2(gx, gy);
        return v2;
    }
}

你可能感兴趣的:(Unity 求出多个物体的中心点)