From 3f364430854716e09d60a501ef8ebb4532c54304 Mon Sep 17 00:00:00 2001 From: Space V <40030799+ahcenezdh@users.noreply.github.com> Date: Mon, 4 Mar 2024 03:07:26 +0100 Subject: [PATCH] feat(natives/misc): update natives (#1032) * feat(natives/misc): update natives * Update TOOGLE_SHOW_OPTIONAL_STUNT_JUMP_CAMERA * Update GET_LINE_PLANE_INTERSECTION Someone has to review the documentation for GetLinePlaneIntersection, i'm not sure, all of this is theoric. * Update GetLinePlaneIntersection.md No underscore in aliases for unnamed natives. * Update ToggleShowOptionalStuntJumpCamera.md No underscore ( _ ) in aliases for unnamed natives. * Update GetLinePlaneIntersection.md Remove any tValue references from the examples. --------- Co-authored-by: ammonia-cfx <38232208+4mmonium@users.noreply.github.com> --- MISC/GetLinePlaneIntersection.md | 109 ++++++++++++++++++++++ MISC/N_0xf56dfb7b61be7276.md | 27 ------ MISC/N_0xfb80ab299d2ee1bd.md | 17 ---- MISC/ToggleShowOptionalStuntJumpCamera.md | 19 ++++ 4 files changed, 128 insertions(+), 44 deletions(-) create mode 100644 MISC/GetLinePlaneIntersection.md delete mode 100644 MISC/N_0xf56dfb7b61be7276.md delete mode 100644 MISC/N_0xfb80ab299d2ee1bd.md create mode 100644 MISC/ToggleShowOptionalStuntJumpCamera.md diff --git a/MISC/GetLinePlaneIntersection.md b/MISC/GetLinePlaneIntersection.md new file mode 100644 index 000000000..4e4083c3f --- /dev/null +++ b/MISC/GetLinePlaneIntersection.md @@ -0,0 +1,109 @@ +--- +ns: MISC +aliases: ["0xF56DFB7B61BE7276"] +--- +## GET_LINE_PLANE_INTERSECTION + +```c +// 0xF56DFB7B61BE7276 0xC6CC812C +BOOL GET_LINE_PLANE_INTERSECTION(float x1, float y1, float z1, float x2, float y2, float z2, float planeX, float planeY, float planeZ, float planeNormalX, float planeNormalY, float planeNormalZ, float* intersectionParameter); +``` + +Determines whether a line segment intersects a plane and, if so, returns the parameter value at which this intersection occurs. + +``` +NativeDB Introduced: v323 +``` + +## Parameters +* **x1**: The X-coordinate of the first point of the line segment. +* **y1**: The Y-coordinate of the first point of the line segment. +* **z1**: The Z-coordinate of the first point of the line segment. Together, `x1`, `y1`, and `z1` define the starting point of the line segment. +* **x2**: The X-coordinate of the second point of the line segment. +* **y2**: The Y-coordinate of the second point of the line segment. +* **z2**: The Z-coordinate of the second point of the line segment. Together, `x2`, `y2`, and `z2` define the ending point of the line segment. +* **planeX**: The X-coordinate of a point on the plane. This, along with `planeY` and `planeZ`, specifies a point that lies on the plane's surface. +* **planeY**: The Y-coordinate of a point on the plane. +* **planeZ**: The Z-coordinate of a point on the plane. +* **planeNormalX**: The X-component of the plane's normal vector. The normal vector is perpendicular to the plane's surface and defines its orientation. +* **planeNormalY**: The Y-component of the plane's normal vector. +* **planeNormalZ**: The Z-component of the plane's normal vector. Together, `planeNormalX`, `planeNormalY`, and `planeNormalZ` fully describe the plane's orientation in 3D space. +* **intersectionParameter**: A pointer to a float. This parameter is used to return the value of `t` at which the line segment intersects the plane. The value of `t` is a scalar multiplier that can be used to calculate the exact intersection point on the line segment. If the line does not intersect the plane, the value of `t` is not meaningful. + +## Return value +Returns `true` if the line segment intersects the plane, in which case the `intersectionParameter` will contain the intersection point's parameter value. Returns `false` if there is no intersection, making the `intersectionParameter` value irrelevant. + +## Examples +```lua +-- Define the line segment with start and end points +local startX, startY, startZ = 100.0, -200.0, 50.0 +local endX, endY, endZ = 200.0, -100.0, 50.0 + +-- Define the plane with a point on the plane and the normal vector +local planeX, planeY, planeZ = 150.0, -150.0, 50.0 +local normalX, normalY, normalZ = 0.0, 0.0, 1.0 + +-- Call the native +local success, intersectionParameter = GetLinePlaneIntersection(startX, startY, startZ, endX, endY, endZ, planeX, planeY, planeZ, normalX, normalY, normalZ, intersectionParameter) + +if success then + -- Calculate the intersection point using intersectionParameter + local intersectX = startX + (endX - startX) * intersectionParameter + local intersectY = startY + (endY - startY) * intersectionParameter + local intersectZ = startZ + (endZ - startZ) * intersectionParameter + + print("Intersection point at: (" .. intersectX .. ", " .. intersectY .. ", " .. intersectZ .. ")") +else + print("No intersection found.") +end +``` + +```js +// Define the line segment with start and end points +const startX = 100.0, startY = -200.0, startZ = 50.0; +const endX = 200.0, endY = -100.0, endZ = 50.0; + +// Define the plane with a point on the plane and the normal vector +const planeX = 150.0, planeY = -150.0, planeZ = 50.0; +const normalX = 0.0, normalY = 0.0, normalZ = 1.0; + +// Call the native +const [success, intersectionParameter] = GetLinePlaneIntersection(startX, startY, startZ, endX, endY, endZ, planeX, planeY, planeZ, normalX, normalY, normalZ, intersectionParameter); + +if (success) { + // Calculate the intersection point using intersectionParameter + const intersectX = startX + (endX - startX) * intersectionParameter; + const intersectY = startY + (endY - startY) * intersectionParameter; + const intersectZ = startZ + (endZ - startZ) * intersectionParameter; + + console.log(`Intersection point at: (${intersectX}, ${intersectY}, ${intersectZ})`); +} else { + console.log("No intersection found."); +} +``` + +```csharp +using static CitizenFX.Core.Native.API; + +// Define the line segment with start and end points +float startX = 100.0f, startY = -200.0f, startZ = 50.0f; +float endX = 200.0f, endY = -100.0f, endZ = 50.0f; + +// Define the plane with a point on the plane and the normal vector +float planeX = 150.0f, planeY = -150.0f, planeZ = 50.0f; +float normalX = 0.0f, normalY = 0.0f, normalZ = 1.0f; + +// Call the native +bool success = GetLinePlaneIntersection(startX, startY, startZ, endX, endY, endZ, planeX, planeY, planeZ, normalX, normalY, normalZ, out float intersectionParameter); + +if (success) { + // Calculate the intersection point using intersectionParameter + float intersectX = startX + (endX - startX) * intersectionParameter; + float intersectY = startY + (endY - startY) * intersectionParameter; + float intersectZ = startZ + (endZ - startZ) * intersectionParameter; + + Debug.WriteLine($"Intersection point at: ({intersectX}, {intersectY}, {intersectZ})"); +} else { + Debug.WriteLine("No intersection found."); +} +``` diff --git a/MISC/N_0xf56dfb7b61be7276.md b/MISC/N_0xf56dfb7b61be7276.md deleted file mode 100644 index af768c6f3..000000000 --- a/MISC/N_0xf56dfb7b61be7276.md +++ /dev/null @@ -1,27 +0,0 @@ ---- -ns: MISC ---- -## _0xF56DFB7B61BE7276 - -```c -// 0xF56DFB7B61BE7276 0xC6CC812C -BOOL _0xF56DFB7B61BE7276(float p0, float p1, float p2, float p3, float p4, float p5, float p6, float p7, float p8, float p9, float p10, float p11, float* p12); -``` - - -## Parameters -* **p0**: -* **p1**: -* **p2**: -* **p3**: -* **p4**: -* **p5**: -* **p6**: -* **p7**: -* **p8**: -* **p9**: -* **p10**: -* **p11**: -* **p12**: - -## Return value diff --git a/MISC/N_0xfb80ab299d2ee1bd.md b/MISC/N_0xfb80ab299d2ee1bd.md deleted file mode 100644 index b319f5cd3..000000000 --- a/MISC/N_0xfb80ab299d2ee1bd.md +++ /dev/null @@ -1,17 +0,0 @@ ---- -ns: MISC ---- -## _0xFB80AB299D2EE1BD - -```c -// 0xFB80AB299D2EE1BD -void _0xFB80AB299D2EE1BD(BOOL toggle); -``` - -``` -Toggles some stunt jump stuff. -``` - -## Parameters -* **toggle**: - diff --git a/MISC/ToggleShowOptionalStuntJumpCamera.md b/MISC/ToggleShowOptionalStuntJumpCamera.md new file mode 100644 index 000000000..df8322b19 --- /dev/null +++ b/MISC/ToggleShowOptionalStuntJumpCamera.md @@ -0,0 +1,19 @@ +--- +ns: MISC +aliases: ["0xFB80AB299D2EE1BD"] +--- +## TOGGLE_SHOW_OPTIONAL_STUNT_JUMP_CAMERA + +```c +// 0xFB80AB299D2EE1BD +void TOGGLE_SHOW_OPTIONAL_STUNT_JUMP_CAMERA(BOOL toggle); +``` + +Enable/disable optional stunt camera. + +``` +NativeDB Introduced: v757 +``` + +## Parameters +* **toggle**: Set to `true` to enable the optional stunt jump camera angles, or `false` to disable them and use the default camera view.