Metadata-Version: 2.2
Name: pythonGraphicalManipulator
Version: 0.1.0
Summary: A python library for graphical image manipulation
Home-page: https://github.com/salchaD-27/pythonGraphicalManipulator.git
Author: Dharyansh Achlas
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: Pillow>=9.0.0
Dynamic: author
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

pythonGraphicalManipulator
==========================

**pythonGraphicalManipulator** is a Python library designed for advanced image manipulation using pixel grids. It offers functions for resizing, cropping, color adjustments, and creative effects such as black-and-white conversion, color isolation, and brightness control. This library is ideal for developers working with custom image processing workflows.

Features
--------

*   **Image Manipulation**
    
    *   Resize and crop images.
        
    *   Flip images horizontally or vertically.
        
*   **Color Transformations**
    
    *   Convert images to black and white.
        
    *   Isolate or remove specific colors.
        
    *   Replace specific colors with new ones.
        
*   **Adjustments**
    
    *   Brightness, shadow intensity, and black point adjustments.
        
    *   Warmth and fade effects for aesthetic modifications.
        
*   **I/O Operations**
    
    *   Convert images to pixel grids and vice versa.
        
    *   Export pixel grids to text files for external processing.


## Installation

Install the library using `pip`:
`pip install pythonGraphicalManipulator`


Quick Start
-----------

Here’s how to get started with `pythonGraphicalManipulator`:

#### 1\. Convert an image to a pixel grid:

`from pythonGraphicalManipulator import imageToPixelGrid`
`pixelGrid = imageToPixelGrid("example.jpg")`

#### 2\. Apply a transformation:

`from pythonGraphicalManipulator import bnw`
`bnwGrid = bnw(pixelGrid)`

#### 3\. Convert back to an image:

`from pythonGraphicalManipulator import pixelGridToImage`
`pixelGridToImage(bnwGrid, "output.jpg")`

Available Methods
-----------------

### **Image Manipulation**

*   `imageToPixelGrid(imagePath, outputToTextFile=False, textFile=None)`
    
*   `pixelGridToImage(pixelGrid, outputImagePath)`
    
*   `resizeImage(pixelGrid, length, width)`
    
*   `cropImage(pixelGrid, top, left, right, bottom)`
    
*   `flipHoriz(pixelGrid)`
    
*   `flipVert(pixelGrid)`
    

### **Color Transformations**

*   `bnw(pixelGrid)`
    
*   `singleColorPop(pixelGrid, r, g, b, threshold=50)`
    
*   `singleColorRemove(pixelGrid, r, g, b, threshold=50)`
    
*   `changeColor(pixelGrid, r1, g1, b1, r2, g2, b2, threshold=0)`
    

### **Adjustments**

*   `adjustBrightness(pixelGrid, factor)`
    
*   `adjustShadowIntensity(pixelGrid, factor)`
    
*   `adjustBlackPoint(pixelGrid, level)`
    
*   `adjustWarmth(pixelGrid, factor)`
    

Tests
-----

The tests folder includes unit tests to validate the functionality of the library. To run the tests:
`python -m unittest discover tests`

Contributing
------------

Contributions are welcome! Please fork this repository and submit a pull request for any bug fixes or enhancements.

License
-------

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

Author
------

Developed by **Dharyansh Achlas** For any queries, feel free to contact **https://github.com/salchaD-27**
