0.0.4
fixed structure of the package added background send thread added close function for terminating the background thread
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -151,3 +151,5 @@ dmypy.json
|
|||||||
|
|
||||||
# End of https://www.toptal.com/developers/gitignore/api/python,vscode
|
# End of https://www.toptal.com/developers/gitignore/api/python,vscode
|
||||||
|
|
||||||
|
pydualsense/interface.py
|
||||||
|
pydualsense/interface.ui
|
||||||
|
22
README.md
22
README.md
@@ -1,2 +1,22 @@
|
|||||||
# pydualsense
|
# pydualsense
|
||||||
controll your dualsense through python
|
control your dualsense through python. using the hid library this module implements the sending report for controlling you new PS5 controller. It creates a background thread to constantly update the controller.
|
||||||
|
|
||||||
|
# dependecies
|
||||||
|
|
||||||
|
- hid >= 1.0.4
|
||||||
|
|
||||||
|
# usage
|
||||||
|
|
||||||
|
```python
|
||||||
|
|
||||||
|
from pydualsense import pydualsense
|
||||||
|
|
||||||
|
ds = pydualsense() # open controller
|
||||||
|
ds.setColor(255,0,0) # set touchpad color to red
|
||||||
|
ds.close() # closing the controller
|
||||||
|
```
|
||||||
|
|
||||||
|
# Coming soon
|
||||||
|
|
||||||
|
- reading the states of the controller to enable a fully compatibility with python
|
||||||
|
- add documentation
|
@@ -0,0 +1,2 @@
|
|||||||
|
from .enums import LedOptions,Brightness,PlayerID,PulseOptions,TriggerModes
|
||||||
|
from .pydualsense import pydualsense, DSAudio, DSLight, DSTrigger
|
@@ -1,5 +1,4 @@
|
|||||||
from enum import Enum, IntFlag
|
from enum import IntFlag
|
||||||
from flags import Flags # bitflag
|
|
||||||
|
|
||||||
class LedOptions(IntFlag):
|
class LedOptions(IntFlag):
|
||||||
Off=0x0,
|
Off=0x0,
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import hid
|
import hid
|
||||||
from enums import (LedOptions, PlayerID,
|
from .enums import (LedOptions, PlayerID,
|
||||||
PulseOptions, TriggerModes, Brightness)
|
PulseOptions, TriggerModes, Brightness)
|
||||||
import threading
|
import threading
|
||||||
|
|
||||||
@@ -17,15 +17,19 @@ class pydualsense:
|
|||||||
self.color = (0,0,255) # set dualsense color around the touchpad to blue
|
self.color = (0,0,255) # set dualsense color around the touchpad to blue
|
||||||
|
|
||||||
self.send_thread = True
|
self.send_thread = True
|
||||||
send_report = threading.Thread(target=self.sendReport)
|
self.report_thread = threading.Thread(target=self.sendReport)
|
||||||
#send_report.start()
|
self.report_thread.start()
|
||||||
# create thread for sending
|
# create thread for sending
|
||||||
|
|
||||||
|
def close(self):
|
||||||
|
self.send_thread = False
|
||||||
|
self.report_thread.join()
|
||||||
|
|
||||||
def __find_device(self):
|
def __find_device(self):
|
||||||
devices = hid.enumerate(vid=0x054c)
|
devices = hid.enumerate(vid=0x054c)
|
||||||
found_devices = []
|
found_devices = []
|
||||||
for device in devices:
|
for device in devices:
|
||||||
if device['vendor_id'] == 0x54c and device['product_id'] == 0xCE6:
|
if device['vendor_id'] == 0x054c and device['product_id'] == 0x0CE6:
|
||||||
found_devices.append(device)
|
found_devices.append(device)
|
||||||
|
|
||||||
# TODO: detect connection mode, bluetooth has a bigger write buffer
|
# TODO: detect connection mode, bluetooth has a bigger write buffer
|
||||||
@@ -98,84 +102,74 @@ class pydualsense:
|
|||||||
|
|
||||||
|
|
||||||
def sendReport(self):
|
def sendReport(self):
|
||||||
# while self.send_thread:
|
while self.send_thread:
|
||||||
outReport = [0] * 48 # create empty list with range of output report
|
outReport = [0] * 48 # create empty list with range of output report
|
||||||
# packet type
|
# packet type
|
||||||
outReport[0] = 0x2
|
outReport[0] = 0x2
|
||||||
|
|
||||||
|
|
||||||
# flags determing what changes this packet will perform
|
# flags determing what changes this packet will perform
|
||||||
# 0x01 set the main motors (also requires flag 0x02); setting this by itself will allow rumble to gracefully terminate and then re-enable audio haptics, whereas not setting it will kill the rumble instantly and re-enable audio haptics.
|
# 0x01 set the main motors (also requires flag 0x02); setting this by itself will allow rumble to gracefully terminate and then re-enable audio haptics, whereas not setting it will kill the rumble instantly and re-enable audio haptics.
|
||||||
# 0x02 set the main motors (also requires flag 0x01; without bit 0x01 motors are allowed to time out without re-enabling audio haptics)
|
# 0x02 set the main motors (also requires flag 0x01; without bit 0x01 motors are allowed to time out without re-enabling audio haptics)
|
||||||
# 0x04 set the right trigger motor
|
# 0x04 set the right trigger motor
|
||||||
# 0x08 set the left trigger motor
|
# 0x08 set the left trigger motor
|
||||||
# 0x10 modification of audio volume
|
# 0x10 modification of audio volume
|
||||||
# 0x20 toggling of internal speaker while headset is connected
|
# 0x20 toggling of internal speaker while headset is connected
|
||||||
# 0x40 modification of microphone volume
|
# 0x40 modification of microphone volume
|
||||||
outReport[1] = 0xff # [1]
|
outReport[1] = 0xff # [1]
|
||||||
|
|
||||||
# further flags determining what changes this packet will perform
|
# further flags determining what changes this packet will perform
|
||||||
# 0x01 toggling microphone LED
|
# 0x01 toggling microphone LED
|
||||||
# 0x02 toggling audio/mic mute
|
# 0x02 toggling audio/mic mute
|
||||||
# 0x04 toggling LED strips on the sides of the touchpad
|
# 0x04 toggling LED strips on the sides of the touchpad
|
||||||
# 0x08 will actively turn all LEDs off? Convenience flag? (if so, third parties might not support it properly)
|
# 0x08 will actively turn all LEDs off? Convenience flag? (if so, third parties might not support it properly)
|
||||||
# 0x10 toggling white player indicator LEDs below touchpad
|
# 0x10 toggling white player indicator LEDs below touchpad
|
||||||
# 0x20 ???
|
# 0x20 ???
|
||||||
# 0x40 adjustment of overall motor/effect power (index 37 - read note on triggers)
|
# 0x40 adjustment of overall motor/effect power (index 37 - read note on triggers)
|
||||||
# 0x80 ???
|
# 0x80 ???
|
||||||
outReport[2] = 0x1 | 0x2 | 0x4 | 0x10 | 0x40 # [2]
|
outReport[2] = 0x1 | 0x2 | 0x4 | 0x10 | 0x40 # [2]
|
||||||
|
|
||||||
outReport[3]= 0 # left low freq motor 0-255 # [3]
|
outReport[3]= 0 # left low freq motor 0-255 # [3]
|
||||||
outReport[4] = 0 # right low freq motor 0-255 # [4]
|
outReport[4] = 0 # right low freq motor 0-255 # [4]
|
||||||
|
|
||||||
|
|
||||||
# outReport[5] - outReport[8] audio related
|
# outReport[5] - outReport[8] audio related
|
||||||
|
|
||||||
|
|
||||||
# set Micrphone LED, setting doesnt effect microphone settings
|
# set Micrphone LED, setting doesnt effect microphone settings
|
||||||
outReport[9] = self.audio.microphone_led # [9]
|
outReport[9] = self.audio.microphone_led # [9]
|
||||||
|
|
||||||
# set microphone muting
|
# set microphone muting
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# add right trigger mode + parameters to packet
|
# add right trigger mode + parameters to packet
|
||||||
outReport[11] = self.triggerR.mode.value
|
outReport[11] = self.triggerR.mode.value
|
||||||
outReport[12] = self.triggerR.forces[0]
|
outReport[12] = self.triggerR.forces[0]
|
||||||
outReport[13] = self.triggerR.forces[1]
|
outReport[13] = self.triggerR.forces[1]
|
||||||
outReport[14] = self.triggerR.forces[2]
|
outReport[14] = self.triggerR.forces[2]
|
||||||
outReport[15] = self.triggerR.forces[3]
|
outReport[15] = self.triggerR.forces[3]
|
||||||
outReport[16] = self.triggerR.forces[4]
|
outReport[16] = self.triggerR.forces[4]
|
||||||
outReport[17] = self.triggerR.forces[5]
|
outReport[17] = self.triggerR.forces[5]
|
||||||
outReport[20] = self.triggerR.forces[6]
|
outReport[20] = self.triggerR.forces[6]
|
||||||
|
|
||||||
outReport[22] = self.triggerL.mode.value
|
outReport[22] = self.triggerL.mode.value
|
||||||
outReport[23] = self.triggerL.forces[0]
|
outReport[23] = self.triggerL.forces[0]
|
||||||
outReport[24] = self.triggerL.forces[1]
|
outReport[24] = self.triggerL.forces[1]
|
||||||
outReport[25] = self.triggerL.forces[2]
|
outReport[25] = self.triggerL.forces[2]
|
||||||
outReport[26] = self.triggerL.forces[3]
|
outReport[26] = self.triggerL.forces[3]
|
||||||
outReport[27] = self.triggerL.forces[4]
|
outReport[27] = self.triggerL.forces[4]
|
||||||
outReport[28] = self.triggerL.forces[5]
|
outReport[28] = self.triggerL.forces[5]
|
||||||
outReport[31] = self.triggerL.forces[6]
|
outReport[31] = self.triggerL.forces[6]
|
||||||
|
|
||||||
|
outReport[39] = self.light.ledOption.value
|
||||||
"""
|
outReport[42] = self.light.pulseOptions.value
|
||||||
outReport.append(self.light.ledOption.value[0]) #
|
outReport[43] = self.light.brightness.value
|
||||||
outReport.append(self.light.pulseOptions.value[0])
|
outReport[44] = self.light.playerNumber.value
|
||||||
outReport.append(self.light.brightness.value[0])
|
outReport[45] = self.color[0]
|
||||||
outReport.append(self.light.playerNumber.value[0])
|
outReport[46] = self.color[1]
|
||||||
outReport.append(self.color[0]) # r
|
outReport[47] = self.color[2]
|
||||||
outReport.append(self.color[1]) # g
|
self.device.write(bytes(outReport)) # send to controller
|
||||||
outReport.append(self.color[2]) # b
|
|
||||||
"""
|
|
||||||
outReport[39] = self.light.ledOption.value
|
|
||||||
outReport[42] = self.light.pulseOptions.value
|
|
||||||
outReport[43] = self.light.brightness.value
|
|
||||||
outReport[44] = self.light.playerNumber.value
|
|
||||||
outReport[45] = self.color[0]
|
|
||||||
outReport[46] = self.color[1]
|
|
||||||
outReport[47] = self.color[2]
|
|
||||||
self.device.write(bytes(outReport)) # send to controller
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
7
setup.py
7
setup.py
@@ -6,14 +6,13 @@ with open("README.md", "r") as fh:
|
|||||||
|
|
||||||
setup(
|
setup(
|
||||||
name='pydualsense',
|
name='pydualsense',
|
||||||
version='0.0.1',
|
version='0.0.4',
|
||||||
description='control your dualsense controller with python',
|
description='control your DualSense (PS5) controller with python',
|
||||||
long_description=long_description,
|
long_description=long_description,
|
||||||
long_description_content_type="text/markdown",
|
long_description_content_type="text/markdown",
|
||||||
url='https://github.com/flok/pydualsense',
|
url='https://github.com/flok/pydualsense',
|
||||||
author='Florian Kaiser',
|
author='Florian Kaiser',
|
||||||
author_email='shudson@anl.gov',
|
license='MIT License',
|
||||||
license='BSD 2-clause',
|
|
||||||
packages=setuptools.find_packages(),
|
packages=setuptools.find_packages(),
|
||||||
install_requires=['hid>=1.0.4']
|
install_requires=['hid>=1.0.4']
|
||||||
)
|
)
|
||||||
|
Reference in New Issue
Block a user