Skip to main content

GPU-accelerated drawing primitives for pixtreme

Project description

pixtreme-draw

GPU-accelerated drawing primitives for pixtreme

Overview

pixtreme-draw provides high-performance drawing operations for rendering shapes, text, and masks directly on GPU memory.

Features

  • Shape Drawing: Circles, rectangles with anti-aliasing
  • Text Rendering: GPU-accelerated text with custom fonts
  • Mask Generation: Rounded masks for compositing
  • Zero-Copy: Direct GPU memory operations via CuPy

Installation

Requirements:

  • Python >= 3.12
  • CUDA Toolkit 12.x
  • NVIDIA GPU with compute capability >= 6.0
pip install pixtreme-draw

Requires pixtreme-core, pixtreme-filter, and CUDA Toolkit 12.x.

Quick Start

import pixtreme_draw as pd
import pixtreme_core as px

# Read image
img = px.imread("input.jpg")

# Draw filled circle
img = pd.circle(img, center_x=256, center_y=256, radius=100, color=(0.0, 1.0, 0.0))

# Draw filled rectangle
img = pd.rectangle(img, top_left_x=100, top_left_y=100, bottom_right_x=300, bottom_right_y=300, color=(1.0, 0.0, 0.0))

# Add text label with background
img = pd.add_label(img, text="Hello World", org=(50, 50), color=(1.0, 1.0, 1.0))

# Save result
px.imwrite("output.jpg", img)

API

Shape Drawing

# Circle (filled)
pd.circle(image, center_x, center_y, radius, color=(1.0, 1.0, 1.0))

# Rectangle (filled)
pd.rectangle(image, top_left_x, top_left_y, bottom_right_x, bottom_right_y, color=(1.0, 1.0, 1.0))

Text Rendering

# Simple text
pd.put_text(image, text, org, font_face=cv2.FONT_HERSHEY_SIMPLEX, font_scale=1.0, color=(1.0, 1.0, 1.0), thickness=2)

# Text with background label
pd.add_label(image, text, org=(0, 0), font_scale=1.0, color=(1.0, 1.0, 1.0), label_color=(0.0, 0.0, 0.0))

Mask Generation

# Rounded mask for compositing
mask = pd.create_rounded_mask(dsize=(512, 512), radius_ratio=0.1, blur_size=0, sigma=1.0)

License

MIT License - see LICENSE file for details.

Links

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

pixtreme_draw-0.7.3.tar.gz (13.6 kB view details)

Uploaded Source

Built Distribution

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

pixtreme_draw-0.7.3-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file pixtreme_draw-0.7.3.tar.gz.

File metadata

  • Download URL: pixtreme_draw-0.7.3.tar.gz
  • Upload date:
  • Size: 13.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.18

File hashes

Hashes for pixtreme_draw-0.7.3.tar.gz
Algorithm Hash digest
SHA256 9fba6c20a14343faf7f73a4b8796e95a4bbb7ad3aa1dd0d381322419ff5611ce
MD5 1bc4283a1afacb3dd0945d8bec682807
BLAKE2b-256 7039ee076ef6f77b221ba1c24a4e4f9db885950ee3da22fdabeff921efcac87c

See more details on using hashes here.

File details

Details for the file pixtreme_draw-0.7.3-py3-none-any.whl.

File metadata

File hashes

Hashes for pixtreme_draw-0.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 374ad419ca876fa06ce6e661272418f3aa8e44ed168c72561f96359c490f4587
MD5 46cd6e917c8491d5d8625cb7173291ac
BLAKE2b-256 65a238c437a7d0a2af4442c423ca560802b035de18c03620df062c418ed91b69

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