def test_brightness_greater_than_1(): im = util.fill((4, 4), [174, 56, 3]) im_b = css.brightness(im, 2) im_b2 = css.brightness(im, 1) assert list(im_b.getdata()) != list(im_b2.getdata()) assert im_b.size == im.size assert im_b.mode == im.mode
def test_brightness_hsv(): im = util.fill((4, 4), [174, 56, 3]) im2 = im.convert('HSV') im_b = css.brightness(im) im_b2 = css.brightness(im2) im_b2_rgb = im_b2.convert('RGB') assert list(im_b.getdata()) == list(im_b2_rgb.getdata()) assert im_b2.size == im2.size assert im_b2.mode == im2.mode
def rise(im): """Applies Rise filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.fill(cb.size, [236, 205, 169, .15]) cm1 = css.blending.multiply(cb, cs1) cs2 = util.fill(cb.size, [50, 30, 7, .4]) cm2 = css.blending.multiply(cb, cs2) gradient_mask1 = util.radial_gradient_mask(cb.size, length=.55) cm = Image.composite(cm1, cm2, gradient_mask1) cs3 = util.fill(cb.size, [232, 197, 152, .8]) cm3 = css.blending.overlay(cm, cs3) gradient_mask2 = util.radial_gradient_mask(cb.size, scale=.9) cm_ = Image.composite(cm3, cm, gradient_mask2) cr = Image.blend(cm, cm_, .6) # opacity cr = css.brightness(cr, 1.05) cr = css.sepia(cr, .2) cr = css.contrast(cr, .9) cr = css.saturate(cr, .9) return cr
def test_brightness(): im = util.fill((4, 4), [174, 56, 3]) im_b = css.brightness(im) assert list(im_b.getdata()) == list(im.getdata()) assert im_b.size == im.size assert im_b.mode == im.mode
def nashville(im): """Applies Nashville filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.fill(cb.size, [247, 176, 153]) cm1 = ImageChops.darker(cb, cs1) cm1 = Image.blend(cb, cm1, .56) cs2 = util.fill(cb.size, [0, 70, 150]) cm2 = ImageChops.lighter(cm1, cs2) cr = Image.blend(cm1, cm2, .4) cr = css.sepia(cr, .2) cr = css.contrast(cr, 1.2) cr = css.brightness(cr, 1.05) cr = css.saturate(cr, 1.2) return cr
def brooklyn(im): """Applies Brooklyn filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.fill(cb.size, [168, 223, 193, .4]) cm1 = css.blending.overlay(cb, cs1) cs2 = util.fill(cb.size, [196, 183, 200]) cm2 = css.blending.overlay(cb, cs2) gradient_mask = util.radial_gradient_mask(cb.size, length=.7) cr = Image.composite(cm1, cm2, gradient_mask) cr = css.contrast(cr, .9) cr = css.brightness(cr, 1.1) return cr
def test_brightness_0(): im = util.fill((4, 4), [174, 56, 3]) black = util.fill((4, 4), [0] * 3) im_b = css.brightness(im, 0) assert list(im_b.getdata()) == list(black.getdata()) assert im_b.size == im.size assert im_b.mode == im.mode
def inkwell(im): """Applies Inkwell filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cr = css.sepia(cb, .3) cr = css.contrast(cr, 1.1) cr = css.brightness(cr, 1.1) cr = css.grayscale(cr) return cr
def gingham(im): """Applies Gingham filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [230, 230, 250]) cr = css.blending.soft_light(cb, cs) cr = css.brightness(cr, 1.05) cr = css.hue_rotate(cr, -10) return cr
def toaster(im): """Applies Toaster filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.radial_gradient(cb.size, [(128, 78, 15), (59, 0, 59)]) cr = css.blending.screen(cb, cs) cr = css.contrast(cr, 1.5) cr = css.brightness(cr, .9) return cr
def _1977(im): """Applies 1977 filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [243, 106, 188, .3]) cr = css.blending.screen(cb, cs) cr = css.contrast(cr, 1.1) cr = css.brightness(cr, 1.1) cr = css.saturate(cr, 1.3) return cr
def stinson(im): """Applies Stinson filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [240, 149, 128, .2]) cr = css.blending.soft_light(cb, cs) cr = css.contrast(cr, .75) cr = css.saturate(cr, .85) cr = css.brightness(cr, 1.15) return cr
def maven(im): """Applies Maven filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [3, 230, 26, .2]) cr = css.blending.hue(cb, cs) cr = css.sepia(cr, .25) cr = css.brightness(cr, .95) cr = css.contrast(cr, .95) cr = css.saturate(cr, 1.5) return cr
def valencia(im): """Applies Valencia filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [58, 3, 57]) cs = css.blending.exclusion(cb, cs) cr = Image.blend(cb, cs, .5) cr = css.contrast(cr, 1.08) cr = css.brightness(cr, 1.08) cr = css.sepia(cr, .08) return cr
def reyes(im): """Applies Reyes filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [239, 205, 173]) cs = css.blending.soft_light(cb, cs) cr = Image.blend(cb, cs, .5) cr = css.sepia(cr, .22) cr = css.brightness(cr, 1.1) cr = css.contrast(cr, .85) cr = css.saturate(cr, .75) return cr
def walden(im): """Applies Walden filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [0, 68, 204]) cs = ImageChops.screen(cb, cs) cr = Image.blend(cb, cs, .3) cr = css.brightness(cr, 1.1) cr = css.hue_rotate(cr, -10) cr = css.sepia(cr, .3) cr = css.saturate(cr, 1.6) return cr
def hudson(im): """Applies Hudson filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.radial_gradient(cb.size, [(166, 177, 255), (52, 33, 52)], [.5, 1]) cs = css.blending.multiply(cb, cs) cr = Image.blend(cb, cs, .5) # opacity cr = css.brightness(cr, 1.2) cr = css.contrast(cr, .9) cr = css.saturate(cr, 1.1) return cr
def slumber(im): """Applies Slumber filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.fill(cb.size, [69, 41, 12, .4]) cm = css.blending.lighten(cb, cs1) cs2 = util.fill(cb.size, [125, 105, 24, .5]) cr = css.blending.soft_light(cm, cs2) cr = css.saturate(cr, .66) cr = css.brightness(cr, 1.05) return cr
def moon(im): """Applies Moon filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.fill(cb.size, [160, 160, 160]) cs = css.blending.soft_light(cb, cs1) cs2 = util.fill(cb.size, [56, 56, 56]) cr = css.blending.lighten(cs, cs2) cr = css.grayscale(cr) cr = css.contrast(cr, 1.1) cr = css.brightness(cr, 1.1) return cr
def aden(im): """Applies Aden filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs = util.fill(cb.size, [66, 10, 14]) cs = ImageChops.darker(cb, cs) alpha_mask = util.linear_gradient_mask(cb.size, start=.8) cr = Image.composite(cs, cb, alpha_mask) cr = css.hue_rotate(cr, -20) cr = css.contrast(cr, .9) cr = css.saturate(cr, .85) cr = css.brightness(cr, 1.2) return cr
def willow(im): """Applies Willow filter. Arguments: im: An input image. Returns: The output image. """ cb = util.or_convert(im, 'RGB') cs1 = util.radial_gradient(cb.size, [(212, 169, 175), (0, 0, 0)], [.55, 1.5]) cm1 = css.blending.overlay(cb, cs1) cs2 = util.fill(cb.size, [216, 205, 203]) cr = css.blending.color(cm1, cs2) cr = css.grayscale(cr, .5) cr = css.contrast(cr, .95) cr = css.brightness(cr, .9) return cr
def test_brightness_less_than_0(): with pytest.raises(AssertionError): im = util.fill((4, 4), [174, 56, 3]) css.brightness(im, -1)