pygame-core


Namepygame-core JSON
Version 0.1.32 PyPI version JSON
download
home_pagehttps://github.com/Nicklas185105/Pygame-Core
SummaryA modular core library for Pygame-based 2D games.
upload_time2024-12-30 23:39:01
maintainerNone
docs_urlNone
authorNicklas Beyer Lydersen
requires_pythonNone
licenseMIT
keywords pygame game development engine
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Pygame Core

## Overview

**Pygame Core** is a modular and reusable library designed to simplify the development of 2D games using the Pygame library. It provides essential components for managing game loops, scenes, input handling, and utility functions, allowing developers to focus on building their game's unique features.

## Features

- **Game Loop Management**: Simplifies the main game loop with FPS control.
- **Scene Management**: Enables seamless transitions between game scenes (e.g., menus, gameplay).
- **Input Handling**: Centralized input management for keyboards or other devices.
- **Utilities**: Provides tools like collision detection and default settings.
- **Extensibility**: Designed for easy customization and expansion.

## Installation

Install the package using `pip`:

```bash
pip install pygame-core
```

## Usage

### Setting Up Your Game

Below is an example of how to use **Pygame Core** to create a simple game:

```python
import pygame
from core import Game, Scene, SceneManager

class MainMenu(Scene):
    def update(self, input_manager):
        if input_manager.is_pressed(pygame.K_RETURN):
            return Gameplay(self.screen)

    def render(self):
        self.screen.fill((0, 0, 0))
        font = pygame.font.Font(None, 74)
        text = font.render("Press Enter to Start", True, (255, 255, 255))
        self.screen.blit(text, (150, 300))

class Gameplay(Scene):
    def update(self, input_manager):
        # Game logic goes here
        pass

    def render(self):
        self.screen.fill((30, 30, 30))

if __name__ == "__main__":
    pygame.init()
    screen = pygame.display.set_mode((800, 600))
    pygame.display.set_caption("Pygame Core Example")

    manager = SceneManager(MainMenu(screen))
    game = Game(screen)
    game.run(manager)
    pygame.quit()
```

### Key Components

- **`Game`**: Manages the main game loop and FPS control.
- **`Scene`**: A base class for creating game scenes with `update` and `render` methods.
- **`SceneManager`**: Handles scene transitions.
- **`InputManager`**: Provides a clean interface for checking key states.
- **`Utils`**: Includes common utilities like collision detection.

## Contributing

Contributions are welcome! To contribute:

1. Fork the repository.
2. Create a new branch for your feature or bug fix.
3. Make your changes.
4. Run a pylint `pylint core`
5. Submit a pull request.

Please ensure all tests pass before submitting your PR.

## License

This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for more details.

## Upload

> Remember to update version number in `VERSION` file and delete the dist folder before uploading.

Build:

```bash
python -m build
```

Upload:

```bash
python -m twine upload dist/*
```

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Nicklas185105/Pygame-Core",
    "name": "pygame-core",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "pygame game development engine",
    "author": "Nicklas Beyer Lydersen",
    "author_email": "nicklasbeyerlydersen@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/94/49/bd2fe0914a2b7d24c94315d86cd00a80e81d2c76935b5f3ebe1cd4f58fa1/pygame_core-0.1.32.tar.gz",
    "platform": null,
    "description": "# Pygame Core\r\n\r\n## Overview\r\n\r\n**Pygame Core** is a modular and reusable library designed to simplify the development of 2D games using the Pygame library. It provides essential components for managing game loops, scenes, input handling, and utility functions, allowing developers to focus on building their game's unique features.\r\n\r\n## Features\r\n\r\n- **Game Loop Management**: Simplifies the main game loop with FPS control.\r\n- **Scene Management**: Enables seamless transitions between game scenes (e.g., menus, gameplay).\r\n- **Input Handling**: Centralized input management for keyboards or other devices.\r\n- **Utilities**: Provides tools like collision detection and default settings.\r\n- **Extensibility**: Designed for easy customization and expansion.\r\n\r\n## Installation\r\n\r\nInstall the package using `pip`:\r\n\r\n```bash\r\npip install pygame-core\r\n```\r\n\r\n## Usage\r\n\r\n### Setting Up Your Game\r\n\r\nBelow is an example of how to use **Pygame Core** to create a simple game:\r\n\r\n```python\r\nimport pygame\r\nfrom core import Game, Scene, SceneManager\r\n\r\nclass MainMenu(Scene):\r\n    def update(self, input_manager):\r\n        if input_manager.is_pressed(pygame.K_RETURN):\r\n            return Gameplay(self.screen)\r\n\r\n    def render(self):\r\n        self.screen.fill((0, 0, 0))\r\n        font = pygame.font.Font(None, 74)\r\n        text = font.render(\"Press Enter to Start\", True, (255, 255, 255))\r\n        self.screen.blit(text, (150, 300))\r\n\r\nclass Gameplay(Scene):\r\n    def update(self, input_manager):\r\n        # Game logic goes here\r\n        pass\r\n\r\n    def render(self):\r\n        self.screen.fill((30, 30, 30))\r\n\r\nif __name__ == \"__main__\":\r\n    pygame.init()\r\n    screen = pygame.display.set_mode((800, 600))\r\n    pygame.display.set_caption(\"Pygame Core Example\")\r\n\r\n    manager = SceneManager(MainMenu(screen))\r\n    game = Game(screen)\r\n    game.run(manager)\r\n    pygame.quit()\r\n```\r\n\r\n### Key Components\r\n\r\n- **`Game`**: Manages the main game loop and FPS control.\r\n- **`Scene`**: A base class for creating game scenes with `update` and `render` methods.\r\n- **`SceneManager`**: Handles scene transitions.\r\n- **`InputManager`**: Provides a clean interface for checking key states.\r\n- **`Utils`**: Includes common utilities like collision detection.\r\n\r\n## Contributing\r\n\r\nContributions are welcome! To contribute:\r\n\r\n1. Fork the repository.\r\n2. Create a new branch for your feature or bug fix.\r\n3. Make your changes.\r\n4. Run a pylint `pylint core`\r\n5. Submit a pull request.\r\n\r\nPlease ensure all tests pass before submitting your PR.\r\n\r\n## License\r\n\r\nThis project is licensed under the MIT License. See the [LICENSE](LICENSE) file for more details.\r\n\r\n## Upload\r\n\r\n> Remember to update version number in `VERSION` file and delete the dist folder before uploading.\r\n\r\nBuild:\r\n\r\n```bash\r\npython -m build\r\n```\r\n\r\nUpload:\r\n\r\n```bash\r\npython -m twine upload dist/*\r\n```\r\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A modular core library for Pygame-based 2D games.",
    "version": "0.1.32",
    "project_urls": {
        "Homepage": "https://github.com/Nicklas185105/Pygame-Core",
        "Source": "https://github.com/Nicklas185105/Pygame-Core",
        "Wiki": "https://github.com/Nicklas185105/Pygame-Core/wiki"
    },
    "split_keywords": [
        "pygame",
        "game",
        "development",
        "engine"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "0b679162db94790c1338b08bb7f0934084e6fff874d443adab9274981aadcecb",
                "md5": "8e69a0b100a401fa2a260c3cd472f24a",
                "sha256": "9dec0bf590af8ea46fbf6bb3b161b9461f02de29a38d6ec17b7af2d676460eeb"
            },
            "downloads": -1,
            "filename": "pygame_core-0.1.32-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "8e69a0b100a401fa2a260c3cd472f24a",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 12886,
            "upload_time": "2024-12-30T23:38:57",
            "upload_time_iso_8601": "2024-12-30T23:38:57.589218Z",
            "url": "https://files.pythonhosted.org/packages/0b/67/9162db94790c1338b08bb7f0934084e6fff874d443adab9274981aadcecb/pygame_core-0.1.32-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "9449bd2fe0914a2b7d24c94315d86cd00a80e81d2c76935b5f3ebe1cd4f58fa1",
                "md5": "f7d850aa03aa52f188c1ab8a7bc3faaf",
                "sha256": "a5d6e735de5537c3b6fcf076cee9d91e57154f9fbb1d5ecd20e87b0cb9af831a"
            },
            "downloads": -1,
            "filename": "pygame_core-0.1.32.tar.gz",
            "has_sig": false,
            "md5_digest": "f7d850aa03aa52f188c1ab8a7bc3faaf",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 12863,
            "upload_time": "2024-12-30T23:39:01",
            "upload_time_iso_8601": "2024-12-30T23:39:01.840273Z",
            "url": "https://files.pythonhosted.org/packages/94/49/bd2fe0914a2b7d24c94315d86cd00a80e81d2c76935b5f3ebe1cd4f58fa1/pygame_core-0.1.32.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-30 23:39:01",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Nicklas185105",
    "github_project": "Pygame-Core",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "pygame-core"
}
        
Elapsed time: 0.38861s