Práce s grafikou XIV – Saturace
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Práce s grafikou XIV – SaturacePráce s grafikou XIV – Saturace

 

Práce s grafikou XIV – Saturace

Google       Google       26. 4. 2006       10 534×

Saturace je pravý opak desaturace a funguje tak, že obrázku přidáme na barvách. Tato úprava není tak častá jako desaturace, ale využít se dá. Její vytvoření mi dalo více zabrat než desaturace, ale složité to nebylo.

Reklama
Reklama

Nebudu toho uvádět moc, mohlo by to na vás zanechat následky, tak tady je kód a pod ním jen krátký kometář.


Declare Function SetPixel Lib "gdi32" (ByVal hdc As Long, ByVal x As Long, ByVal y As Long, ByVal crColor As Long) As Long
Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal x As Long, ByVal y As Long) As Long

Public Sub Saturace(Img As PictureBox, Fx As Byte)
Const RGBMax = 256

    Img.DrawWidth = 1
    Img.ScaleMode = 3
    Img.AutoRedraw = True
    On Error Resume Next
        For x = 0 To Img.ScaleWidth
            For y = 0 To Img.ScaleHeight
                DoEvents
                Imgp = GetPixel(Img.hdc, x, y)
                b = Imgp \ RGBMax \ RGBMax
                g = (Imgp \ RGBMax) Mod RGBMax
                r = Imgp Mod RGBMax
                
                r1 = (r * 3) - (g + b)
                g1 = (g * 3) - (r + b)
                b1 = (b * 3) - (g + r)
                
                r1 = ((r * Fx) + r1) / (Fx + 1)
                g1 = ((g * Fx) + g1) / (Fx + 1)
                b1 = ((b * Fx) + b1) / (Fx + 1)
                
                If r1 >= 255 Then r1 = 255
                If g1 >= 255 Then g1 = 255
                If b1 >= 255 Then b1 = 255
                If r1 <= 0 Then r1 = 1
                If g1 <= 0 Then g1 = 1
                If b1 <= 0 Then b1 = 1
                
                Call SetPixel(Img.hdc, x, y, RGB(r1, g1, b1))
            Next y
            DoEvents
        Next x
    Img.Refresh
End Sub

Je to jednoduché, jako parametr Fx se doplní síla saturace. Čím větší číslo, tím menší saturace, takže při 25 sotva něco postřehnete, zatímco u nuly je efekt výrazný. Pokud je saturace přílišná, vyvstává na obrázcích kresba komprimace, např. u JPG. Záleží ovšem na kvalitě obrázku atd.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
(fotka) Jiří ChytilAutor programuje ve VB, zajímá se o elektrotechniku, studuje na SOŠ Elektrotechnické - obor číslicová technika.
Web    

Nové články

Reklama
Reklama
Obrázek ke článku Facebook spouští službu Marketplace V ČR

Facebook spouští službu Marketplace V ČR

Společná platforma Marketplace usnadní lidem na Facebooku vyhledávání, nákup a prodej použitého zboží na lokální úrovni. Bude tak přímou konkurencí pro weby a aplikace se stejným zaměřením jako je například Letgo, Bazoš, Aukro, Sbazar a další.

Obrázek ke článku DistrCut – optimalizace pomocí distribuované inteligence

DistrCut – optimalizace pomocí distribuované inteligence

Optimalizační systémy, které jsem dosud popisoval, se týkaly vždy optimalizace na jednom zařízení. Optimalizovalo se dělení tyčového materiálu na jedné pile, vypalování plošného materiálu na jednom plazmovém stroji, řídilo se tavení na jedné elektrické obloukové peci.

Ve výrobním procesu je však často nutné optimalizovat činnost celého výrobního úseku, kde je více různých objektů odlišného typu a koordinovat činnost těchto objektů k dosažení společného cíle, zpravidla kvality finálního výrobku. Řešení tohoto problému umožňuje distribuovaná inteligence.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý