Skip to content

Features include freehand drawing, geometric shapes, shape modifications (resize, recolor, rotate, duplicate), and save/load functionality in JSON and XML formats. Built with React (frontend) and Spring Boot (backend)

Notifications You must be signed in to change notification settings

HuzaifaOmar/Paint

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Web Based Paint Application

image This is Our Third Assignment in Design Patterns Course (CSED27 Alexandria University)

🌟Project Objectives

  • Design an object-oriented model for geometric shapes.
  • Draw a UML class diagram that represents your model.
  • Apply the OOP concepts of inheritance and polymorphism to your design.
  • Create an advanced UI with 2D Graphics capabilities.
  • Dealing with JSON for requests and responses handling.

📜Project Description

A web Application that has all the features of any paint application beside saving and loading the files in 2 formats.

🔧Technologies Used

Frontend

  • React: For building a dynamic and responsive user interface.
  • React-Konva: For advanced canvas manipulation.
  • React-Color: For a user-friendly color picker.
  • FontAwesome: For visually appealing icons.
  • Axios: For making HTTP requests to the backend.

Backend

  • Spring Boot: For managing RESTful APIs and handling backend logic.

Data Format

  • JSON: Drawings are saved as JSON files for easy storage and reusability.

🛠️Setup and Installation

Prerequisites

  • Node.js and npm installed.
  • Java JDK 11 or higher installed.

Steps

Frontend

  1. Clone the repository:

    git clone https://github.com/omarzydan610/Paint.git  
    cd Paint/frontend  
  2. Install dependencies:

    npm install  
  3. Start the development server:

    npm start  

    The application will be available at http://localhost:3000.

Backend

  1. Navigate to the backend directory:

    cd ../backend  
  2. Build the Spring Boot application:

    ./mvnw package  
  3. Run the backend server:

    java -jar target/paint-application.jar  

    The backend server will run at http://localhost:8080.

🚀System Features

  • Advanced UI with 2D capabilities
  • Free hand drawing
  • Geometric shapes drawing
  • shapes modifications
    • Draw
    • Delete
    • Move
    • ReColor
    • ReSize
    • Rotate
    • Duplicate
  • Undo & Redo
  • Save & Load using 2 different file types (XML, JSON)

Implemented Design Patterns

  • Factory Design Pattern
  • Prototype Design Pattern
  • Command Design Pattern
  • Dependency Injection (springboot)
  • Singleton Pattern (springboot)

Demo

Demo

For more detalied information check Project Report

About

Features include freehand drawing, geometric shapes, shape modifications (resize, recolor, rotate, duplicate), and save/load functionality in JSON and XML formats. Built with React (frontend) and Spring Boot (backend)

Resources

Stars

Watchers

Forks

Languages

  • Java 49.8%
  • JavaScript 43.2%
  • CSS 5.6%
  • HTML 1.4%