Práca s grafikou I. - Inverzia
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Práca s grafikou I. - InverziaPráca s grafikou I. - Inverzia

 

Práca s grafikou I. - Inverzia

Google       Google       23. 10. 2005       8 934×

Týmto článkom by som chcel naštartovať novú sériu článkov o počítačovej grafike vo Visual Basicu. Dnes sa pozrieme na inverziu obrázku a predstavíme si dve API funkcie, ktoré podstatne zrýchlia vaše aplikácie...

Reklama
Reklama

Prvá API funkcia sa volá GetPixel a slúži na zistenie farby pixelu. Je podobná funkcii Picturebox.point, ale ako som už spomínal, je niekoľkonásobne rýchlejšia. Druhá funkcia sa volá SetPixel a slúži na nakreslenie pixelu. Deklarácia týchto funkcií sa prevedie nasledovne:


Private Declare Function SetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long, ByVal crColor As Long) As Long
Private Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long) As Long

Teraz niečo k inverzii. Inverzia je funkcia, pri ktorej sa každý pixel obrázku rozloží na RGB zložky a každá zložka sa odčíta od hodnoty 255. Zdrojový kód vyzerá takto:


Private Declare Function SetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long, ByVal crColor As Long) As Long
Private Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long) As Long

Private Function Inverzia(Obrazok As Object)

Dim X, Y As Double
Dim Color As Long
Dim R, R1, R2 As Integer
Dim G, G1, G2 As Integer
Dim B, B1, B2 As Integer

For X = 0 To (Obrazok.Width - 1) / 15
For Y = 0 To (Obrazok.Height - 1) / 15
Color = GetPixel(Obrazok.hdc, X, Y)
B1 = Color  256  256
G1 = (Color  256) Mod 256
R1 = Color Mod 256
R = 255 - R1
G = 255 - G1
B = 255 - B1
Color = RGB(R, G, B)
SetPixel Obrazok.hdc, X, Y, Color
Next Y
Next X

End Function

Implementáciu funkcie si môžete pozrieť tu.
Samozrejme, že existuje aj API funkcia na inverziu, ale cieľom tohto článku je vytvoriť si vlastnú, aj keď pomalšiu funkciu.

Na záver by som ešte pridal pár tipov pre prácu s grafikou.

1.) Pre obrázok, ktorý chcete invertovať nastavte:
AutoRedraw = true
AutoSize = true

2.) Použitie funkcií GetPixel a SetPixel je až 3 krát rýchlejšie, keď má obrázok nastavenú hodnotu visible = false

V ďalšom článku sa môžete tešiť na transparenciu.

×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.

4 názory  —  4 nové  
Hlasování bylo ukončeno    
0 hlasů
Google
Autor programuje ve VB, mezi jeho další koníčky patří fyzika a matematika.

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ý