2016-01-04 15:05:58 -08:00
|
|
|
/* EINA - EFL data type library
|
2016-01-07 01:58:54 -08:00
|
|
|
* Copyright (C) 2016 Cedric Bail
|
2016-01-04 15:05:58 -08:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library;
|
|
|
|
* if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef EINA_VECTOR_H_
|
|
|
|
#define EINA_VECTOR_H_
|
|
|
|
|
2016-01-07 00:57:44 -08:00
|
|
|
#include "eina_matrix.h"
|
|
|
|
|
2016-01-04 15:05:58 -08:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @ender_group{Eina_Vector_Type}
|
|
|
|
* @ender_group{Eina_Vector2}
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef struct _Eina_Vector2 Eina_Vector2;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
* @defgroup Eina_Vector2 Vectors in floating point
|
|
|
|
* @ingroup Eina_Basic
|
|
|
|
* @brief Vector definition and operations
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct _Eina_Vector2
|
|
|
|
{
|
|
|
|
double x;
|
|
|
|
double y;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set parameters to vector.
|
|
|
|
*
|
|
|
|
* @param dst The resulting vector.
|
|
|
|
* @param x The x component.
|
|
|
|
* @param y The y component.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_set(Eina_Vector2 *dst, double x, double y);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set array to vector.
|
|
|
|
*
|
|
|
|
* @param dst The resulting vector.
|
|
|
|
* @param v The the array[2] for set.
|
|
|
|
*
|
|
|
|
* Set to vector first 2 elements from array.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_array_set(Eina_Vector2 *dst, const double *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Copy vector.
|
|
|
|
*
|
|
|
|
* @param dst The vector copy.
|
|
|
|
* @param src The vector for copy.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_copy(Eina_Vector2 *dst, const Eina_Vector2 *src);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Make negative vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param v The current vector.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_negate(Eina_Vector2 *out, const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Add two vectors.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param a The first member of the add.
|
|
|
|
* @param b The second member of the add.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_add(Eina_Vector2 *out, const Eina_Vector2 *a, const Eina_Vector2 *b);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Subtract two vectors
|
|
|
|
*
|
|
|
|
* @param out The resulting vector
|
|
|
|
* @param a The first member of the subtract
|
|
|
|
* @param b The second member of the subtract
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_subtract(Eina_Vector2 *out, const Eina_Vector2 *a, const Eina_Vector2 *b);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Scale vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param v The vector for scale.
|
|
|
|
* @param scale The scale value.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_scale(Eina_Vector2 *out, const Eina_Vector2 *v, double scale);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the dot product of the two vectors.
|
|
|
|
*
|
|
|
|
* @param a The first member.
|
|
|
|
* @param b The secondt member.
|
|
|
|
* @return The dot product.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline double eina_vector2_dot_product(const Eina_Vector2 *a, const Eina_Vector2 *b);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the length of the given vector.
|
|
|
|
*
|
|
|
|
* @param v The vector.
|
|
|
|
* @return The length.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline double eina_vector2_length_get(const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the length in square of the given vector.
|
|
|
|
*
|
|
|
|
* @param v The vector.
|
|
|
|
* @return The length in square.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline double eina_vector2_length_square_get(const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the distance between of two vectors.
|
|
|
|
*
|
|
|
|
* @param a The first vector.
|
|
|
|
* @param b The second vector.
|
|
|
|
* @return The distance.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline double eina_vector2_distance_get(const Eina_Vector2 *a, const Eina_Vector2 *b);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the distance in square between of two vectors.
|
|
|
|
*
|
|
|
|
* @param a The first vector.
|
|
|
|
* @param b The second vector.
|
|
|
|
* @return The distance in square.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline double eina_vector2_distance_square_get(const Eina_Vector2 *a, const Eina_Vector2 *b);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief normalize vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param v The vector for normalize.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_normalize(Eina_Vector2 *out, const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Transform vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param m The matrix for transform.
|
|
|
|
* @param v The ector for transform.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_transform(Eina_Vector2 *out, const Eina_Matrix2 *m, const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Homogeneous position transform vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param m The matrix for transform.
|
|
|
|
* @param v The ector for transform.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_homogeneous_position_transform(Eina_Vector2 *out, const Eina_Matrix3 *m, const Eina_Vector2 *v);
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Homogeneous direction ransform vector.
|
|
|
|
*
|
|
|
|
* @param out The resulting vector.
|
|
|
|
* @param m The matrix for transform.
|
|
|
|
* @param v The ector for transform.
|
|
|
|
*
|
|
|
|
* @since 1.17
|
|
|
|
*/
|
2016-01-07 01:58:54 -08:00
|
|
|
static inline void eina_vector2_homogeneous_direction_transform(Eina_Vector2 *out, const Eina_Matrix3 *m, const Eina_Vector2 *v);
|
2016-01-07 00:57:44 -08:00
|
|
|
|
2016-01-07 01:58:54 -08:00
|
|
|
/** @} */
|
2016-01-07 00:57:44 -08:00
|
|
|
|
2016-01-07 01:58:54 -08:00
|
|
|
#include "eina_inline_vector.x"
|
2016-01-04 15:05:58 -08:00
|
|
|
|
|
|
|
#endif
|