Skip to content

Pixel art editor with generative AI functionality. Comp229 Group Project.

License

Notifications You must be signed in to change notification settings

ConnorBP/pixel-intelligence

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pixel Intelligence Netlify Status

Latest live demo can be viewed on Netlify

Overview

Pixel Intelligence is a full-stack pixel art editor application with generative AI functionality through stablehorde, image downscale processing, image export, and a showcase gallery. This project was developed as part of the Comp229 Group Project (Fall 2024).

picture of the editor page picture of the gallery page picture of the gallery page with image details overlay

Features

Editor

  • Maximum canvas size of 64px by 64px
  • Minimum canvas size of 8px by 8px
  • Resolution selection and adjustment while editing
  • Drawing tools: pencil, eraser, clear, eyedropper, and fill-bucket
  • Color selection with primary/secondary colors
  • Project save/load functionality
  • PNG image export
  • Image import with k-means clustering down-scaling
  • Transparency support
  • Share directly to gallery

Gallery

  • Paginated image display
  • Image metadata and details view
  • Project file storage
  • Dynamic image rendering from stored data
  • Client-side caching
  • Sort by newest first

AI Integration

  • Image generation via Horde AI API
  • Optimized for pixel art style output
  • Generation prompt on canvas creation

Backend

  • Node + Express JS
  • API routes can be run as a traditional Express JS server or as a netlify serverless function
  • Mongo DB for storing gallery listings
  • User sessions for gallery API use JWT (Json Web Tokens)

Current Implementation Status

Completed

  • Full-featured pixel art editor
  • Gallery system with pagination
  • Project file save/load
  • Image import/export
  • Dynamic image rendering
  • Client-side caching

In Progress

Stretch Goals Status

  • ✅ Extended metadata support
  • ✅ Image scaling in editor
  • ❌ Crochet pattern export
  • ❌ URL share codes
  • ❌ Extended color palettes
  • ❌ Additional file formats
  • ❌ User login system
  • ❌ Undo-redo support

Why We Made It

The goal of this project is to provide a comprehensive tool for creating and sharing pixel art. By integrating generative AI, we aim to enhance the creative process and offer unique features that set this editor apart from others.

Getting Started

Prerequisites

  • Node.js (v14 or higher)
  • npm (v6 or higher)

Installation

  1. Clone the repository:

    git clone https://github.com/ConnorBP/pixel-intelligence.git
    cd pixel-intelligence
  2. Install dependencies for the main project:

    npm install
  3. Install dependencies for the frontend:

    cd frontend
    npm install
    cd ..
  4. Install dependencies for the backend:

    cd backend
    npm install
    cd ..
  5. Set up the environment variables Variables can be found example.env

    cp ./backend/example.env ./backend/.env
    vim .env

Running the Project

To start the development server, run:

npm run dev

This will concurrently start both the frontend and backend servers.

Building the Project

To build the project for production, run:

npm run build

This will build the frontend and prepare the backend for deployment.

Contributing

We welcome contributions! Please read our contributing guidelines for more details.

License

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

Authors

  • ConnorBP
  • sanjeev-cs
  • superYM222
  • Parmilashams

Acknowledgements

Special thanks to our instructors and peers for their support and feedback throughout this project.