-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy patheffects.py
148 lines (112 loc) · 5.08 KB
/
effects.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
from PIL import Image, ImageOps, ImageEnhance, ImageFilter
def _limit(command, param):
if param == "fade":
return 100
elif command == "quantize":
return 256
elif command == "rotate":
return 360
elif command == "autocontrast":
return 50
elif command == "posterize":
return 8
elif command == "solarize":
return 255
elif command == "unsharp_mask":
if param == "percent":
return 200
elif command in ["brightness", "color", "contrast", "sharpness"]:
return 200
elif command == "geek":
if param == "minus":
return 255
elif param == "times":
return 30
elif command == "hue":
return 128
def spread(image, distance=50, fade=100):
return Image.blend(image, image.effect_spread(distance), fade / 100)
def quantize(image, colors=128, fade=100):
return Image.blend(image, image.quantize(colors).convert("RGB"), fade / 100)
def rotate(image, degrees=45, fade=100):
return Image.blend(image, image.rotate(degrees), fade / 100)
def autocontrast(image, cutoff=0, fade=100):
return Image.blend(image, ImageOps.autocontrast(image, cutoff), fade / 100)
def equalize(image, fade=100):
return Image.blend(image, ImageOps.equalize(image), fade / 100)
def flip(image, fade=100):
return Image.blend(image, ImageOps.flip(image), fade / 100)
def grayscale(image, fade=100):
return Image.blend(image, ImageOps.grayscale(image).convert("RGB"), fade / 100)
def invert(image, fade=100):
return Image.blend(image, ImageOps.invert(image), fade / 100)
def mirror(image, fade=100):
return Image.blend(image, ImageOps.mirror(image), fade / 100)
def posterize(image, bits=4, fade=100):
return Image.blend(image, ImageOps.posterize(image, bits).convert("RGB"), fade / 100)
def solarize(image, threshold=128, fade=100):
return Image.blend(image, ImageOps.solarize(image, threshold), fade / 100)
def brightness(image, factor=50, fade=100):
return Image.blend(image, ImageEnhance.Brightness(image).enhance(factor / 100), fade / 100)
def color(image, factor=50, fade=100):
return Image.blend(image, ImageEnhance.Color(image).enhance(factor / 100), fade / 100)
def contrast(image, factor=50, fade=100):
return Image.blend(image, ImageEnhance.Contrast(image).enhance(factor / 100), fade / 100)
def sharpness(image, factor=50, fade=100):
return Image.blend(image, ImageEnhance.Sharpness(image).enhance(factor / 100), fade / 100)
def gaussian_blur(image, radius=2, fade=100):
return Image.blend(image, image.filter(ImageFilter.GaussianBlur(radius)), fade / 100)
def unsharp_mask(image, radius=2, percent=150, threshold=3, fade=100):
return Image.blend(image, image.filter(ImageFilter.UnsharpMask(radius, percent, threshold)), fade / 100)
def _run_total_rgb(x):
if x >= 128: x = 255
else: x = 0
return x
def total_rgb(image, fade=100):
return Image.blend(image, Image.eval(image, _run_total_rgb), fade / 100)
def geek(image, minus=254, times=15, fade=100):
return Image.blend(image, Image.eval(image, (lambda x: minus - x * times)), fade / 100)
def channel_drop(image, red=100, green=100, blue=100, fade=100):
return Image.blend(image, image.convert("RGB", (red / 100, 0, 0, 0,
0, green / 100, 0, 0,
0, 0, blue / 100, 0)), fade / 100)
def _run_sepia(image):
#Thank you TroJanzHEX for this command!
width, height = image.size
image_pixels = image.load()
for x in range(width):
for y in range(height):
red, green, blue = image_pixels[x, y]
new_val = 0.3 * red + 0.59 * green + 0.11 * blue
new_red = int(new_val * 2)
if new_red > 255:
new_red = 255
new_green = int(new_val * 1.5)
if new_green > 255:
new_green = 255
new_blue = int(new_val)
if new_blue > 255:
new_blue = 255
image_pixels[x, y] = (new_red, new_green, new_blue)
return image
def sepia(image, fade=100):
return Image.blend(image, _run_sepia(image), fade / 100)
def _run_tritone(image):
image = ImageOps.grayscale(image).convert("RGB")
width, height = image.size
image_pixels = image.load()
shadow_color = (255, 0, 0)
mid_color = (255, 128, 128)
high_color = (255, 255, 255)
for x in range(width):
for y in range(height):
red, green, blue = image_pixels[x, y]
if green <= 64 or blue <= 64:
image_pixels[x, y] = shadow_color
elif (green >= 64 and green <= 128) or (blue >= 64 and blue <= 128):
image_pixels[x, y] = mid_color
else:
image_pixels[x, y] = high_color
return image
def tritone(image, fade=100):
return Image.blend(image, _run_tritone(image), fade / 100)