Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/komefai/PS4RemotePlayInterceptor

A small .NET library to intercept and inject controls on PS4 Remote Play for Windows
https://github.com/komefai/PS4RemotePlayInterceptor

automation bot dualshock ps4 remoteplay sony

Last synced: about 2 months ago
JSON representation

A small .NET library to intercept and inject controls on PS4 Remote Play for Windows

Awesome Lists containing this project

README

        

# PS4 Remote Play Interceptor

[![nuget](https://img.shields.io/nuget/v/PS4RemotePlayInterceptor.svg)](https://nuget.org/packages/PS4RemotePlayInterceptor)
[![NuGet](https://img.shields.io/nuget/dt/PS4RemotePlayInterceptor.svg)](https://nuget.org/packages/PS4RemotePlayInterceptor)
[![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](http://paypal.me/Komefai)
[![Twitter](https://img.shields.io/twitter/url/https/twitter.com/fold_left.svg?style=social&label=Follow%20Me)](https://twitter.com/itskomefai)

A small .NET library to intercept controls on PS4 Remote Play for Windows, powered by [EasyHook](https://easyhook.github.io/). The library can be used to automate any PS4 game. See the [prototype demo](https://youtu.be/QjTZsPR-BcI).

Also check out [PS4 Macro](https://github.com/komefai/PS4Macro) repository for a ready-to-use software built on this library.

## Install

#### Using NuGet (Recommended)
```
Install-Package PS4RemotePlayInterceptor
```

#### From Source
Add reference to PS4RemotePlayInterceptor.dll.

## Example Usage

This console application will hold the X button while moving the left analog stick upwards until interrupted by a keypress.

You can set `EmulateController` to `true` to use the library without a DualShock 4 controller plugged in (the real controller must be unplugged).

```csharp
using PS4RemotePlayInterceptor;

class Program
{
static void Main(string[] args)
{
// Setup callback to interceptor
Interceptor.Callback = new InterceptionDelegate(OnReceiveData);
// Emulate controller (BETA)
Interceptor.EmulateController = false;

// Start watchdog to automatically inject when possible
Interceptor.Watchdog.Start();
// Notify watchdog events
Interceptor.Watchdog.OnInjectionSuccess = () => Console.WriteLine("Watchdog OnInjectionSuccess");
Interceptor.Watchdog.OnInjectionFailure = () => Console.WriteLine("Watchdog OnInjectionFailure");

// Or inject manually and handle exceptions yourself
//Interceptor.Inject();

Console.WriteLine("-- Press any key to exit");
Console.ReadKey();
}

private static void OnReceiveData(ref DualShockState state)
{
/* -- Modify the controller state here -- */

// Force press X
state.Cross = true;

// Force left analog upwards
state.LY = 0;

// Force left analog downwards
// state.LY = 255;

// Force left analog to center
// state.LX = 128;
// state.LY = 128;
}
}
```

## To-Do List

- Intercept ouput reports

## Troubleshoot

- > {"STATUS_INTERNAL_ERROR: Unknown error in injected C++ completion routine. (Code: 15)"}

SOLUTION: Restart PS4 Remote Play.

- > Injection IPC failed (on some machines)

SOLUTION: Inject with Compatibility mode instead

```csharp
// Setup callback to interceptor
Interceptor.Callback = new InterceptionDelegate(OnReceiveData);

// Inject
Interceptor.InjectionMode = InjectionMode.Compatibility;
Interceptor.Inject();
```

## Credits

- https://easyhook.github.io/
- https://github.com/Jays2Kings/DS4Windows
- http://www.psdevwiki.com/ps4/DS4-USB