Skip to content

Commit 91e6263

Browse files
committed
Changes for first release
1 parent 0d4a9b7 commit 91e6263

13 files changed

+150
-55
lines changed

Doc/APIRef.tex

+17-17
Original file line numberDiff line numberDiff line change
@@ -121,20 +121,20 @@ \subsection{Types}
121121
\label{APIRef_Types_vec3}
122122
\paragraph{Vector3, Vec3} Represents a three component 16-Bit vector \\
123123

124-
\tbly{int16\_t}{x}{X Component} \\
124+
\tbly{int16\_t}{x}{X Component.} \\
125125

126-
\tbly{int16\_t}{y}{Y Component} \\
126+
\tbly{int16\_t}{y}{Y Component.} \\
127127

128-
\tbly{int16\_t}{z}{Z Component} \\
128+
\tbly{int16\_t}{z}{Z Component.} \\
129129

130130
\label{APIRef_Types_color}
131131
\paragraph{Color} RGB 8-Bit color components. The library also provides several conversion functions to turn several color formats into 8-Bit RGB values.\\
132132

133-
\tbly{uint8\_t}{r}{R - Red color channel}\\
133+
\tbly{uint8\_t}{r}{R - Red color channel.}\\
134134

135-
\tbly{uint8\_t}{g}{G - Green color channel}\\
135+
\tbly{uint8\_t}{g}{G - Green color channel.}\\
136136

137-
\tbly{uint8\_t}{b}{B - Blue color channel}\\
137+
\tbly{uint8\_t}{b}{B - Blue color channel.}\\
138138

139139
\label{APIRef_Types_touch}
140140
\paragraph{Touch} This struct contains information about a single fingers touch position. \\
@@ -146,9 +146,9 @@ \subsection{Types}
146146
\label{APIRef_Types_micled}
147147
\paragraph{MicLed} Enum class representation the state of the microphone LED. \\
148148

149-
\tblx{OFF}{Microphone LED is completely off}
150-
\tblx{ON}{Microphone LED is on}
151-
\tblx{PULSE}{Microphone LED is pulsing}
149+
\tblx{OFF}{Microphone LED is completely off.}
150+
\tblx{ON}{Microphone LED is on.}
151+
\tblx{PULSE}{Microphone LED is pulsing.}
152152

153153

154154
\label{APIRef_Types_tfxt}
@@ -189,21 +189,21 @@ \subsection{Types}
189189

190190
\tbly{bool}{EffectEx.keepEffect}{Indicates weather the effect should keep playing (vibration) when the trigger is fully pressed.}\\
191191

192-
\tbly{uint8\_t}{EffectEx.beginForce}{Force for the section with trigger value >= 128.}\\
192+
\tbly{uint8\_t}{EffectEx.beginForce}{Force for the section with trigger value $\geq 128$.}\\
193193

194-
\tbly{uint8\_t}{EffectEx.middleForce}{Force for the section with trigger value <= 128.}\\
194+
\tbly{uint8\_t}{EffectEx.middleForce}{Force for the section with trigger value $\leq 128$.}\\
195195

196196
\tbly{uint8\_t}{EffectEx.endForce}{Force applied when the trigger is fully pressed / would go beyond 255.}\\
197197

198-
\tbly{uint8\_t}{EffectEx.frequency}{Frequency with witch the effect is executed. More a scalar value to scale between two fixed frequency than an read frequency parameter,}\\
198+
\tbly{uint8\_t}{EffectEx.frequency}{Frequency with witch the effect is executed. More a scalar value to scale between two fixed frequency than an real frequency parameter.}\\
199199

200200

201201
\label{APIRef_Types_ledbr}
202202
\paragraph{LedBrightness} Enum class representation the brightness of the player indication LEDs.\\
203203

204-
\tblx{LOW}{Low brightness player indication LEDs}
205-
\tblx{MEDIUM}{Medium brightness player indication LEDs}
206-
\tblx{HIGH}{High brightness player indication LEDs}
204+
\tblx{LOW}{Low brightness player indication LEDs.}
205+
\tblx{MEDIUM}{Medium brightness player indication LEDs.}
206+
\tblx{HIGH}{High brightness player indication LEDs.}
207207

208208
\label{APIRef_Types_pleds}
209209
\paragraph{PlayerLeds} Struct defining the player LDEs state.\\
@@ -212,7 +212,7 @@ \subsection{Types}
212212

213213
\tbly{bool}{playerLedFade}{Indicates weather the player LEDs should fade in when enabled.}\\
214214

215-
\tbly{\hyperref[APIRef_Types_ledbr]{LedBrightness}}{brightness}{Brightness of the player LEDs}\\
215+
\tbly{\hyperref[APIRef_Types_ledbr]{LedBrightness}}{brightness}{Brightness of the player LEDs.}\\
216216

217217

218218
\paragraph{DS5InputState}
@@ -260,7 +260,7 @@ \subsection{Types}
260260

261261
\tbly{\hyperref[APIRef_Types_pleds]{PlayerLeds}}{playerLeds}{State of the player LEDs.}\\
262262

263-
\tbly{\hyperref[APIRef_Types_color]{Color}}{lightbar}{RGB Color of the lightbar. No affect when \texttt{disableLeds} is \texttt{true}}\\
263+
\tbly{\hyperref[APIRef_Types_color]{Color}}{lightbar}{RGB Color of the lightbar. No affect when \texttt{disableLeds} is \texttt{true}.}\\
264264

265265
\tbly{\hyperref[APIRef_Types_trigfx]{TriggerEffect}}{leftTriggerEffect}{Effect of the left adaptive trigger.}\\
266266

Doc/DualSenseWindows_Doc.pdf

1.29 KB
Binary file not shown.

Doc/DualSenseWindows_Doc.tex

+1
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@
3434
keywordstyle=\color{clr-type},
3535
keywordstyle={[2]\color{clr-constant}},
3636
tabsize=4,
37+
breaklines=true,
3738
numbers=left,
3839
numbersep=5pt
3940
}

Doc/Features.tex

+4-4
Original file line numberDiff line numberDiff line change
@@ -41,7 +41,7 @@ \subsection{Feature List}
4141
\end{figure}
4242

4343
\paragraph{Adaptive trigger}
44-
The DualSense controller feature two 8-Bit analog triggers. It is possible to read the trigger values as 8-Bit continuous values or alternatively as binary button input. Aside of the normal trigger operation the adaptive triggers can be configured to simulate various force feedback effects. It is possible for example to simulate a gun trigger.
44+
The DualSense controller features two 8-Bit analog triggers. It is possible to read the trigger values as 8-Bit continuous values or alternatively as binary button input. Aside of the normal trigger operation the adaptive triggers can be configured to simulate various force feedback effects. It is possible for example to simulate a gun trigger.
4545
\begin{figure}[H]
4646
\centering
4747
\subfloat{{\includegraphics[width=8cm]{rearView_trigger} }}
@@ -57,7 +57,7 @@ \subsection{Feature List}
5757
\end{figure}
5858

5959
\paragraph{DPAD and PS Buttons}
60-
The DualSense controller feature a DPAD and the default well know PlayStation Square, Cross, Circle and Triangle buttons. The DPAD is capable of registering two simultaneously pressed buttons, however the two buttons must be neighbors. The PS-Buttons are being registered as four individual binary values.
60+
The DualSense controller features a DPAD and the default well know PlayStation Square, Cross, Circle and Triangle buttons. The DPAD is capable of registering two simultaneously pressed buttons, however the two buttons must be neighbors. The PS-Buttons are being registered as four individual binary values.
6161
\begin{figure}[H]
6262
\centering
6363
\subfloat{{\includegraphics[width=8cm]{frontView_mainbtn} }}
@@ -69,7 +69,7 @@ \subsection{Feature List}
6969
\begin{itemize}
7070
\item \textbf{Menu button} Should be used to open the in-game menu.
7171
\item \textbf{Share button} Should be used to open the in-game photo mode.
72-
\item \textbf{PlayStation button} Can be used to open a in-game overlay (Look at the know issues to get an additional use case of this button).
72+
\item \textbf{PlayStation button} Can be used to open a in-game overlay.
7373
\item \textbf{Mic button} Should be used to mute the microphone.
7474
\end{itemize}
7575
All the listed buttons are readable through individual binary values.
@@ -102,7 +102,7 @@ \subsection{Feature List}
102102
\end{itemize}
103103

104104
\paragraph{Rumble motors / Haptic feedback}
105-
The DualSense feature two Haptic feedback devices. Thees device work similar like normal speaker, but they are not good in producing tones, they are good in producing vibration. It is possible to send an audio signal directly to those haptic speakers (However currently not supported by this API).\\
105+
The DualSense feature two Haptic feedback devices. Thees device work similar like normal speakers, but they are not good in producing tones, they are good in producing vibration. It is possible to send an audio signal directly to those haptic speakers (However currently not supported by this API).\\
106106
The controller supports simulating the normal soft and hard rumble motors using the haptic speakers. When using this mode both motors can be controlled with the usual 8-Bit values. The left rumble feels hard, the right one soft.
107107

108108
\paragraph{Integrated speaker and microphone}

Doc/GitHub_readme/header.png

-12.2 KB
Loading

Doc/ImportantInfos.tex

+6-1
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,11 @@
11
\section{Important information}
22
\subsection{Trademarks and affiliation}
3-
"PlayStation", "PlayStation Family Mark", "PS5 logo", "PS5", "DualSense" and "DUALSHOCK" are registered trademarks or trademarks of Sony Interactive Entertainment Inc. "SONY" is a registered trademark of Sony Corporation.
3+
"PlayStation", "PlayStation Family Mark", "PS5 logo", "PS5", "DualSense" and "DUALSHOCK" are registered trademarks or trademarks of Sony Interactive Entertainment Inc. "SONY" is a registered trademark of Sony Corporation. \\
4+
5+
"Windows" is a registered trademark of Microsoft Corporation. \\
46

57
\textbf{The Author is not affiliated in any kind with Sony Interactive Entertainment Inc.!} \\
8+
\textbf{The Author is not affiliated in any kind with Microsoft Corporation!} \\
69
Using this library may void your / your clients / your users / your customers controllers warranty! You as the redistributor of the precompiled or self compiled library have to make sure the controller will not be damaged by the functionality you use or at least point out the possible risk to your users / clients / customer!\\
710
Probably no damage or failure at all. This statement is just for my own safety!
811

@@ -20,6 +23,8 @@ \subsection{Sources}
2023
\subsection{License}
2124
\textbf{MIT License}\\
2225

26+
\textbf{Info} Only the implementation is licensed by the MIT license. The protocol of the DualSense 5 controller has been discovered independently and collectively by several people. You can find my sources in the GitHub repository.
27+
2328
Copyright (c) 2020 Ludwig Füchsl\\
2429

2530
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\\

Doc/Introduction.tex

+1-1
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,6 @@ \section{Introduction}
88
\item api references
99
\end{itemize}
1010

11-
We recommend starting with reading through all features as far as you are not familiar with the DualSense controllers feature. Continuing with the installation and getting started guide to get your own demo application up and running. Then you can use the API references to integrate the api into your application.
11+
We recommend starting with reading through all features as far as you are not familiar with the DualSense controllers features. Continuing with the installation and getting started guide to get your own demo application up and running. Then you can use the API references to integrate the api into your application.
1212

1313
\newpage

Doc/QuickStart.tex

+1
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@ \subsection{Enumerate controllers}
3434

3535
// Call enumerate function and switch on return value
3636
switch(DS5W::enumDevices(infos, 16, &controllersCount)){
37+
case DS5W_OK:
3738
// The buffer was not big enough. Ignore for now
3839
case DS5W_E_INSUFFICIENT_BUFFER:
3940
break;

LICENSE

+6
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,11 @@
11
MIT License
22

3+
----------------------------------- Info -----------------------------------
4+
Only the implementation is licensed by the MIT license. The protocol of the
5+
DualSense 5 controller has been discovered independently and collectively by
6+
several people. You can find my sources in the GitHub repository.
7+
----------------------------------------------------------------------------
8+
39
Copyright (c) 2020 Ludwig Füchsl
410

511
Permission is hereby granted, free of charge, to any person obtaining a copy

README.md

+98-31
Original file line numberDiff line numberDiff line change
@@ -1,53 +1,120 @@
1-
# DualSense / PS5 Controller on Windows [API]
2-
Windows API for the PS5 DualSense controller. Written in C++ for C++
1+
# DualSense on Windows [API]
2+
![](https://raw.githubusercontent.com/Ohjurot/DualSense-Windows/main/Doc/GitHub_readme/header.png)
33

4-
First Release coming soon!
54

6-
#### Road map to first preview release:
75

8-
- ~~Reading the input state from the controller using USB~~. DONE!
9-
- ~~Reading input via bluetooth~~. DONE!
10-
- ~~Writing Output state to the controller using USB~~. DONE!
11-
- ~~Controlling and reading the adaptive triggers.~~ DONE!
12-
- ~~Writing Output state via bluetooth.~~ DONE!
13-
- Addition input / output parameters. *Work in progress*
14-
- Calibrating the gyroscope *Work in progress*
15-
- Documenting the API *Work in progress*
16-
- Updating the github repo and publish release
6+
Windows API for the PS5 DualSense controller. Written in C++ for C++. This API will help you using the DualSense controller in your windows C++ Applications / Projects.
177

18-
First preview should be released before 28.11.2020 (The hard work is done - The USB and BT protocol is, at least partially, reverse engineered)
8+
> :exclamation: ​Warning: The current release state is still a preview release. The library may not work as intended!
199
20-
#### Features of the first preview
10+
## Features
2111

22-
- Reading all buttons and analog values (triggers and sticks) which are on the controller
12+
- Reading all button input from the controller
13+
- Reading the analog sticks and analog triggers
2314
- Reading the two finger touch positions
24-
- Reading the accelerometer
25-
- Reading the gyroscope (Currently only raw / uncalibrated values)
26-
- Reading the connection state of the headphone jack
27-
- Setting the rumble motors speed
28-
- Setting various effects to the force feedback triggers
29-
- Retrieving force feedback triggers feedback
30-
- controlling the RGB-Leds, Microphone Led and User Leds
15+
- Reading the Accelerometer and Gyroscope
16+
- Using the haptic feedback for default rumbleing
17+
- Controlling the adaptive triggers (3 Types of effects) and reading back the users force while active
18+
- Controlling the RGB color of the lighbar
19+
- Setting the player indication LEDs and the microphone LED
3120

32-
Fully working over USB and Bluetooth!
21+
The library is still in active development and will be extended with additional features soon. Consider checking out our [Road-map](https://github.com/Ohjurot/DualSense-Windows/blob/main/ROADMAP.md) for further information.
3322

34-
#### Feature planed for the future
23+
## Using the API
3524

36-
- Using the haptic feedback
37-
- Internal speaker and mic
25+
1. Download the `DualSenseWindows_VX.X.zip` file from the latest release found at the [Release Page](https://github.com/Ohjurot/DualSense-Windows/releases)
26+
2. Unzip the archive to your computer
27+
3. Read the `DualSenseWindows.pdf` PDF documentation to get the specific information for your current release
3828

39-
#### Know issues
29+
If you don't want to mess your time documentation - this is the minimal example on how to use the library:
30+
31+
```c++
32+
#include <Windows.h>
33+
#include <ds5w.h>
34+
#include <iostream>
35+
36+
int main(int argc, char** argv){
37+
// Array of controller infos
38+
DS5W::DeviceEnumInfo infos[16];
39+
40+
// Number of controllers found
41+
unsigned int controllersCount = 0;
42+
43+
// Call enumerate function and switch on return value
44+
switch(DS5W::enumDevices(infos, 16, &controllersCount)){
45+
case DS5W_OK:
46+
// The buffer was not big enough. Ignore for now
47+
case DS5W_E_INSUFFICIENT_BUFFER:
48+
break;
49+
50+
// Any other error will terminate the application
51+
default:
52+
// Insert your error handling
53+
return -1;
54+
}
55+
56+
// Check number of controllers
57+
if(!controllersCount){
58+
return -1;
59+
}
60+
61+
// Context for controller
62+
DS5W::DeviceContext con;
63+
64+
// Init controller and close application is failed
65+
if(DS5W_FAILED(DS5W::initDeviceContext(&infos[0], &con))){
66+
return -1;
67+
}
68+
69+
// Main loop
70+
while(true){
71+
// Input state
72+
DS5W::DS5InputState inState;
73+
74+
// Retrieve data
75+
if (DS5W_SUCCESS(DS5W::getDeviceInputState(&con, &inState))){
76+
// Check for the Logo button
77+
if(inState.buttonsB & DS5W_ISTATE_BTN_B_PLAYSTATION_LOGO){
78+
// Break from while loop
79+
break;
80+
}
81+
82+
// Create struct and zero it
83+
DS5W::DS5OutputState outState;
84+
ZeroMemory(&outState, sizeof(DS5W::DS5OutputState));
85+
86+
// Set output data
87+
outState.leftRumble = inState.leftTrigger;
88+
outState.rightRumble = inState.rightTrigger;
89+
90+
// Send output to the controller
91+
DS5W::setDeviceOutputState(&con, &outState);
92+
}
93+
}
94+
95+
// Shutdown context
96+
DS5W::freeDeviceContext(&con);
97+
98+
// Return zero
99+
return 0;
100+
}
101+
```
102+
103+
## Known issues
40104
41105
- When the controller being shut down while connected via Bluetooth (Holding the PS button). The lib will encounter a dead lock within `getDeviceInputState(...)` call. The function will return as soon as the controller is getting reconnected. Not encountering over USB, over USB the expected `DS5W_E_DEVICE_REMOVED` error is returned.
42106
43-
#### Sources
107+
## Special thanks to
44108
45109
I have partially used the following sources to implement the functionality:
46110
47111
- The GitHub community on this project and https://github.com/Ryochan7/DS4Windows/issues/1545
112+
- https://www.reddit.com/r/gamedev/comments/jumvi5/dualsense_haptics_leds_and_more_hid_output_report/
48113
- https://gist.github.com/dogtopus/894da226d73afb3bdd195df41b3a26aa
49114
- https://gist.github.com/Ryochan7/ef8fabae34c0d8b30e2ab057f3e6e039
50115
- https://gist.github.com/Ryochan7/91a9759deb5dff3096fc5afd50ba19e2
51-
- https://github.com/Ryochan7/DS4Windows/tree/dualsense-integration (Copyright (c) 2019 Travis Nickles - [MIT License](https://github.com/Ryochan7/DS4Windows/blob/jay/LICENSE.txt))
52-
- https://www.reddit.com/r/gamedev/comments/jumvi5/dualsense_haptics_leds_and_more_hid_output_report/
116+
117+
118+
119+
[Important Informations about Trademarks](https://github.com/Ohjurot/DualSense-Windows/blob/main/TRADEMARKS.md)
53120

ROADMAP.md

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
# Road-Map
2+
3+
This is my list of feature I would like to see being supported by my API:
4+
5+
- Getting addition input working (Battery, ...)
6+
- Using the haptic feedback
7+
- Playing audio through all channels (somewhat related to haptic feedback)
8+
- Listening to the user with the integrated microphone
9+
- Controlling all that audio related stuff (Volume / Mute / ...)
10+

TRADEMARKS.md

+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
"PlayStation", "PlayStation Family Mark", "PS5 logo", "PS5", "DualSense" and "DUALSHOCK" are registered trademarks or trademarks of Sony Interactive Entertainment Inc. "SONY" is a registered trademark of Sony Corporation.
2+
3+
"Windows" is a registered trademark of Microsoft Corporation.
4+
5+
The Author is not affiliated in any kind with Sony Interactive Entertainment Inc.! The Author is not affiliated in any kind with Microsoft Corporation!

VS19_Solution/DS5W_Test/src/wWinMain.cpp

+1-1
Original file line numberDiff line numberDiff line change
@@ -156,7 +156,7 @@ INT WINAPI wWinMain(HINSTANCE _In_ hInstance, HINSTANCE _In_opt_ hPrevInstance,
156156
outState.rightRumble = (rrmbl & 0xFF00) >> 8UL;
157157

158158
// Lightbar
159-
outState.lightbar = DS5W::color_R8G8B8_UCHAR_A32_UNORM(255, 0, 0, intensity);
159+
outState.lightbar = DS5W::color_R8G8B8_UCHAR_A32_FLOAT(255, 0, 0, intensity);
160160
intensity -= 0.0025f / btMul;
161161
if (intensity <= 0.0f) {
162162
intensity = 1.0f;

0 commit comments

Comments
 (0)