It's a web application written in Python using the Flask framework and it allows users to editor images where users can upload their pictures and edit them using different tools and methods that the program provides.
To install the necessary dependencies, follow these steps:
1.Clone the APARTSTUDIO repository from GitHub:
`git clone https://github.com/yousefturin/APARTSTUDIO.git`
2.Navigate to the project directory:
`cd APARTSTUDIO/codes`
3.Create a virtual environment(optional but recommended):
`python3 -m venv env`
-
On macOS/Linux:
source env/bin/activate
-
On Windows:
env\Scripts\activate
4.Install the required Python packages:
`pip install -r requirements.txt`
5.Download the pre-trained models:
- Model 1: ColorizeArtistic_gen
Download the ColorizeArtistic_gen model. Extract the downloaded file and place it in the directory.
`APARTSTUDIO/codes/models/ColorizeArtistic_gen`
- Model 2: deeplabv3_resnet101_coco-586e9e4e
Download the deeplabv3_resnet101_coco-586e9e4e model. Extract the downloaded file and place it in the directory.
`APARTSTUDIO/codes/models/deeplabv3_resnet101_coco-586e9e4e`
- Model 3: RRDB_ESRGAN_x4 Model
Download the RRDB_ESRGAN_x4 model. Extract the downloaded file and place it in the directory.
`APARTSTUDIO/codes/models/RRDB_ESRGAN_x4`
This project utilizes the following technologies and dependencies:
- torch: A machine learning framework for image processing.
- Flask: A lightweight web framework for building the backend server.
- Werkzeug: A utility library for handling HTTP requests and responses.
- OpenCV: A computer vision library for image processing.
- NumPy: A library for numerical computations in Python.
- arch: A library for econometric modeling.
- PIL (Python Imaging Library): A library for image processing in Python.
- Other dependencies:
os
,base64
,sqlite3
,random
,schedule
,time
The project also utilizes the following external API:
- DiceBear Avatars API: An API for generating avatars dynamically using the avataaars style. The API endpoint used:
https://avatars.dicebear.com/api/avataaars/${randomSeed}.svg
This project incorporates the following models for image processing:
-
DeOldify: A deep learning model for colorizing black and white images.
-
ESRGAN: Enhanced Super-Resolution Generative Adversarial Networks, used for enhancing image quality.
-
resnet101 : A deep learning model, specifically the resnet101 architecture, used for background removal.
- Histogram Visualization
- Fix White-balance
- Fix Exposure
- Fix Contrast
- Fix Highlights
- Fix Shadows
- Fix White
- Fix Black
- Add Texture
- Add Clarity
- Add Dehaze
- Set Vibrance
- Set Saturation
- Clip The colors "Red/Orange/Yellow/Green/Sky-Blue/Blue/Purple/Pink" and Adjust (Hue, Saturation, Luminance)
- Add text and customize it with (Font size, Rotation, Color, Font Type and Font View)
- Add Blur
- Add Grin
- Crop The Image
- Resize the image using SCALORBUST
- Colorize images using DeOldif model
- Enhance images using ESRGAN model
- Remove Background using deeplabv3_resnet101 model
- Download The image in any Quality (100%, 75%, 50%, 25%). Any format (.jpg, .jpeg, .png). Any DPI(300dpi, 150dpi, 96dpi, 72dpi)
- Share The image on any platform with one click
We welcome contributions from the community to help improve APARTSTUDIO. If you encounter any bugs, visual problems, or non-responsive issues, or if you have ideas on making the website better, we would appreciate your input and assistance.
To contribute to the project, please follow these steps:
- Fork the repository and clone it to your local machine.
- Create a new branch for your contributions:
git checkout -b your-branch-name
. - Make your desired changes and improvements.
- Test your changes thoroughly.
- Commit your changes with a descriptive commit message:
git commit -m "Add your message here"
. - Push your changes to your forked repository:
git push origin your-branch-name
. - Open a pull request in this repository, describing your changes and contributions.
We appreciate your efforts in helping to make APARTSTUDIO a better web image editor. Thank you for your contributions!
If you have any questions or need further assistance, please feel free to reach out to us.
Mobile-Friendly Website: Our primary focus is to optimize the website for mobile devices and tablets. We aim to make APARTSTUDIO accessible and user-friendly across multiple platforms, ensuring a seamless experience for users on laptops, desktops, and mobile devices.
Enhanced Performance and User Experience: We plan to revamp the architecture for handling XMLHttpRequests to improve overall performance and responsiveness. By leveraging JavaScript for event handling and dynamically updating the user interface, we aim to minimize delays and provide a smoother user experience.
Text-to-Image Generation with OpenAI DALL·E: As part of our future development, we're excited to integrate OpenAI DALL·E into APARTSTUDIO. This powerful model allows users to generate images based on text descriptions, expanding the creative possibilities of our web image editor.
Database and User Authentication Improvements: We acknowledge the importance of database security and user authentication. Currently, we have implemented the login/logout functionality, but without any authentication mechanisms. To address this, we are actively working on enhancing our database and implementing robust user authentication features to ensure the privacy and security of our users' data.
These updates will significantly enhance APARTSTUDIO by addressing the mobile responsiveness, improving performance, and introducing a cutting-edge feature for text-to-image generation. We value user feedback and strive to create a robust and user-friendly platform for image editing.
This project is licensed under the terms of the APACHE License. See the LICENSE file for details.
This project makes use of the following external resources and models:
-
Colorize images using the DeOldify model:
-
Enhance images using the ESRGAN model:
-
Remove Background using the deeplabv3_resnet101 model: