File Exchange

image thumbnail

Image blending functions

version 2.17.0.0 (6.98 MB) by DGM
Image blending with support for 4-D image sequences, influence scaling, and several uncommon modes

7 Downloads

Updated 19 Oct 2020

View Version History

View License

These tools effect image blending and masking functionality common in image manipulation applications such as GIMP, Krita, or Photoshop. For a layered image composition GUI based on this functionality, see the parent toolbox linked below.

================== BLENDING FUNCTION ==================
IMBLEND() can blend images or imagesets as one would blend layers in GIMP or Photoshop. See 'help imblend'
I assert that if nothing else, IMBLEND() stands as the single most comprehensive collection and demonstration of blend mode math from GIMP, ImageMagick, Photoshop, Krita, and elsewhere.

Inputs are image arrays of same H,V dimension; both can be single images or 4-D imagesets of equal length.
-- Mismatches of dimensions 1:2 are not supported. Use IMRESIZE, IMCROP, or PADARRAY
 to enforce desired colocation of layer content.
-- Mismatches of dimension 3:4 are handled by array expansion.

User can optionally specify compositing method independently of the blend method.

Unlike other image manipulation software, most blend and composition modes have been made parametric. This useful feature may allow the user to tailor the influence of blends in a manner which cannot be acheived using mixdown opacity, or control density/thresholding behavior in composition modes. See the synopsis for details.

This collection of blend modes is comprehensive; if a mode is not on this list, it is likely equivalent to one of the modes that is. The list of supported mode synonyms is in the synopsis.

Submission thumbnail shows contour plots for the majority of the non-component blend modes. Included in the zip file is a PDF containing this sheet as well as parameter sweeps and documentation of mathematical properties and relationships among modes.

COMPOSITION MODES:
gimp compatibility (default)
translucent
dissolve (8 variants)
src over
src atop
src in
src out
dst over
dst atop
dst in
dst out
xor

BLEND MODES:
==== Light & Contrast ====
softlight (5 variants)
overlay
hard light
linear light
vivid light
easy light
flat light (3 variants)
mean light (2 variants)
super light
pin light
hard mix (3 variants)
scale add
scale mult
contrast

==== Quadratic & Complements ====
glow
heat
reflect
freeze
frect
reeze
helow
gleat

==== Directional Pairs ====
color dodge & burn
linear dodge & burn
soft dodge & burn (3 variants)
easy dodge & burn
gamma dodge & burn
tint & shade
light & shadow
bright & dark
lighteneb & darkeneb

==== Relational ====
lighten RGB
darken RGB
lighten Y
darken Y
saturate
desaturate
near
far
replace color
exclude color

==== Mathematic ====
multiply
screen
divide
addition
subtraction
bleach
stain
difference
phoenix
exclusion
negation
sqrtdiff
compsqrtdiff
average
geometric
harmonic
interpolate
hard int
pnorm
arctan
curves
gammalight
gammadark
grain extract
grain merge

==== Mesh Modes ====
mesh
bomb
bomblocked
hard bomb

==== Modulo Modes ====
mod
mod shift
mod divide
cmod
cmod shift
cmod divide

==== Component ====
hue
saturation
color (5 variants)
value
luma
lightness
intensity
transfer inchan>outchan (directly transfer any channel to another)
permute inchan>H (rotate hue)
permute inchan>HS (rotate hue and blend saturation)

==== Specialty Modes ====
recolor lch
recolor hsly
blurmask
blurmask ring

================== MASKING FUNCTION ==================
Also included is REPLACEPIXELS() which effects an opacity blending similar to GIMP's 'Layer Mask' functionality. Accepts two input images and a mask. Foreground image may be replaced by a color triplet for convenience. REPLACEPIXELS() supports multichannel and multiframe masks, and can support NaN throughput if mask is logical.

Archive includes support functions for image conversion and typecasting. IP Toolbox is used for 'recolor' and 'blurmask' modes in IMBLEND, but is otherwise not required.

Documentation with commentary, example code, and input/output images is available here:
http://myplace.frontier.com/~chooks9592/manual/html/imblend.html
This is part of my image manipulation toolbox:
http://www.mathworks.com/matlabcentral/fileexchange/53786-image-manipulation-toolbox

Cite As

DGM (2020). Image blending functions (https://www.mathworks.com/matlabcentral/fileexchange/52513-image-blending-functions), MATLAB Central File Exchange. Retrieved .

Comments and Ratings (1)

Robert Riley

MATLAB Release Compatibility
Created with R2009b
Compatible with any release
Platform Compatibility
Windows macOS Linux
Acknowledgements

Inspired by: Colorspace Transformations

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!