#altv #module #alt-v #events #server-side #client-side #api

altv_internal_sdk

为alt:V模块的内部库。不建议直接使用。

84次发布 (9个稳定版本)

16.2.1 2024年8月19日
16.1.0 2024年6月2日
16.0.0-dev.12023年12月29日
15.1.0 2023年10月22日
0.3.1 2023年4月17日

#2 in #alt-v

Download history 32/week @ 2024-04-28 197/week @ 2024-05-05 306/week @ 2024-05-12 29/week @ 2024-05-19 18/week @ 2024-05-26 261/week @ 2024-06-02 40/week @ 2024-06-09 10/week @ 2024-06-16 7/week @ 2024-06-23 1/week @ 2024-06-30 2/week @ 2024-07-07 4/week @ 2024-07-14 7/week @ 2024-07-21 102/week @ 2024-07-28 49/week @ 2024-08-04 26/week @ 2024-08-11

每月184次下载
4 crate 中使用

MIT 许可证

80KB
693


服务器端alt:V API for Rust

crates.io

altv::events::on_player_connect(|event| {
    let name = event.player.name()?;
    altv::log!("player with name: {name} connected!");
    Ok(())
});

alt:V平台的新服务器端Rust模块

非常感谢 第一个Rust模块的创建者,他们的工作帮助我理解了如何开始自己的模块

客户端部分

最初是使用原生实现wasmtime(不使用JavaScript)。它工作正常,但由于alt:V不允许在生产环境中未经批准使用自定义客户端模块(.dll),以及集成到客户端核心、持续维护以及没有人使用此模块,我转向了更现实的方法,JavaScript WASM

文档

API文档可以在这里找到

如何使用

在所有这些之前,你需要安装LLVM

[!WARNING] 目前在Windows上,LLVM的最新版本与Rust模块不兼容,你需要安装17.0.1版本,例如,使用winget可以通过以下命令进行安装:winget install LLVM.LLVM --version 17.0.1(如果失败,请添加--force

[!重要] 在Windows上,请将LIBCLANG_PATH设置为环境变量,指向您LLVM安装的bin目录。例如,如果您将LLVM安装到了D:\programs\LLVM,那么您需要将值设置为D:\programs\LLVM\bin。您还需要安装带有MSVC编译器的Visual Studio(通常与Rust的Rustup一起安装)

[!注意] 如果在安装或构建altv_internal_sdk时遇到类似的错误:src/alt_bridge.h:5:10: 致命错误: 'memory' 文件未找到,请尝试这个

如果您更喜欢视频教程,可以查看本教程的视频格式

  1. 使用以下命令创建新的cargo包:cargo new altv-resource --lib

  2. 在您的Cargo.toml中将您的crate配置为编译为cdylib

[lib]
crate-type = ['cdylib']
  1. 之后,您可以使用以下命令安装altv crate:cargo add altv

  2. 下一步是将主函数添加到您的资源中(在src/lib.rs

use altv::prelude::*; // Entity, WorldObject traits

#[altv::main] // This is required
fn main() -> impl altv::IntoVoidResult {
    altv::log!("~gl~hello world");
}
  1. 现在您可以使用以下命令构建您的资源:cargo build

  2. target/debug/目录中,您应该看到您刚刚编译的.dll.so文件(如果您没有看到它,请确保您已将lib.crate-type设置为["cdylib"],参见第2步)

  3. 在服务器的resources目录中创建新的alt:V资源

  4. 将编译好的.dll.so复制到资源目录

  5. 使用以下内容创建resource.toml

type = 'rs'
main = 'example.dll' # your compiled .dll or .so
  1. 别忘了将资源添加到server.toml

  2. 现在您可以从最新版本或使用cargo-altvup下载rust模块.dll.so

  3. 将其复制到服务器的modules目录(如果您不使用cargo-altvup

  4. rust-module添加到server.toml中,如下所示

modules = ['rust-module']
  1. 现在,如果您一切操作正确,您应该在服务器控制台看到绿色的“hello world”消息

依赖项

~2.6–7MB
~132K SLoC