PCoIP Core Library Integration¶
The core library allows an application developer to integrate a PCoIP session directly into an application. The core library facilitates connection to a remote host, decoding PCoIP image data directly into an application supplied frame buffer as well as remoting audio, keyboard and mouse events and supported USB devices. The application is responsible for all of the interactions with the window manager and the local operating system. The following diagram shows how an application would integrate the core library and broker library into a custom application.
PCoIP Core API¶
This method uses the PCoIP Core API to integrate the PCoIP protocol into a custom application. This method is necessary if you want custom features in the client beyond that which is possible using the Session Client API.
PCoIP Core API
This diagram shows the architecture with a custom application integrating the core library.
*Partner Virtual Channel Plugins can be developed using the Virtual Channel SDK, to enable this you can combine the PCoIPÂ Client SDK with the PCoIPÂ Virtual Channel SDK.
PCoIP Core API and Application Functionality¶
Using the Core API the application developer has more control over the client application than the PCoIP Session API but the developer must implement the integration between the local OS and the core library.
Broker Interactions¶
The core library does not implement any of the broker protocol interactions. The application is responsible for obtaining the PCoIP agent address, port number and session tag, using the Broker Client API or some other brokering method, and passing these to the core library.
Session Establishment¶
The application must provide the PCoIP agent address, port number and session tag to the core library in order to establish a PCoIP session.
Display Topology¶
The application is responsible for deciding what displays to present to the user. The application may specify up to four displays with resolutions up to 4096x4096. The application must determine the correct display position and the rotations (if any).
Keyboard Events¶
The application is responsible for handling local keyboard events, and providing the core library with scan codes to send to the remote host.
Mouse Events¶
The application must provide the mouse events, with either absolute or relative coordinates, for the core library to send to the remote host.
Touch Events¶
If the application supports touch events, the core library can forward these to the remote host.
Cursor Handling¶
Local cursor handling is critical for providing the most responsive user experience possible. The application is responsible for updating the local cursor shape and position on call-back from the core library.
USB Redirection¶
The application is responsible for determining if any USB devices should be connected to the remote session. The core library will disconnect the USB devices from the local system and redirect the device to the remote system.
Session Reconnection¶
The core library supports reconnecting a session (for up to 20 minutes) in the event of a network disruption. The application is notified when a network disruption occurs and provides a method for terminating reconnection attempts.
Session Termination¶
The core library provides a method for the application to terminate the session.