A virtual thumb pad for directional input, featuring a central donut shape and a movable button pad.
Project description
PyThumbPad
PyThumbPad is a customizable virtual thumb pad for directional input, designed for use in Pygame projects. It features a central donut-shaped control area and a movable button pad, making it ideal for mobile games or any application requiring a thumb stick-style input.
Features
- Customizable Appearance: Easily change colors and sizes for the donut and button pad.
- Directional Input: Supports 4 or 8 directional quadrants for precise input.
- Simple Integration: Easy to add to any Pygame project with minimal setup.
- Responsive Input Handling: Smoothly tracks user input and updates the direction accordingly.
Installation using PyPI
You can install the py_thumbpad
package directly from PyPI using pip:
pip install py_thumbpad
Installation using GIT
Clone the repository and include the py_thumbpad
package in your Pygame project.
git clone https://github.com/kerodekroma/py-thumbpad.git
Usage
Here's a basic example of how to use PyThumbPad in your Pygame project:
from py_thumbpad import PyThumbPad, PY_THUMBPAD_Directions
# Initialize the thumbpad at position (400, 300)
thumbpad = PyThumbPad((400, 300), {})
# In your game loop
running = True
while running:
for event in pygame.event.get():
if event.type == pygame.QUIT:
running = False
thumbpad.listen_events(event)
# Check the direction the thumbpad is pointing to
if PY_THUMBPAD_Directions.TOP in thumbpad.directions:
print("Moving UP!")
elif PY_THUMBPAD_Directions.BOTTOM in thumbpad.directions:
print("Moving DOWN!")
elif PY_THUMBPAD_Directions.LEFT in thumbpad.directions:
print("Moving LEFT!")
elif PY_THUMBPAD_Directions.RIGHT in thumbpad.directions:
print("Moving RIGHT!")
# Update and render the thumbpad
thumbpad.update()
thumbpad.render(screen)
pygame.display.flip()
pygame.quit()
Options
When initializing PyThumbPad, you can pass a dictionary of options to customize the appearance and behavior:
-
quadrants
: The number of directional quadrants (4 for up, down, left, right; 8 for diagonals as well). Default is 4. -
donut_color
: The color of the donut-shaped pad. Default is (123, 157, 243). -
button_color
: The color of the movable button pad. Default is (255, 255, 0). -
donut_bg_color
: The background color of the donut. Default is (0, 0, 0).
Example:
thumb_pad = PyThumbPad((400, 300), {
"quadrants": 8,
"donut_color": (200, 100, 100),
"button_color": (100, 200, 100),
"donut_bg_color": (50, 50, 50)
})
Methods
update()
Updates the state of the button pad. This method should be called within the game loop.
render(screen)
Renders the thumb pad on the provided Pygame surface.
listen_events(event)
Handles Pygame input events and updates the thumb pad's state.
get_directions(current_angle)
Returns the direction based on the current angle and the number of quadrants. This method is used internally by listen_events.
Contributing
Contributions are welcome! Feel free to submit a pull request or open an issue to discuss any changes or improvements.
License
This project is licensed under the MIT License - see the MIT-LICENSE.txt file for details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file py_thumbpad-1.0.2.tar.gz
.
File metadata
- Download URL: py_thumbpad-1.0.2.tar.gz
- Upload date:
- Size: 5.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 075ba84d6d290bae304f637e9459b5a8fad36dc2337cab3cb5d9a612760eb9ed |
|
MD5 | 8da21a226bea6935b1ee84616d6d9262 |
|
BLAKE2b-256 | 3b1e65f0ef95852215d115189283460afb8ecb1fafab6d1292aef6edce2ce9d0 |
File details
Details for the file py_thumbpad-1.0.2-py3-none-any.whl
.
File metadata
- Download URL: py_thumbpad-1.0.2-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6a20a4060a139a475a0e4da9e7ca3bf064b5a5981ae46344a319014078e122ef |
|
MD5 | ca9454cad868c04e6b5bb294a9ccae27 |
|
BLAKE2b-256 | d8246a7b0fa737e84d8c4434d7f5ed30debe2d0feb16f128b923e060675e88f8 |