MarcusCZ.AltV.VTarget.Client 1.1.0

dotnet add package MarcusCZ.AltV.VTarget.Client --version 1.1.0                
NuGet\Install-Package MarcusCZ.AltV.VTarget.Client -Version 1.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="MarcusCZ.AltV.VTarget.Client" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MarcusCZ.AltV.VTarget.Client --version 1.1.0                
#r "nuget: MarcusCZ.AltV.VTarget.Client, 1.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install MarcusCZ.AltV.VTarget.Client as a Cake Addin
#addin nuget:?package=MarcusCZ.AltV.VTarget.Client&version=1.1.0

// Install MarcusCZ.AltV.VTarget.Client as a Cake Tool
#tool nuget:?package=MarcusCZ.AltV.VTarget.Client&version=1.1.0                

VTarget

A 'third-eye' system inspired by FiveM resource qtarget (ox_target) for AltV.

This is abstracted version of my old roleplay framework, which I discontinued. And I think it still can be useful for someone, so I've decided to release it.

This resource is written in C# and unfortunately because of callback structure, cannot be used from js. Only way to use this resource is to add the dll file into your C# resource project and use API methods directly. The reason is mentioned above - this was intended to be part of bigger C# framework, so there was no need to make it work with javascript. But ofc pull request are welcome, if someone is willing to do any JS wrapper 😃

Resource is client-side only.

How to run this resource

Add the resource to your C# project from NuGet.

Create instance of main VTarget Target class and add calls for OnStart, OnStop methods in your main class.

using MarcusCZ.AltV.VTarget.Target;

class YourResource
{
    private Target _vtarget;
    
    public void OnStart()
    {
        _vtarget = new Target();
        _vtarget.OnStart();
        // your code
    }
    
    public void OnStop()
    {
        // your code
        _vtarget.OnStop();
    }
}

After building your project, don't forget copy dll file of VTarget (MarcusCZ.AltV.VTarget.Client.dll) and downloaded frontend files into your resource. And include it both in resource.toml to client-files section.

Concepts

  • Option - is one option of displayed menu.
  • Options can have children - that means, after clicking on one option, child menu can be displayed along with the main.
  • Options can be disabled - disabled options have greyed background and player cannot click* on them.
  • Options can have several conditions to display despite current circumstances.
    • List<string> Bones Player must aim at specific bone of entity.
    • bool EnableInVehicle If the option is enabled in vehicle. (ex. player must leave vehicle to interact with mailbox)
    • float Distance Defines maximum distance between targeted object and player. Default 7 max 100
    • bool callback CanShow Custom callback, which is called before the option is displayed. Return value True|False defines if the option should be displayed in the menu or not.
    • bool callback CanInterract Custom callback, which is called after the option is displayed and decides whether the option is disabled or not.
  • Option have several other attributes:
    • string Icon FontAwesome icon ID fas fa-times. Icon is displayed at the right side.
    • string Label Label of the option.
    • Background? Background Background color of the option. See Background enum in Data. Null = default (no) background.
    • List<IVTargetOption>? Children Children menu, displayed when clicked on the option.
    • string? Description NOT IMPLEMENTED
    • Position Position NOT IMPLEMENTED

*when option is disabled, callback OnClickDisabled is called instead of OnClick.

Callbacks

CanShow

Decides whether option can be displayed (sent to frontend) or not.

delegate bool VEntityOptionCheckCallback(uint entity, Vector3 pos, ISharedEntity? altEntity)
  • uint entity - script entity ID, which player is aiming at.
  • Vector3 pos - Hit position. Exact position where raycast from player camera hit the object, which player is aiming at.
  • ISharedEntity? altEntity - If player is aiming at some entity (ped, other player, vehicle) created using AltV natives, their instance should be there. Can be null if player is aiming on some object for example.

<details> <summary>Example use</summary>

Display option only if the vehicle is unlocked.

// option will be displayed only when the vehicle is unlocked
someDoorOption.CanShow = (entity, pos, altEntity) => {
  if (Alt.Natives.GetVehicleDoorLockStatus(entity) == 1) {
      return true;
  }
  return false;
};    

</details>

CanInteract

Decides whether the option is disabled or not. Similar like CanShow

delegate bool VEntityOptionCheckCallback(uint entity, Vector3 pos, ISharedEntity? altEntity)

OnClick

Called when player clicks on the option. Callback must return bool value - true|false, which decides if the menu should be refreshed. That can be useful when we have options for opening vehicle doors, but we don't want to show them, when the vehicle is locked. We have another option for unlocking vehicle, so when the player unlocks the vehicle from this option, we want the other options to appear immediately, without closing and opening the menu again.

delegate bool VEntityOptionCallback(uint entity, Vector3 pos, ISharedEntity? altEntity, Alert alert);
  • uint entity - script entity ID, which player is aiming at.
  • Vector3 pos - Hit position. Exact position where raycast from player camera hit the object, which player is aiming at.
  • ISharedEntity? altEntity - If player is aiming at some entity (ped, other player, vehicle) created using AltV natives, their instance should be there. Can be null if player is aiming on some object for example.
  • Alert alert - Function reference, which can render option alert in the VTarget menu.

<details> <summary>Example</summary>

If the vehicle is locked, unlock it, render alert and refresh the menu, so new options which were hidden until now, can show without reopening the menu.

// Option for unlocking vehicle
option.OnClick = (entity, pos, altEntity, alert) => {
  if (Alt.Natives.GetVehicleDoorLockStatus(entity) != 1) { // If vehicle is locked
      Alt.Natives.SetVehicleDoorsLocked(entity, 1); // Unlock vehicle
      alert(Background.SUCCESS, "Vehicle was unlocked"); // Render alert with green background
      return true; // We want to refresh the menu
  }
  
  return false; // Vehicle is not locked, do nothing.
};    

</details>

OnDisabledClick

Called when option is disabled and player clicks on it. Same like OnClick

delegate bool VEntityOptionCallback(uint entity, Vector3 pos, ISharedEntity? altEntity, Alert alert);

Option registration for entities and objects

Using class VEntityOption

Available constructors:

VEntityOption(string icon, string label); // ID will be generated random.
VEntityOption(string icon, string label, string id); // If we want specify ID.

Available methods for registration

Target#RegisterGlobalVehicle(VEntityOption option); // Register option for all vehicles
Target#RegisterGlobalPlayer(VEntityOption option); // Register option for all players
Target#RegisterGlobalObject(uint model, VEntityOption option); // Register option for all objects with specified model.
// Target#Register(VEntityOption option); // Register for specific instance of AltV entity NOT IMPLEMENTED

Example

Register option for opening vehicle doors.

var option = new VEntityOption("fas fa-door", "Open doors");
option.Bones = new List<string> {"door_dside_f"}; // Option will be shown only if player aims at vehicle door.
option.CanInterract = (entity, pos, altEntity) => {
    if (Alt.Natives.GetVehicleDoorLockStatus(entity) == 1) {
        return true;
    }
    return false;
}; // option will be enabled only if the vehicle is unlocked
option.OnClick = (entity, pos, altEntity, alert) => {
    // open vehicle doors
    return false; // we dont need to refresh the menu
};
option.OnDisabledClick = (entity, pos, altEntity, alert) => {
    alert(Background.DANGER, "Vehicle is locked"); 
    return false;
};
_vtarget.RegisterGlobalVehicle(option); // Register this option for all vehicles

Option registration for PolyZones

Please refer to my VZone Resource VTarget API

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on MarcusCZ.AltV.VTarget.Client:

Package Downloads
MarcusCZ.AltV.VZones.Client.VTargetAPI

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.0 106 1/4/2025