A game engine.
Project description
# Game Engine Package - starcrusher2025
## Introduction
This package provides a simple game engine framework named starcrusher2025. It allows developers to create 2D games using Pygame by providing essential functionalities such as managing the game window, controlling player entities, handling input, and rendering.
## Installation
To install starcrusher2025-games, use pip:
```bash
pip install starcrusher2025-games
Usage
To use starcrusher2025 in your Python projects, follow the examples below:
from starcrusher2025_games import Game
# Initialize the game instance
game = Game()
# Set the background color of the game window
game.window.set_bgc(0, 0, 0) # Sets the background to black
# Set player attributes
game.player.set_color(255, 0, 0) # Sets the player color to red
game.player.set_start_pos((400, 300)) # Sets the player starting position
game.player.set_size((50, 50)) # Sets the player size
game.player.set_speed(5) # Sets the player speed
game.player.load_image("player.png") # Loads an image for the player
game.set_fps(60) # Sets the fps to 60
# Add game objects
obj1 = game.obj(start_pos=(100, 100), size=(50, 50), speed=0, color=(255, 0, 0))
obj2 = game.obj(start_pos=(200, 200), size=(75, 75), speed=2, color=(0, 255, 0))
game.add_object(obj1)
game.add_object(obj2)
# Set window size
game.window.set_size(800, 600) # Sets the game window size
# Start the game loop
game.start()
Commands
game.window.set_bgc(r, g, b)
Sets the background color of the game window.
- Parameters:
r
: Integer representing the red component of the RGB color (0-255).g
: Integer representing the green component of the RGB color (0-255).b
: Integer representing the blue component of the RGB color (0-255).
game.player.set_start_pos(start_pos)
Sets the starting position of the player entity.
- Parameters:
start_pos
: Tuple representing the(x, y)
coordinates of the starting position.
game.player.set_size(size)
Sets the size of the player entity.
- Parameters:
size
: Tuple representing the(width, height)
of the player entity.
game.player.set_speed(speed)
Sets the speed of the player entity.
- Parameters:
speed
: Integer value representing the speed of the player.
game.player.get_player_position()
Returns the player position.
game.player.load_image(image_path)
Loads an image file for the player entity.
- Parameters:
image_path
: Path to the image file to be loaded for the player.
game.window.set_size(width, height)
Sets the size of the game window.
- Parameters:
width
: Width of the game window in pixels.height
: Height of the game window in pixels.
game.set_fps(fps)
Sets the game's target frames per second (FPS).
- Parameters:
fps
: Integer value representing the target frames per second.
game.add_object(obj)
Adds a game object to the game.
- Parameters:
obj
: Instance ofGameObject
.
game.start()
Starts the game loop, which handles game logic, rendering, and input handling until the game is stopped or closed.
game.stop()
Stops the game loop and terminates the game.
Additional Features
Collision Handling
Both Player
and GameObject
have built-in collision handling. When objects collide, their positions are adjusted to avoid overlap.
-
Player.handle_collision(other_object)
Handles collision between the player and another game object. -
GameObject.handle_collision(other_object)
Handles collision between two game objects.
License
This project is licensed under the MIT License. See the LICENSE.md file for details.
With these changes, you can now create game objects using `game.obj` without needing to import `GameObject` separately. This approach keeps the code cleaner and more intuitive to use.
Project details
Release history Release notifications | RSS feed
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 starcrusher2025_games-1.0.1.tar.gz
.
File metadata
- Download URL: starcrusher2025_games-1.0.1.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9decf2d44e536378e2865ba1e0c4b1df18c39605565328e22d9eb3a3e7f56cd3 |
|
MD5 | be8946749f5704fd68b244b966c66a1a |
|
BLAKE2b-256 | e7754d596c23ed2054e9142e4e22fe69263d3d456fc3e4256dd34ac612975e04 |
File details
Details for the file starcrusher2025_games-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: starcrusher2025_games-1.0.1-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67e8c378948dd4d26445394ab42c352b98c6b8ab4e74eaa1c224e53533048dc8 |
|
MD5 | 85fb6e73ecc326beab450777af194446 |
|
BLAKE2b-256 | d481ebf0614560e52eac1c999de9a2391ca78445679b2d36980916f76c61b575 |