2019-07-21 19:03:39 +08:00
|
|
|
"""
|
|
|
|
Changing contrast with PIL
|
|
|
|
|
|
|
|
This algorithm is used in
|
2020-03-04 20:40:28 +08:00
|
|
|
https://noivce.pythonanywhere.com/ Python web app.
|
2019-07-21 19:03:39 +08:00
|
|
|
|
2023-03-16 20:31:29 +08:00
|
|
|
psf/black: True
|
|
|
|
ruff : True
|
2019-07-21 19:03:39 +08:00
|
|
|
"""
|
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
|
2020-10-03 15:22:22 +08:00
|
|
|
def change_contrast(img: Image, level: int) -> Image:
|
2019-07-21 19:03:39 +08:00
|
|
|
"""
|
|
|
|
Function to change contrast
|
|
|
|
"""
|
|
|
|
factor = (259 * (level + 255)) / (255 * (259 - level))
|
|
|
|
|
2020-10-03 15:22:22 +08:00
|
|
|
def contrast(c: int) -> int:
|
2019-07-21 19:03:39 +08:00
|
|
|
"""
|
|
|
|
Fundamental Transformation/Operation that'll be performed on
|
|
|
|
every bit.
|
|
|
|
"""
|
2020-10-03 15:22:22 +08:00
|
|
|
return int(128 + factor * (c - 128))
|
2019-07-21 19:03:39 +08:00
|
|
|
|
|
|
|
return img.point(contrast)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
# Load image
|
|
|
|
with Image.open("image_data/lena.jpg") as img:
|
|
|
|
# Change contrast to 170
|
|
|
|
cont_img = change_contrast(img, 170)
|
|
|
|
cont_img.save("image_data/lena_high_contrast.png", format="png")
|