MaskHS

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (1 revision)
m
 
(10 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Template:FuncDef|MaskHS(clip [, int ''startHue'', int ''endHue'', int ''maxSat'', int ''minSat'', bool ''coring''])}}
+
<div style="max-width:82em; min-width:42em;" >
  
Added in v2.6. This filter returns a mask (as Y8) of clip using a given hue and saturation range.
+
<div {{BlueBox2|40|0|3px solid purple}} >
 +
{{AvsPlusFullname}}<br>
 +
Up-to-date documentation: [https://avisynthplus.readthedocs.io/en/latest/avisynthdoc/corefilters/maskhs.html https://avisynthplus.readthedocs.io]
 +
</div>
  
''startHue'' (default 0), ''endHue'' (default 360): (both from 0 to 360; given in degrees.). The hue and saturation will be adjusted for values in the range [startHue, endHue] when startHue<endHue. Note that the hue is periodic, thus a hue of 360 degrees corresponds with a hue of zero degrees. If endHue<startHue then the range [endHue, 360] and [0, startHue] will be selected (thus anti-clockwise). If you need to select a range of [350, 370] for example, you need to specify startHue=370 and endHue=350. Thus when using the default values all pixels will be processed.
 
  
''maxSat'' (default 150), ''minSat'' (default 0): (both from 0 to 150 with minSat<maxSat; given in percentages). The hue and saturation will be adjusted for values in the range [minSat, maxSat]. Practically the saturation of a pixel will be in the range [0,100] (thus 0-100%), since these correspond to valid RGB pixels (100% corresponds to R=255, G=B=0, which has a saturation of 119). An overshoot (up to 150%) is allowed for non-valid RGB pixels (150% corresponds to U=V=255, which has a saturation of sqrt(127^2+127^2) = 180). Thus when using the default values all pixels will be processed.
+
Returns a mask (as [[Y8]]) of clip using a given hue and saturation range. Added in v2.6.
  
''coring'' = true/false (default true). When set to true, the luma (Y) is clipped to [16,235]; when set to false, the luma is left untouched.
 
  
Suppose we want to create a mask of the skin of the girl. The proper way to do this is to look at the vectorscope of [[Histogram]]:
+
== Syntax and Parameters ==
 +
<div style="max-width:62em" >
 +
{{FuncDef
 +
|MaskHS(clip [, int ''startHue'', int ''endHue'', int ''maxSat'', int ''minSat'', bool ''coring'' ] )
 +
}}
  
clip = ...
+
{{FuncDef
Histogram(clip, mode="color2")
+
|MaskHS(clip [, int ''startHue'', int ''endHue'', int ''maxSat'', int ''minSat'', bool ''coring'',
 +
bool ''realcalc'' ] ) {{AvsPluscon}}
 +
}}
  
and estimate the hue range you want to select. As can be seen, the orange hue is between (about) 105 and 165 degrees.
+
:{{Par2|startHue|int|0}}
 +
:{{Par2|endHue|int|360}}
 +
::The resulting mask will contain source values in the range [{{FuncArg|startHue}}, {{FuncArg|endHue}}] when {{FuncArg|startHue}}<{{FuncArg|endHue}}. Note that the hue is periodic, thus a hue of 360 degrees corresponds with a hue of zero degrees.  
  
Lower the hue range till you found the correct hue range which should be processed. Use the values in MaskHS and make the interval smaller till the correct one is selected. You can also use Tweak for this (with sat=0). Using the example in [[Tweak]], the following mask is obtained:
+
::If {{FuncArg|endHue}}<{{FuncArg|startHue}} then the range [{{FuncArg|endHue}}, 360] and [0, {{FuncArg|startHue}}] will be selected (thus anti-clockwise). If you need to select a range of [350, 370] for example, you need to specify {{FuncArg|startHue}}=370, {{FuncArg|endHue}}=350.
  
{|border=1 cellspacing=1 cellpadding=4
+
::Range 0 to 360 (degrees), default 0, 360; thus when using the default values, all pixels will be processed.
| [[Image:Tweak_original2.jpg]]
+
 
| [[Image:Maskhs.jpg]]
+
::The following shows some arbitrary {{FuncArg|startHue}} and {{FuncArg|endHue}} values for the basic colors, with a [[Histogram#Color2_mode|Histogram vectorscope]] to illustrate the color circle:
 +
::{| class="wikitable" border="1" style="text-align:center"
 +
|style="width:6em" | '''Color'''
 +
|style="width:6em" | '''startHue'''
 +
|style="width:6em" | (center)
 +
|style="width:6em" | '''endHue'''
 +
|rowspan="7"| [[File:Labeled-vector-color2.png|right]]
 +
|-
 +
|style="text-align:left" | Red
 +
|style="background:#D926B9; color: #EEEEEE" | 075
 +
|style="background:#D90000; color: #EEEEEE" | 102
 +
|style="background:#D93B26; color: #EEEEEE" | 115
 +
|-
 +
|style="text-align:left" | Yellow
 +
|style="background:#D99D26; color: #121212" | 150
 +
|style="background:#D9D900; color: #121212" | 176
 +
|style="background:#D5D926; color: #121212" | 180
 +
|-
 +
|style="text-align:left" | Green
 +
|style="background:#9DD926; color: #121212" | 191
 +
|style="background:#00D900; color: #121212" | 230
 +
|style="background:#26D97A; color: #121212" | 258
 +
|-
 +
|style="text-align:left" | Cyan
 +
|style="background:#26D9B9; color: #121212" | 279
 +
|style="background:#00D9D9; color: #121212" | 282
 +
|style="background:#26B2D9; color: #121212" | 300
 +
|-
 +
|style="text-align:left" | Blue
 +
|style="background:#2688D9; color: #EEEEEE" | 316
 +
|style="background:#0000D9; color: #EEEEEE" | 000
 +
|style="background:#5026D9; color: #EEEEEE" | 004
 +
|-
 +
|style="text-align:left" | Magenta
 +
|style="background:#9626D9; color: #EEEEEE" | 028
 +
|style="background:#D900D9; color: #EEEEEE" | 048
 +
|style="background:#D526D5; color: #EEEEEE" | 052
 +
|}
 +
 
 +
:{{Par2|maxSat|int|150}}
 +
:{{Par2|minSat|int|0}}
 +
::The resulting mask will contain source values in the range [{{FuncArg|minSat}}, {{FuncArg|maxSat}}].
 +
 
 +
::Practically the saturation of a pixel will be in the range [0,100] (thus 0-100%), since these correspond to valid RGB pixels (100% corresponds to R=255, G=B=0, which has a saturation of 119). An overshoot (up to 150%) is allowed for non-valid RGB pixels (150% corresponds to U=V=255, which has a saturation of sqrt(127<sup>2</sup>+127<sup>2</sup>) = 180).
 +
::{{AvsPluscon}} [[TODO]] needs documentation of behavior with {{Deep_color}} formats.
 +
 
 +
::Range 0 to 150 (percent), default 150, 0; thus when using the default values all pixels will be processed.
 +
 
 +
:{{Par2|coring|bool|true}}
 +
::When set to true, the luma (Y) is clipped to TV-range; when set to false, the luma is left untouched.
 +
 
 +
{{HiddenAnchor|realcalc}}
 +
:{{Par2|realcalc|bool|false}}
 +
::{{AvsPluscon}} When true, force 'no-lookup': pure float calculation of new pixel values (always true for certain {{Deep_color}} formats) ([[TODO]] - clarify)
 +
</div>
 +
 
 +
 
 +
== Examples ==
 +
<div style="max-width:62em" >
 +
*Suppose we want to create a mask of the skin of the girl below. The proper way to do this is to look at the vectorscope of [[Histogram#Color2_mode|Histogram]]:
 +
:{|border=0
 +
|<pre style="width:22em">
 +
clip = ...
 +
Histogram(clip, mode="color2")
 +
</pre>
 +
|-
 +
|[[File:Tweak_original2_plus_hist.jpg]]
 +
|}
 +
:and estimate the hue range you want to select. As can be seen, the orange hue is between (about) 105 and 165 degrees.
 +
:''Note: axis labels have been added to the vectorscope as a guide &ndash; they are not generated by the above script''
 +
 
 +
:Start with a wide hue range and narrow it until the output of '''MaskHS''' isolates the range of interest. You can also use [[Tweak]] to preview the affected range (with ''sat''=0), as the arguments are compatible.
 +
 
 +
:In our example we end at {{FuncArg|startHue}}=105, {{FuncArg|endHue}}=138, and the following mask is obtained:
 +
:{|border=0
 +
|<pre style="width:22em" >
 +
clip = ...
 +
MaskHS(startHue=105, endHue=138)
 +
</pre>
 
|-
 
|-
| original
+
|[[File:Maskhs.jpg]]
| MaskHS(startHue=105, endHue=138)
+
 
|}
 
|}
  
Looking at the blue screen example in [[Overlay]] the following can be used
 
  
  testcard = ColorBars()
+
*Looking at the blue screen example in [[Overlay]] the following can be used
 +
<div {{BoxWidthIndent|56|1}} >
 +
  testcard = [[ColorBars]]
 
   
 
   
 
  # example subtitle file with blue background:
 
  # example subtitle file with blue background:
  subs = ImageSource("F:\TestClips\blue.jpg").ConvertToYV24
+
  subs = [[ImageSource]]("F:\TestClips\blue.jpg").[[ConvertToYV24]]
 
   
 
   
 
  # subs.Histogram(mode="color2").ConvertToRGB # blue in [345,359]
 
  # subs.Histogram(mode="color2").ConvertToRGB # blue in [345,359]
  mask_hs = subs.MaskHS(startHue=340, endHue=359).Levels(0, 1, 255, 255, 0)
+
  mask_hs = subs.MaskHS(startHue=340, endHue=359).[[Levels]](0, 1, 255, 255, 0)
 
   
 
   
  Overlay(testcard, subs, mask=mask_hs, mode="blend", opacity=1)
+
  [[Overlay]](testcard, subs, mask=mask_hs, mode="blend", opacity=1)
 +
</div>
 +
</div>
  
'''Changelog:'''
+
== Changelog ==
  
 
{|border=1 cellspacing=1 cellpadding=4
 
{|border=1 cellspacing=1 cellpadding=4
Line 44: Line 133:
 
  | Initial Release
 
  | Initial Release
 
  |}
 
  |}
 +
</div>
  
 
[[Category:Internal_filters]]
 
[[Category:Internal_filters]]
 +
[[Category:Masking]]

Latest revision as of 07:23, 18 September 2022

AviSynth+
Up-to-date documentation: https://avisynthplus.readthedocs.io


Returns a mask (as Y8) of clip using a given hue and saturation range. Added in v2.6.


[edit] Syntax and Parameters

MaskHS(clip [, int startHue, int endHue, int maxSat, int minSat, bool coring ] )

MaskHS(clip [, int startHue, int endHue, int maxSat, int minSat, bool coring, bool realcalc ] ) AVS+

int  startHue = 0
int  endHue = 360
The resulting mask will contain source values in the range [startHue, endHue] when startHue<endHue. Note that the hue is periodic, thus a hue of 360 degrees corresponds with a hue of zero degrees.
If endHue<startHue then the range [endHue, 360] and [0, startHue] will be selected (thus anti-clockwise). If you need to select a range of [350, 370] for example, you need to specify startHue=370, endHue=350.
Range 0 to 360 (degrees), default 0, 360; thus when using the default values, all pixels will be processed.
The following shows some arbitrary startHue and endHue values for the basic colors, with a Histogram vectorscope to illustrate the color circle:
Color startHue (center) endHue
Labeled-vector-color2.png
Red 075 102 115
Yellow 150 176 180
Green 191 230 258
Cyan 279 282 300
Blue 316 000 004
Magenta 028 048 052
int  maxSat = 150
int  minSat = 0
The resulting mask will contain source values in the range [minSat, maxSat].
Practically the saturation of a pixel will be in the range [0,100] (thus 0-100%), since these correspond to valid RGB pixels (100% corresponds to R=255, G=B=0, which has a saturation of 119). An overshoot (up to 150%) is allowed for non-valid RGB pixels (150% corresponds to U=V=255, which has a saturation of sqrt(1272+1272) = 180).
AVS+ TODO needs documentation of behavior with Deep Color formats.
Range 0 to 150 (percent), default 150, 0; thus when using the default values all pixels will be processed.
bool  coring = true
When set to true, the luma (Y) is clipped to TV-range; when set to false, the luma is left untouched.
bool  realcalc = false
AVS+ When true, force 'no-lookup': pure float calculation of new pixel values (always true for certain Deep Color formats) (TODO - clarify)


[edit] Examples

  • Suppose we want to create a mask of the skin of the girl below. The proper way to do this is to look at the vectorscope of Histogram:
clip = ...
Histogram(clip, mode="color2")
Tweak original2 plus hist.jpg
and estimate the hue range you want to select. As can be seen, the orange hue is between (about) 105 and 165 degrees.
Note: axis labels have been added to the vectorscope as a guide – they are not generated by the above script
Start with a wide hue range and narrow it until the output of MaskHS isolates the range of interest. You can also use Tweak to preview the affected range (with sat=0), as the arguments are compatible.
In our example we end at startHue=105, endHue=138, and the following mask is obtained:
clip = ...
MaskHS(startHue=105, endHue=138)
Maskhs.jpg


  • Looking at the blue screen example in Overlay the following can be used
testcard = ColorBars

# example subtitle file with blue background:
subs = ImageSource("F:\TestClips\blue.jpg").ConvertToYV24

# subs.Histogram(mode="color2").ConvertToRGB # blue in [345,359]
mask_hs = subs.MaskHS(startHue=340, endHue=359).Levels(0, 1, 255, 255, 0)

Overlay(testcard, subs, mask=mask_hs, mode="blend", opacity=1)

[edit] Changelog

v2.60 Initial Release
Personal tools