tunnelForward
- Type:
boolean - Default value:
false
Use ADB forward tunnel instead of reverse tunnel.
This option determines how the Scrcpy client and server communicate through ADB.
By default, Scrcpy uses reverse tunnels where the client listens on the PC and the server connects to it.
When tunnelForward is set to true, the server listens on the device and the client connects to it from the PC.
In forward tunnel mode, the sendDummyByte option is enabled by default to help detect successful connection establishment.
When to Use Forward Tunnels
Forward tunnels are primarily used as a fallback when reverse tunnels are not supported:
- On Android versions < 9 when connected wirelessly (ADB over WiFi), as the ADB daemon cannot create reverse tunnels
- When using custom transports that don't support reverse tunneling
- When encountering
AdbReverseNotSupportedErrorexceptions
For detailed information about both tunneling mechanisms, see the Connect to server page.
Automatic Detection
When using AdbScrcpyClient, the client can automatically detect when reverse tunnels are not supported and will enable forward tunnels automatically. This happens when the underlying transport throws an AdbReverseNotSupportedError.
Related options
sendDummyByte: Controls whether the server should send a0byte at the start of the video stream to detect connection issuesscid: Specifies a session identifier for the Scrcpy server instance
Example
import { ScrcpyOptions1_15 } from "@yume-chan/scrcpy";
const options = new ScrcpyOptions1_15({
tunnelForward: true, // Use forward tunnel instead of reverse
});