Layer
Raffriff42 (Talk | contribs) m (one more touch-up) |
Raffriff42 (Talk | contribs) (small example image for each blend mode; remove old examples) |
||
Line 17: | Line 17: | ||
:{{Par2|op|string|"add"}} | :{{Par2|op|string|"add"}} | ||
::The merge operation to be performed, which can be one of the following: | ::The merge operation to be performed, which can be one of the following: | ||
− | ::{| class="wikitable" | + | <div style="max-width:56em;margin:0 0 0 3.5em" > |
+ | {| class="wikitable" | ||
|- | |- | ||
− | + | !style="min-width:4em"| Op | |
− | + | ! Example | |
+ | ! Description | ||
|- | |- | ||
− | | ''add'' | + | |style="vertical-align:top"| ''add'' |
− | | This is the default mode. Equivalent to [[Overlay]](mode="blend").<br>{{FuncArg|overlay_clip}} will be copied on top of the original, in proportion to {{FuncArg|level}}, and subject to the alpha channel. | + | |[[File:Layer-base-Lena.png]] [[File:Layer-over-grad.png]] |
+ | |||
+ | [[File:Layer-example-add.png]] | ||
+ | |style="vertical-align:top"| This is the default mode. Equivalent to [[Overlay]](mode="blend").<br>{{FuncArg|overlay_clip}} will be copied on top of the original, in proportion to {{FuncArg|level}}, and subject to the alpha channel. <br><br>The difference between {{FuncArg|base_clip}} and {{FuncArg|overlay_clip}} is multiplied with alpha and added to {{FuncArg|base_clip}}. | ||
+ | *alpha=0 → only {{FuncArg|base_clip}} visible | ||
+ | *alpha=128 → {{FuncArg|base_clip}} and {{FuncArg|overlay_clip}} equally blended | ||
+ | *alpha=255 → only {{FuncArg|overlay_clip}} visible | ||
+ | Formula used : | ||
+ | *RGB: [[File:Layer-Eq1.png]] | ||
+ | *YUY2: [[File:Layer-Eq2.png]] | ||
|- | |- | ||
− | | ''subtract'' | + | |style="vertical-align:top"| ''subtract'' |
− | | {{FuncArg|base_clip}} minus {{FuncArg|overlay_clip}}. <br>If both clips are equal and {{FuncArg|level}}=128, a flat gray field is returned; compare to [[Subtract]]. | + | |style="vertical-align:top"| [[File:Layer-example-sub.png]] |
+ | |style="vertical-align:top"| {{FuncArg|base_clip}} minus {{FuncArg|overlay_clip}}. The same as ''add'', but {{FuncArg|overlay_clip}} is inverted before adding.<br><br>If both clips are equal and {{FuncArg|level}}=128, a flat gray field is returned; compare to [[Subtract]]. | ||
|- | |- | ||
− | | ''lighten'' | + | |style="vertical-align:top"| ''lighten'' |
− | | Copy {{FuncArg|overlay_clip}} over {{FuncArg|base_clip}} in areas where {{FuncArg|overlay_clip}} is lighter.<br> Also known as [http://photoblogstop.com/photoshop/photoshop-blend-modes-explained ''lighter color.''] | + | |style="vertical-align:top"| [[File:Layer-example-lite.png]] |
+ | |style="vertical-align:top"| Copy {{FuncArg|overlay_clip}} over {{FuncArg|base_clip}} in areas where {{FuncArg|overlay_clip}} is lighter by {{FuncArg|threshold}}. <br><br>Performs the same operation as ''add'', but only when {{FuncArg|overlay_clip}} is BRIGHTER than {{FuncArg|base_clip}}. {{FuncArg|use_chroma}} must be ''true''. | ||
+ | <br> Also known as [http://photoblogstop.com/photoshop/photoshop-blend-modes-explained ''lighter color.''] | ||
|- | |- | ||
− | | ''darken'' | + | |style="vertical-align:top"| ''darken'' |
− | | Copy {{FuncArg|overlay_clip}} over {{FuncArg|base_clip}} in areas where {{FuncArg|overlay_clip}} is darker.<br> Also known as [http://photoblogstop.com/photoshop/photoshop-blend-modes-explained ''darker color.''] | + | | [[File:Layer-example-dark.png]] |
+ | |style="vertical-align:top"| Copy {{FuncArg|overlay_clip}} over {{FuncArg|base_clip}} in areas where {{FuncArg|overlay_clip}} is darker by {{FuncArg|threshold}}. <br><br>The same as "lighten", but it is performed only when {{FuncArg|overlay_clip}} is DARKER than {{FuncArg|base_clip}}. {{FuncArg|use_chroma}} must be ''true''. | ||
+ | <br>Also known as [http://photoblogstop.com/photoshop/photoshop-blend-modes-explained ''darker color.''] | ||
|- | |- | ||
− | | '' | + | |style="vertical-align:top"| ''mul'' |
− | | | + | |style="vertical-align:top"| [[File:Layer-example-mul-rgb.png]] |
+ | |style="vertical-align:top"| {{FuncArg|base_clip}} multiplied by {{FuncArg|overlay_clip}}. This will generally make the output darker. | ||
+ | *alpha=0 → only {{FuncArg|base_clip}} visible. | ||
+ | *alpha=255 → approx. the same luminance as {{FuncArg|base_clip}} but with the colors of {{FuncArg|overlay_clip}}. | ||
+ | See [http://docs.gimp.org/2.8/en/gimp-concepts-layer-modes.html#layer-mode-multiply GIMP: Multiply] | ||
|- | |- | ||
− | | '' | + | |style="vertical-align:top"| ''fast'' |
− | | {{FuncArg| | + | | |
+ | |style="vertical-align:top"| Like ''add'', but without masking. {{FuncArg|use_chroma}} must be ''true''; {{FuncArg|level}} and {{FuncArg|threshold}} are not used. The result is simply the average of {{FuncArg|base_clip}} and {{FuncArg|overlay_clip}}. | ||
|} | |} | ||
+ | |||
:{{Par2|level|int|(maximum)}} | :{{Par2|level|int|(maximum)}} | ||
Line 51: | Line 73: | ||
:{{Par2|threshold|int|0}} | :{{Par2|threshold|int|0}} | ||
− | ::Changes the transition point of {{FuncArg|op}}="darken" | + | ::Changes the transition point of {{FuncArg|op}} = "darken", "lighten." |
:{{Par2|use_chroma|bool|true}} | :{{Par2|use_chroma|bool|true}} | ||
− | ::Use chroma of the {{FuncArg|overlay_clip}}. Default=true. When false, only luma is used. | + | ::Use chroma of the {{FuncArg|overlay_clip}}. Default=true. When false, only luma is used. |
+ | ::Must be true for {{FuncArg|op}} = "darken", "lighten", "add." | ||
Line 66: | Line 89: | ||
*In [[RGB32]] the {{FuncArg|overlay_clip}} alpha channel is multiplied with {{FuncArg|level}}, so the resulting alpha = (alpha_mask * level + 1) / 256. <br>This means for full strength of operation, alpha has to be 255 and {{FuncArg|level}} has to be 257. | *In [[RGB32]] the {{FuncArg|overlay_clip}} alpha channel is multiplied with {{FuncArg|level}}, so the resulting alpha = (alpha_mask * level + 1) / 256. <br>This means for full strength of operation, alpha has to be 255 and {{FuncArg|level}} has to be 257. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
====Examples==== | ====Examples==== | ||
*'''Layer''' can be used to combine two captures of different broadcasts for reducing noise. A discussion of this idea can be found {{doom9|28438}}. Of course you have to ensure that the frames of the two clips match exactly -- use [[Trim]] or [[DeleteFrame]] as necessary. A sample script: | *'''Layer''' can be used to combine two captures of different broadcasts for reducing noise. A discussion of this idea can be found {{doom9|28438}}. Of course you have to ensure that the frames of the two clips match exactly -- use [[Trim]] or [[DeleteFrame]] as necessary. A sample script: | ||
Line 119: | Line 97: | ||
return Layer(clip1, clip2, "fast") | return Layer(clip1, clip2, "fast") | ||
</div> | </div> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
</div> | </div> | ||
Revision as of 12:14, 29 August 2016
Contents |
Layer
Layer (aka overlay, blend, merge) two clips of possibly different sizes, but with the same color format.
For pixel-wise transparency information the alpha channel of an RGB32 overlay_clip is used as a mask.
Layer( clip base_clip, clip overlay_clip [, string op, int level, int x, int y, int threshold, bool use_chroma ] )
- clip base_clip =
- The underlying clip, which determines the size and all other video and audio properties of the result.
- clip overlay_clip =
- The clip which is merged onto clip.
- string op = "add"
- The merge operation to be performed, which can be one of the following:
Op | Example | Description |
---|---|---|
add | This is the default mode. Equivalent to Overlay(mode="blend"). overlay_clip will be copied on top of the original, in proportion to level, and subject to the alpha channel. The difference between base_clip and overlay_clip is multiplied with alpha and added to base_clip.
Formula used : | |
subtract | base_clip minus overlay_clip. The same as add, but overlay_clip is inverted before adding. If both clips are equal and level=128, a flat gray field is returned; compare to Subtract. | |
lighten | Copy overlay_clip over base_clip in areas where overlay_clip is lighter by threshold. Performs the same operation as add, but only when overlay_clip is BRIGHTER than base_clip. use_chroma must be true.
| |
darken | Copy overlay_clip over base_clip in areas where overlay_clip is darker by threshold. The same as "lighten", but it is performed only when overlay_clip is DARKER than base_clip. use_chroma must be true.
| |
mul | base_clip multiplied by overlay_clip. This will generally make the output darker.
See GIMP: Multiply | |
fast | Like add, but without masking. use_chroma must be true; level and threshold are not used. The result is simply the average of base_clip and overlay_clip. |
- int level = (maximum)
- The strength of the performed operation:
- 0 – no effect: base_clip is returned unchanged
- 257 (256 for YUY2) – maximum strength
- The strength of the performed operation:
- int x = 0
- int y = 0
- offset position of overlay_clip
- int threshold = 0
- Changes the transition point of op = "darken", "lighten."
- bool use_chroma = true
- Use chroma of the overlay_clip. Default=true. When false, only luma is used.
- Must be true for op = "darken", "lighten", "add."
Audio, FrameRate and FrameCount are taken from the first clip.
There are some differences in the behaviour and the allowed parameter depending on the color format and the operation; here are the details:
- There is no mask (alpha channel) in YUY2, so the alpha channel is assumed to be fully opaque (255) everywhere.
- In RGB32 the overlay_clip alpha channel is multiplied with level, so the resulting alpha = (alpha_mask * level + 1) / 256.
This means for full strength of operation, alpha has to be 255 and level has to be 257.
Examples
- Layer can be used to combine two captures of different broadcasts for reducing noise. A discussion of this idea can be found here. Of course you have to ensure that the frames of the two clips match exactly -- use Trim or DeleteFrame as necessary. A sample script:
clip1 = AviSource("capture-pass-1.avi").ConvertToYUY2 clip2 = AviSource("capture-pass-2.avi").ConvertToYUY2.Trim(101, 0) return Layer(clip1, clip2, "fast")
Mask
Applies a defined alpha-mask to a clip, by converting RGB32-only mask_clip to greyscale and copying that greyscale information to the alpha channel of RGB32-only clip. In the alpha channel, "black" means transparent and "white" means opaque. For those of you who familiar with Photoshop masks, the concept is the same. In fact you can create a black and white photo in Photoshop, load it in your script and use it as a mask.
Mask(clip clip, clip mask_clip)
Examples
Suppose "ss.jpg" is a snapshot from a video clip, which served as a guideline to create the mask using Paint. We use ImageSource to load the image in the script and Mask to apply it.
bg = AviSource("01gray.avi").ConvertToRGB32 # here is the background clip mk = ImageSource("ss.jpg").ConvertToRGB32 # load the image top = AviSource("k3.avi").ConvertToRGB32.Mask(mk) # load the top layer clip and apply the mask to it Layer(bg, top) # layer the background and the top layer with mask
ResetMask
Applies an opaque (white) alpha channel to a clip. The alpha channel of an RGB32 clip is not always well-defined, depending on the source (it may contain random data); this filter is a fast way to apply an all-white mask.
ResetMask(clip clip)
ColorKeyMask
Clears pixels in the alpha channel by comparing to a transparent color (default black).
Each pixel with a color differing less than (tolB,tolR,tolG) (default 10) is set to transparent (black); otherwise it is left unchanged – note, it is NOT set to opaque (white). That's why you might need ResetMask before applying this filter. This behaviour allows an aggregate mask to be constructed with multiple calls to ColorKeyMask.
When tolR or tolG are not set, they get the value of tolB by default. Normally you start with a ResetMask, then chain a few calls to ColorKeyMask to cause transparent holes where each color of interest occurs. See Overlay for examples.
ColorKeyMask(clip clip, int color [, int tolB, int tolG, int tolR])
- clip clip =
- Source clip.
- int color = black
- Transparent color. Default black.
- int tolB = 10
- int tolG = (tolB)
- int tolR = (tolB)
- Color tolerance. See description above.
Changelog
v2.58 | ColorKeyMask: Added separate tolerance levels. |