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

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

 

Práce s grafikou XIV – Saturace

Google       Google       26. 4. 2006       9 933×

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

Obrázek ke článku RAD Studio a Windows Store

RAD Studio a Windows Store

RAD Studio je první vývojové prostředí se zabudovanou podporou balení aplikací typu Win32 a Win64 pro jejich umístění a šíření prostřednictvím Windows 10 Store.

Reklama
Reklama
Obrázek ke článku Testujte na 2 400+ Android a iOS zařízení

Testujte na 2 400+ Android a iOS zařízení

V dnešní době, kdy většina softwaru pro mobilní aplikace je tvořena a distribuována průběžně, mnohdy do celého světa je třeba zajistit také průběžnou automatizaci testování mobilního softwaru. V případě mobilních aplikací pro Android a iOS začíná být problém, jak testovat na obrovském množství kombinací HW variant, rozměrů, edic operačních systémů různých výrobců v různých částech světa na reálných zařízení. Simulátory a emulátory nejsou většinou to pravé. Pokud již testuji, jak si udělat vlastní beta distribuci opravdovým reálným testerům napříč platformami?

Obrázek ke článku Funkcie main vo Windows API

Funkcie main vo Windows API

V tretej časti seriálu o Windows API budeme hovoriť o funkčných prototypoch main. Funkčný prototyp je tvorený názvom funkcie a typom signatúry, pričom sa vynecháva telo funkcie. 

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ý