Skip to main content

Pixel Generator

Project description

PixelGen

PixelGen is a Python library that simplifies pixel art creation, making it faster and more detailed. This library provides various tools to create, manipulate, and generate pixel art.

🚀 Features

  • Create pixel art canvas with customizable dimensions
  • Individual pixel manipulation
  • Area filling with colors
  • Color gradient generation
  • Pattern creation
  • Save results in image format

📦 Installation

pip install pixelgen

🎨 Basic Usage

Creating Simple Pixel Art

from pixelgen.core import PixelGenerator
from pixelgen.tools import create_gradient, create_pattern

# Initialize a 32x32 canvas
pixel_art = PixelGenerator(32, 32)

# Set individual pixels
pixel_art.set_pixel(0, 0, (255, 0, 0))  # Red
pixel_art.set_pixel(1, 1, (0, 255, 0))  # Green

# Fill area with color
pixel_art.fill_area(10, 10, 20, 20, (0, 0, 255))  # Blue area

# Save result
pixel_art.save_image("pixel_art_result.png")

Creating Gradients

# Create gradient from red to blue with 10 steps
gradient = create_gradient((255, 0, 0), (0, 0, 255), 10)

Creating Patterns

# Create 8x8 checkered pattern
pattern = create_pattern(8, (255, 0, 0), (0, 0, 255))

📚 API Reference

PixelGenerator

__init__(width: int, height: int)

Creates a new pixel art canvas with specified dimensions.

set_pixel(x: int, y: int, color: tuple)

Sets color for a specific pixel.

  • x, y: Pixel coordinates
  • color: RGB tuple (red, green, blue)

fill_area(x1: int, y1: int, x2: int, y2: int, color: tuple)

Fills a rectangular area with a specific color.

  • x1, y1: Top-left corner coordinates
  • x2, y2: Bottom-right corner coordinates
  • color: RGB tuple (red, green, blue)

save_image(filename: str)

Saves pixel art as an image file.

  • filename: Output filename

Tools

create_gradient(color1: tuple, color2: tuple, steps: int)

Creates a gradient between two colors.

  • color1: Starting color (RGB)
  • color2: Ending color (RGB)
  • steps: Number of gradient steps

create_pattern(pattern_size: int, color1: tuple, color2: tuple)

Creates a checkered pattern.

  • pattern_size: Pattern size
  • color1, color2: Colors for pattern (RGB)

🌟 Advanced Examples

Creating Complex Patterns

# Create a rainbow gradient
colors = [
    (255, 0, 0),    # Red
    (255, 127, 0),  # Orange
    (255, 255, 0),  # Yellow
    (0, 255, 0),    # Green
    (0, 0, 255),    # Blue
    (75, 0, 130),   # Indigo
    (148, 0, 211)   # Violet
]

# Apply gradient to canvas
for i, color in enumerate(colors):
    pixel_art.fill_area(i*4, 0, (i+1)*4, 32, color)

🔧 Requirements

  • Python >= 3.6
  • PIL >= 5.2.0
  • NumPy

🤝 Contributing

Contributions are always welcome! Please feel free to submit a Pull Request or create an Issue for any improvements or suggestions.

Development Setup

  1. Clone the repository
git clone https://github.com/rifqanzalbina/product-generator.git
  1. Install development dependencies
pip install -r requirements.txt
  1. Run tests
python -m pytest

📝 License

This project is licensed under the MIT License - see the LICENSE file for details.

👤 Author

🔗 Links

🗺️ Roadmap

  • Add more pattern generation tools
  • Implement layer system
  • Add undo/redo functionality
  • Add AI-powered pixel art generation
  • Implement real-time preview
  • Add export to multiple formats

❓ FAQ

Q: Can I use this for commercial projects? A: Yes, PixelGen is released under the MIT license, which allows commercial use.

Q: What image formats are supported? A: Currently, PixelGen supports saving to common image formats like PNG, JPEG, and BMP.

Q: Is there a size limit for pixel art? A: The size is limited only by your system's memory capacity.

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

pixelgen-0.0.3.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pixelgen-0.0.3-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file pixelgen-0.0.3.tar.gz.

File metadata

  • Download URL: pixelgen-0.0.3.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.6

File hashes

Hashes for pixelgen-0.0.3.tar.gz
Algorithm Hash digest
SHA256 d30436501537e3b66b0bf09db92d63b9c2c56fd3ebe615de977417dd0c7402b6
MD5 52498b1f08e4ad534fffd74cb278edf9
BLAKE2b-256 05935decfd66da509541986decb516cf6889e38271c13d20b42f1d93187b736d

See more details on using hashes here.

File details

Details for the file pixelgen-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: pixelgen-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 5.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.6

File hashes

Hashes for pixelgen-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 93624c2ada722046b0e88e54b2861a22adf28f0b8317334087e5564fda83d4c4
MD5 56be2fecb8a49334ecc57961ee908f81
BLAKE2b-256 5b64df7a1de6fb355a3bc5d93b6d474c91f1c97b9fb90d445986d05b7d735bf7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page