游戏AI-个体AI角色的操控行为(2)

本文介绍游戏开发中两种关键的AI行为算法:随机徘徊和障碍规避。随机徘徊算法使游戏角色在场景中自然地游走,避免了生硬的路径切换;障碍规避算法则确保AI角色能智能地避开前进道路上的障碍物。通过具体代码实现,展示了如何在Unity引擎中运用这些算法。
5.随机徘徊

我们希望场景中有随机移动的单位,如巡逻的士兵 吃草的牛羊,往往我们在场景中设置几个点让单位在几个点中随机移动,这样会出现一种情况,单位突然掉头,Craig Reynolds突出的随机徘徊解决了这个问题

public class SteeringForWander : Steering {
    public float wanderRadius;//Wander半径
    public float wanderDistance;//Wander距离
    public float wanderJitter;//每秒加到随机位移的最大值
    
    
    private Vector3 desiredVelocity;
    private Vehicle m_vehicle;
    private float maxSpeed;
    private Vector3 circleTarget;
    private Vector3 wanderTarget;
    // Use this for initialization
    void Start () {
        m_vehicle = GetComponent<Vehicle>();
        maxSpeed = m_vehicle.maxSpeed;
        //选圆上一个点作为初始点
        circleTarget = new Vector3(wanderRadius * 0.5f, 0, wanderRadius * 0.3f);

    }

    public override Vector3 Force()
    {
        //随机位移
        Vector3 randomDisplacement = new Vector3((Random.value - 0.5f) * 2 * wanderJitter, 0, (Random.value - 0.5f) * 2 * wanderJitter);
        //从初始点加上一个随机位移
        circleTarget += randomDisplacement;
        //将得到的新点进行投射到圆弧上
        circleTarget = wanderRadius * circleTarget.normalized;
        wanderTarget = m_vehicle.velocity.normalized * wanderDistance + circleTarget + transform.position;
        desiredVelocity = (wanderTarget - transform.position).normalized * maxSpeed;
        return desiredVelocity - m_vehicle.velocity;
    }
}
11173460-9bc48d83003787f4.gif
Wander.gif
6.避开障碍

通过在AI前方发射一条一定长度的射线来检测AI前方是否有需要躲避的物体,在有障碍时,我们给AI一个向量为向前方的向量加上障碍中心到AHead的向量,来让AI物体避开障碍.

public class SteeringForCollisionAvoidance : Steering {
    public Vehicle m_vehicle;
    private float maxSpeed;

    Vector3 desiredVelocity;
    float maxForce;
    //避免障碍的力
    public float avoidanceForce;
    public float MAX_SEE_AHEAD = 2.0f;

    GameObject[] allColliders;
    
    
    // Use this for initialization
    void Start () {
        m_vehicle = GetComponent<Vehicle>();
        maxSpeed = m_vehicle.maxSpeed;
        maxForce = m_vehicle.maxForce;
        if(avoidanceForce > maxForce)
        {
            avoidanceForce = maxForce;
        }
        allColliders = GameObject.FindGameObjectsWithTag("obstacle");
    }

    public override Vector3 Force()
    {
        RaycastHit hit;
        Vector3 force = new Vector3(0, 0, 0);
        Vector3 velocity = m_vehicle.velocity;
        Vector3 normalizedVelocity = velocity.normalized;
        //从AI向前发射一条射线,如果在需要避开障碍的范围内,进行当前前方加一个原点到前方的向量和来作为新的力
        if (Physics.Raycast(transform.position,normalizedVelocity,out hit, MAX_SEE_AHEAD * velocity.magnitude / maxSpeed))
        {
            Vector3 ahead = transform.position + normalizedVelocity * MAX_SEE_AHEAD * (velocity.magnitude / maxSpeed);
            force = ahead - hit.collider.transform.position;
            force *= avoidanceForce;
        }
        return force;
    }
}
11173460-122c2719f593427e.gif
CollisionAvoidance.gif
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值