All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.badlogic.gdx.ai.steer.utils.Path Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright 2014 See AUTHORS file.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *   http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/

package com.badlogic.gdx.ai.steer.utils;

import com.badlogic.gdx.ai.steer.utils.Path.PathParam;
import com.badlogic.gdx.math.Vector;

/** The {@code Path} for an agent having path following behavior. A path can be shared by multiple path following behaviors because
 * its status is maintained in a {@link PathParam} local to each behavior.
 * 

* The most common type of path is made up of straight line segments, which usually gives reasonably good results while keeping * the math simple. However, some driving games use splines to get smoother curved paths, which makes the math more complex. * * @param Type of vector, either 2D or 3D, implementing the {@link Vector} interface * @param

Type of path parameter implementing the {@link PathParam} interface * * @author davebaol */ public interface Path, P extends PathParam> { /** Returns a new instance of the path parameter. */ public P createParam (); /** Returns {@code true} if this path is open; {@code false} otherwise. */ public boolean isOpen (); /** Returns the length of this path. */ public float getLength (); /** Returns the first point of this path. */ public T getStartPoint (); /** Returns the last point of this path. */ public T getEndPoint (); /** Maps the given position to the nearest point along the path using the path parameter to ensure coherence and returns the * distance of that nearest point from the start of the path. * @param position a location in game space * @param param the path parameter * @return the distance of the nearest point along the path from the start of the path itself. */ public float calculateDistance (T position, P param); /** Calculates the target position on the path based on its distance from the start and the path parameter. * @param out the target position to calculate * @param param the path parameter * @param targetDistance the distance of the target position from the start of the path */ public void calculateTargetPosition (T out, P param, float targetDistance); /** A path parameter used by path following behaviors to keep the path status. * * @author davebaol */ public static interface PathParam { /** Returns the distance from the start of the path */ public float getDistance (); /** Sets the distance from the start of the path * @param distance the distance to set */ public void setDistance (float distance); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy