OmsiHook 2.3.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package OmsiHook --version 2.3.1                
NuGet\Install-Package OmsiHook -Version 2.3.1                
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="OmsiHook" Version="2.3.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add OmsiHook --version 2.3.1                
#r "nuget: OmsiHook, 2.3.1"                
#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 OmsiHook as a Cake Addin
#addin nuget:?package=OmsiHook&version=2.3.1

// Install OmsiHook as a Cake Tool
#tool nuget:?package=OmsiHook&version=2.3.1                

Omsi-Extensions

Omsi hooking and modding sdk.

.NET DocFX Nuget OMSI Version

The dead simple way to hook into Omsi and fiddle with it's memory. In it's current state we only have mappings for a limited number of Omsi objects, but it's easy to extend. Allows both reading and writing data from Omsi in real time, but currently doesn't allow for anything that requires memory allocation (eg: adding elements to arrays).

The library makes use of C# properties and classes to wrap native Omsi objects making them simple to interact with in a managed environment.

See the documentation for details on the API.

Usage Example

Here's a quick example of how to use it.

using OmsiHook;

class Program
{
    static void Main(string[] args)
    {
        // Create an OmsiHook and attach to any running instance of Omsi
        OmsiHook.OmsiHook omsi = new();
        omsi.AttachToOMSI();

        while (true)
        {
            // Get the PlayerVehicle and get its position
            var pos = omsi.Globals.PlayerVehicle.Position;
            
            // Print the position to the console
            Console.WriteLine($"Player vehicle pos: x:{pos.x:F3}\ty:{pos.y:F3}\tz:{pos.z:F3}");

            Thread.Sleep(500);
        }
    }
}

See the OmsiExtensionsCLI Program.cs for more examples using OmsiHook.

Project Structure

This repository contains the source for the OmsiHook and OmsiHookInvoker libraries as well as template projects using OmsiHook which run under various frameworks.

Here's a summary of the project structure:

\Omsi-Extensions\
┃
┠─► \OmsiHook\             -> Base library containing all the Omsi hooking code and 
┃                             exposing Omsi's internal data.
┠─► \OmsiHookInvoker\      -> C++ plugin for invoking native Omsi methods from OmsiHook, 
┃                             only used by OmsiHook.
┠─► \OmsiHookRPCPlugin\    -> An Omsi plugin which exposes native methods from OmsiHookInvoker 
┃                             to other processes using OmsiHook.
┠─► \OmsiExtensionsCLI\    -> Example command line application that uses OmsiHook; runs
┃                             outside of Omsi.
┠─► \OmsiExtensionsUI\     -> Example Avalonia UI (similar to WPF) application that uses
┃                             OmsiHook; runs outside of Omsi.
┖─► \OmsiHookPlugin\       -> Example plugin that uses OmsiHook and compiles to a native
                               Omsi plugin by using DNNE.

Building

The project requires .NET 6 SDK to build and only works on Windows x86_32. Because of the nature of the project dependencies, sometimes Visual Studio gets the build order wrong (especially for projects depending on OmsiHookInvoker). When updating to a new version of OmsiHook or if you make changes to OmsiHookInvoker you may need to clean and rebuild the solution; if you're really struggling delete the contents of the following directories:

Omsi-Extensions\Debug
Omsi-Extensions\Release
Omsi-Extensions\OmsiExtensionsCLI\bin\
Omsi-Extensions\OmsiHookPlugin\bin\

The project can be configured to automatically copy binaries to your Omsi directory. To do so set the OmsiDir environment variable to your Omsi directory (eg: set "OmsiDir=C:\Program Files\OMSI 2\"). You can also set it by editing the Post-build event action in the OmsiHookRPCPlugin.csproj and OmsiHookPlugin.csproj project files. Note that the binaries are only copied when OmsiHookRPCPlugin or OmsiHookPlugin is rebuilt.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net6.0-windows7.0 is compatible.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.5.3 150 9/18/2024
2.4.4 293 1/4/2024
2.3.2 183 12/14/2023
2.3.1 165 11/20/2023
2.2.0 181 10/25/2023
2.1.0 507 8/16/2022
2.0.1 423 7/8/2022
2.0.0 410 7/7/2022
1.5.0 429 5/7/2022
1.3.0 431 4/30/2022
1.2.0 459 4/17/2022
1.0.1 441 4/16/2022
1.0.0 438 4/15/2022