-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(natives/vehicles): Update natives about hover mode (deluxo/opres…
…sor2)
- Loading branch information
Showing
9 changed files
with
179 additions
and
77 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
--- | ||
ns: VEHICLE | ||
aliases: ["_SET_VEHICLE_HOVER_TRANSFORM_ACTIVE"] | ||
--- | ||
## SET_DISABLE_HOVER_MODE_FLIGHT | ||
|
||
```c | ||
// 0x2D55FE374D5FDB91 | ||
void SET_DISABLE_HOVER_MODE_FLIGHT(Vehicle vehicle, BOOL toggle); | ||
``` | ||
## Disables wings for `Deluxo` and `Oppressor MK II`. For the Deluxo, it retracts the wings immediately, preventing flight. For the Oppressor Mk II, the wings retract after landing and take-off is not possible, though it can still glide if launched into the air. | ||
## Parameters | ||
* **vehicle**: The vehicle to which the toogle will be applied. | ||
* **toggle**: Boolean parameter where setting `true` disables the vehicle's wings, preventing flight. Setting it to `false` allows the vehicle to fly as usual. | ||
## Examples | ||
```lua | ||
-- In this case we are disabling the wings of the vehicle | ||
local vehicle = GetVehiclePedIsIn(PlayerPedId(), false) | ||
SetDisableHoverModeFlight(vehicle, true) | ||
``` | ||
|
||
```js | ||
// In this case we are disabling the wings of the vehicle | ||
const vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetDisableHoverModeFlight(vehicle, true); | ||
``` | ||
|
||
```cs | ||
// In this case we are disabling the wings of the vehicle | ||
using static CitizenFX.Core.Native.API; | ||
Vehicle vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetDisableHoverModeFlight(vehicle, true); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
--- | ||
ns: VEHICLE | ||
aliases: ["_SET_SPECIALFLIGHT_WING_RATIO"] | ||
--- | ||
## SET_HOVER_MODE_WING_RATIO | ||
|
||
```c | ||
// 0x70A252F60A3E036B | ||
void SET_HOVER_MODE_WING_RATIO(Vehicle vehicle, float ratio); | ||
``` | ||
## This native allows opening or closing the wings of the Deluxo/Oppressor. For the Deluxo, wing deployment depends on sufficient altitude. | ||
## Parameters | ||
* **vehicle**: The vehicle to which the ratio will be applied. | ||
* **ratio**: Between 0.0 and 1.0. 0.0 is wings closed, 1.0 is wings open. | ||
## Examples | ||
```lua | ||
-- In this case we are opening the wings of the vehicle | ||
local vehicle = GetVehiclePedIsIn(PlayerPedId(), false) | ||
SetHoverModeWingRatio(vehicle, 1.0) | ||
``` | ||
|
||
```js | ||
// In this case we are opening the wings of the vehicle | ||
const vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetHoverModeWingRatio(vehicle, 1.0); | ||
``` | ||
|
||
```cs | ||
// In this case we are opening the wings of the vehicle | ||
using static CitizenFX.Core.Native.API; | ||
Vehicle vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetHoverModeWingRatio(vehicle, 1f); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
--- | ||
ns: VEHICLE | ||
aliases: ["0xF1211889DF15A763", "_SET_VEHICLE_HOVER_TRANSFORM_ENABLED"] | ||
--- | ||
## SET_SPECIAL_FLIGHT_MODE_ALLOWED | ||
|
||
```c | ||
// 0xF1211889DF15A763 | ||
void SET_SPECIAL_FLIGHT_MODE_ALLOWED(Vehicle vehicle, BOOL toggle); | ||
``` | ||
## Allows locking the state of a vehicle, such as the flying mode of the `Deluxo` or the `oppressor2` | ||
In the decompiled scripts [SetSpecialFlightModeAllowed](SET_SPECIAL_FLIGHT_MODE_ALLOWED) is used on `oppressor2` but couldn't get it work on it. | ||
## Parameters | ||
* **vehicle**: The vehicle to which the locking state will be applied. | ||
* **toogle**: Boolean parameter where setting `false` locks the current state of the vehicle, preventing transitions such as the `Deluxo` or Oppressor switching between their flying and driving modes. Setting it to `true` allows changing the vehicle state as usual. | ||
## Examples | ||
```lua | ||
-- Checks the altitude of the Deluxo and locks its current mode when above 150 meters. | ||
-- If the Deluxo is in flying mode at this altitude, it will be unable to switch to driving mode, and vice versa. | ||
Citizen.CreateThread(function() | ||
local coords -- Variable to store the vehicle's coordinates. | ||
local vehicle -- Variable to store the vehicle entity. | ||
repeat | ||
vehicle = GetVehiclePedIsIn(PlayerPedId(), false) -- Get the vehicle the player is currently in. | ||
if (GetEntityModel(vehicle) == joaat("deluxo")) then -- Check if the vehicle is a Deluxo. | ||
coords = GetEntityCoords(vehicle) -- Get the current coordinates of the vehicle. | ||
end | ||
Citizen.Wait(0) -- Wait for the next frame. | ||
until coords.z >= 150.0 -- Keep looping until the Deluxo is above 150 meters. | ||
SetSpecialFlightModeAllowed(vehicle, false) -- Lock the Deluxo's current mode (flying or driving). | ||
end) | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
--- | ||
ns: VEHICLE | ||
aliases: ["_SET_VEHICLE_HOVER_TRANSFORM_RATIO"] | ||
--- | ||
## SET_SPECIAL_FLIGHT_MODE_RATIO | ||
|
||
```c | ||
// 0xD138FA15C9776837 | ||
void SET_SPECIAL_FLIGHT_MODE_RATIO(Vehicle vehicle, float ratio); | ||
``` | ||
## Used alongside [SET_SPECIAL_FLIGHT_MODE_TARGET_RATIO](SetSpecialFlightModeTargetRatio), this function initiates hover transformation for vehicles with a hover mode, like the `Deluxo`, based on a specified ratio (0.0 to 1.0). Incorrect values can glitch the vehicle. Without pairing, vehicles revert to car mode. Ineffective on the `oppressor2` | ||
## Parameters | ||
* **vehicle**: The vehicle to which the ratio will be applied. | ||
* **ratio**: A value between 0.0 and 1.0 indicating the target state for the vehicle's hover mode transition. In decompiled scripts, a common usage is 0.75 - GetFrameTime(). Exceeding the maximum can cause the `Deluxo's` wheels to glitch, delaying their return to the initial position. | ||
## Examples | ||
```lua | ||
-- In this case we are enabling the hover mode for the vehicle and initiates hover transformation. | ||
local vehicle = GetVehiclePedIsIn(PlayerPedId(), false) | ||
SetSpecialFlightModeRatio(vehicle, 0.75 - GetFrameTime()) | ||
SetVehicleHoverTransformPercentage(vehicle, 1.0) | ||
``` | ||
|
||
```js | ||
// In this case we are enabling the hover mode for the vehicle and initiates hover transformation. | ||
const vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetSpecialFlightModeRatio(vehicle, 0.75 - GetFrameTime()); | ||
SetVehicleHoverTransformPercentage(vehicle, 1.0); | ||
``` | ||
|
||
```cs | ||
// In this case we are enabling the hover mode for the vehicle and initiates hover transformation. | ||
using static CitizenFX.Core.Native.API; | ||
Vehicle vehicle = GetVehiclePedIsIn(PlayerPedId(), false); | ||
SetSpecialFlightModeRatio(vehicle, 0.75f - GetFrameTime()); | ||
SetVehicleHoverTransformPercentage(vehicle, 1f); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.