
Research
/Security News
10 npm Typosquatted Packages Deploy Multi-Stage Credential Harvester
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.
py-thumbpad
Advanced tools
A virtual thumb pad for directional input, featuring a central donut shape and a movable button pad.
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.
You can install the py_thumbpad package directly from PyPI using pip:
pip install py_thumbpad
Clone the repository and include the py_thumbpad package in your Pygame project.
git clone https://github.com/kerodekroma/py-thumbpad.git
If you've already installed the py_thumbpad package and want to update it to the latest version, you can easily do so using pip. Run the following command in your terminal or command prompt:
pip install --upgrade py_thumbpad
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()
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)
})
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.
Contributions are welcome! Feel free to submit a pull request or open an issue to discuss any changes or improvements.
This project is licensed under the MIT License - see the MIT-LICENSE.txt file for details.
FAQs
A virtual thumb pad for directional input, featuring a central donut shape and a movable button pad.
We found that py-thumbpad demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Research
/Security News
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.