Hilfe

ReadPixelFast

B2D B+ B3D

Aufruf

rgb = ReadPixelFast ( x, y, [, buffer] )

Parameter

x X-Koordinate
y Y-Koordinate
buffer Grafikbuffer, aus dem gelesen werden soll. Standard=aktueller Buffer


Rückgabewert

Integerwert, der einen Farbcode als RGB-Wert beinhaltet. Siehe Zusatzinformationen, um zu sehen wie man es ausrechnet.


Beschreibung

Diese Funktion liest die Farbe eines Pixels an der X/Y-Koordinate aus. Dabei wird die Farbe immer aus dem aktuellen Buffer ermitteln. Wenn man möchte, dann kann man einen speziellen Grafikbuffer mit dem optionalen Parameter "Buffer" angeben - dann wird daraus die Farbe ausgelesen. (siehe BackBuffer, FrontBuffer und ImageBuffer).

Bevor man ReadPixelFast oder WritePixelFast verwenden kann, muss man noch den Befehl LockBuffer verwenden. Dadurch wird ein Buffer für andere Befehle gesperrt und die Fehlerprüfung deaktiviert. Danach muss ein Buffer mit UnlockBuffer wieder geöffnet werden.

Benutze WritePixel oder WritePixelFast, um die ausgelesene Farbe wieder einzuzeichnen.

Der ermittelte Farbcode wird sofort an die Variable übergeben. Die RGB-Anteile können nicht mit den Befehlen ColorRed, ColorGreen und ColorBlue ermittelt werden. Die können nur ausgerechnet werden (siehe Zusatzinformationen).
 


Readpixel kann den Farbcode auch ermitteln. Es ist nur etwas langsamer. Die Deaktivierung des Debuggers bringt eine enorme Geschwindigkeitssteigerung. ReadPixelFast ist die schnellste Variante (bis 620% schneller als GetColor).
 


Zusatzinformation

So wird ein Farbcode abgespeichert:
Es wird ein Integerwert übergeben. Ein Integerwert besteht aus 4 Byte. Das erste Byte (von rechts!) gibt den Blauanteil einer Farbe wieder, das zweite Byte den Grünanteil und das dritte Byte den Rotanteil. Die Farbanteile sind Werte im Bereich von 0-255. Das vierte Byte gibt den Alpha-Wert wieder. Alpha ist ein Transparenzwert, der erst ab Blitz3D voll verfügbar sein wird. Es sind Werte zwischen 0 (transparent) bis 255 (normal) möglich. Blitz2D kann keine Transparenz darstellen, somit hat es den Wert 255. Bis V1.53 gab es keinen Alphawert.

FF FF FF FF - Farbcode in einem Integerwert
=> vier Informationen (je 00-FF = 256 Werte pro Information)
1.: Beinhaltet Alpha-Information 255 (FFh), erst ab Blitz3D ist Alpha voll verfügbar
2.: Rotanteil 0-255 (0h-FFh)
3.: Grünanteil 0-255 (0h-FFh)
4.: Blauanteil 0-255 (0h-FFh)


Berechnung der Farbanteile aus einem Farbcode:
a = (rgb AND $FF000000)/$1000000
r = (rgb AND $FF0000)/$10000
g = (rgb AND $FF00)/$100
b = rgb AND $FF

Berechnung des Farbcodes aus den Farbanteilen:
rgb = a*$1000000 + r*$10000 + g*$100 + b

Berechnung der Farbwerte ohne Alpha:
rgb2 = rgb AND $FFFFFF


Beispiel

Standardbeispiel:

In diesem Beispiel liest ReadPixelFast den Farbwert ein und ermittelt die RGB - Farbanteile:

LockBuffer FrontBuffer()
rgb = ReadPixelFast(x, y)
r = (rgb And $FF0000) / $10000
g = (rgb And $FF00) / $100
b = rgb And $FF
UnlockBuffer FrontBuffer()
Text 0, 0, r + " " + g + " " + b


Siehe auch

ReadPixel, CopyPixel, CopyPixelFast, GetColor, Plot, WritePixelFast, WritePixel, LockBuffer, UnlockBuffer

Übersicht 2D Grafik Pixel