This is Our Third Assignment in Design Patterns Course (CSED27 Alexandria University)
- 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.
A web Application that has all the features of any paint application beside saving and loading the files in 2 formats.
- 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.
- Spring Boot: For managing RESTful APIs and handling backend logic.
- JSON: Drawings are saved as JSON files for easy storage and reusability.
- Node.js and npm installed.
- Java JDK 11 or higher installed.
-
Clone the repository:
git clone https://github.com/omarzydan610/Paint.git cd Paint/frontend
-
Install dependencies:
npm install
-
Start the development server:
npm start
The application will be available at
http://localhost:3000
.
-
Navigate to the backend directory:
cd ../backend
-
Build the Spring Boot application:
./mvnw package
-
Run the backend server:
java -jar target/paint-application.jar
The backend server will run at
http://localhost:8080
.
- 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)
- Factory Design Pattern
- Prototype Design Pattern
- Command Design Pattern
- Dependency Injection (springboot)
- Singleton Pattern (springboot)