Revolutionize handheld gaming with adaptive game settings. Optimize graphics and gameplay experience based on real-time system metrics. Open-source project empowering developers to enhance games on portable devices
Find a file
2023-06-26 19:50:41 +01:00
.cargo Updated DLL 2023-06-04 00:41:26 +01:00
.github/workflows update release workflow 2023-06-11 00:41:11 +01:00
.vscode Initial Commit 2023-06-02 22:58:55 +01:00
Images Added Logo 2023-06-19 18:33:15 +01:00
Resources Updated DLL files 2023-06-07 20:25:05 +01:00
src Updated DLL 2023-06-04 00:41:26 +01:00
.gitignore Added build script to move files out of the Resources folder into the target 2023-06-03 01:40:42 +01:00
build.rs Updated DLL 2023-06-04 00:41:26 +01:00
Cargo.toml Version Bump 2023-06-10 23:21:21 +01:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2023-06-26 19:48:23 +01:00
CONTRIBUTING.md Create CONTRIBUTING.md 2023-06-26 19:50:05 +01:00
LICENSE Initial commit 2023-06-02 22:08:19 +01:00
README.md Removed Conclusion from Readme 2023-06-26 19:50:41 +01:00

HarmonyLinkLogo

Welcome to the server-side application for the HarmonyLink project. This innovative software is developed with the Rust programming language and is aimed at enhancing the handheld gaming experience.

The Vision and The Reality

The central goal with HarmonyLink is to provide a comprehensive and interactive gaming experience on handheld devices. This client-side application is a crucial part of this vision.

Key Features

  1. Device Identification: HarmonyLink equips games with the ability to identify the specific handheld device they are operating on.
  2. Real-Time Metrics: Games can access real-time data about the handheld device's power usage and docking status through HarmonyLink.
  3. Cross-Platform Compatibility: HarmonyLink extends its functionality to Windows games running on Proton/Wine.

Using HarmonyLinkServer

For users who wish to run the precompiled release version of HarmonyLinkServer, please follow the instructions specific to your platform below.

Windows Users

  1. Navigate to the latest release on the project's GitHub page.
  2. Download the .zip archive for Windows.
  3. Extract the contents of the .zip archive to a directory of your choice.
  4. Open a command prompt in the directory where you extracted the files.
  5. Run the HarmonyLinkServer executable by typing ./harmony_link_server.exe.

Please note that you'll need to manually start the program each time you want to use it.

Steam Deck (Linux) Users

  1. Navigate to the latest release on the project's GitHub page.
  2. Download the .zip archive for Linux.
  3. Extract the contents of the .zip archive to a directory of your choice.

Running in Desktop Mode

To use HarmonyLinkServer in Desktop Mode, follow these steps:

  1. Open a terminal in the directory where you extracted the files.
  2. Run the HarmonyLinkServer executable by typing ./harmony_link_server.

Please note that you'll need to keep the terminal window open while using HarmonyLinkServer in desktop mode.

Optional: Setting Up as a Service for Gamemode

For a seamless experience in gamemode, you have the option to set up HarmonyLinkServer as a service on your Steam Deck. Please be aware that this setup process will require a moderate level of technical knowledge.

How It Works

HarmonyLink operates using a client-server structure. This server-side application runs on the host side (native Linux or Windows), and games access the metrics via an API.

Developers and modders can easily implement GET and POST requests from the API, integrating system metrics into games. These metrics can be used to adapt the game's quality settings, providing a more customized gaming experience.

Getting Started

Prerequisites

Before getting started, make sure you have:

  • A working installation of Rust.
  • Familiarity with Rust syntax and concepts.
  • Git installed on your system.

Compiling

  1. Clone the repository: git clone https://github.com/Jordonbc/HarmonyLinkServer.git
  2. Navigate into the directory: cd HarmonyLinkServer
  3. Build the project: cargo build
  4. Run the project: cargo run

To view the API in action, check out HarmonyLink: View. This sister project provides a comprehensive interface to see what data the API is providing.

👇 To help visualize its functionality, we've included a demonstration video that showcases HarmonyLink in action on a Steam Deck in gamemode. HarmonyLink in action

Frequently Asked Questions (FAQ)

A: HarmonyLink supports both native Linux and Windows platforms, and extends its functionality to Windows games running on Proton/Wine.

A: You can start by cloning the HarmonyLinkServer repository. Detailed instructions are provided in the Getting Started section.

A: Yes, HarmonyLink is designed to be engine-agnostic and can be used with games developed in different engines. For Unreal Engine, there is a specific Unreal Engine Plugin available.

A: While game developers will find HarmonyLink particularly useful for optimizing their games for handheld devices, players can also benefit from the enhanced gaming experience that HarmonyLink provides.

A: HarmonyLink is designed to be lightweight and efficient, with minimal impact on game performance. The primary purpose of HarmonyLink is to enhance game performance by allowing games to adapt their settings based on real-time device metrics.

License

This project is licensed under the GNU General Public License v3.0 or later. Please do not redistribute HarmonyLinkServer. e.g.: Proving an alternative download link or distributing with a game.