Обновление документации по векторам и кватернионам

This commit is contained in:
Andrey Pokidov 2026-03-30 01:05:57 +07:00
parent 2fd2578bb3
commit 460fe94830
20 changed files with 237 additions and 138 deletions

View file

@ -1,31 +1,39 @@
# Copying
[Русская версия / Russian version](copy-rus.md)
The copy functions allow you to copy the coordinate values of one vector to another vector.
Function for **BgcVector2FP32**:
Function for **BGC_FP32_Vector2**:
```c
inline void bgc_vector2_copy_fp32(const BgcVector2FP32* from, BgcVector2FP32* to);
inline void bgc_fp32_vector2_copy(BGC_FP32_Vector2* const destination, const BGC_FP32_Vector2* const source);
```
Function for **BgcVector2FP64**:
Function for **BGC_FP64_Vector2**:
```c
inline void bgc_vector2_copy_fp64(const BgcVector2FP64* from, BgcVector2FP64* to);
inline void bgc_fp64_vector2_copy(BGC_FP64_Vector2* const destination, const BGC_FP64_Vector2* const source);
```
Each of these functions is equivalent to the following lines of code:
```c
to->x1 = from->x1;
to->x2 = from->x2;
destination->x = source->x;
destination->y = source->y;
```
The **from** and **to** parameters must not be invalid pointers. The NULL (0) value is also considered invalid.
The **source** and **destination** parameters must be valid pointers.
The NULL (0) value is also considered invalid.
The **from** parameter must be a pointer to a two-dimensional vector whose coordinates are to be copied. The coordinates of the **from** vector will not change after the function call.
The **source** parameter must be a pointer to a two-dimensional vector whose
coordinates are to be copied. The coordinates of the **source** vector will
not change after the function call.
The **to** parameter must be a pointer to a two-dimensional vector whose coordinates are to be changed. The coordinates of the **to** vector will become the same as those of the **from** vector after the function call.
The **destination** parameter must be a pointer to a two-dimensional vector
whose coordinates are to be changed. The coordinates of the **destination**
vector will become the same as those of the **source** vector after the function
call.
Example of use:
@ -35,13 +43,14 @@ Example of use:
int main()
{
BgcVector2FP32 my_vector1, my_vector2;
BGC_FP32_Vector2 my_vector1, my_vector2;
bgc_vector2_set_values_fp32(-2, 7, &my_vector1);
my_vector1.x = -2.0f;
my_vector1.y = 7.4f;
bgc_vector2_copy_fp32(&my_vector1, &my_vector2);
bgc_fp32_vector2_copy(&my_vector2, &my_vector1);
printf("x1 = %f, x2 = %f\n", my_vector2.x1, my_vector2.x2);
printf("x = %f, y = %f\n", my_vector2.x, my_vector2.y);
return 0;
}