Nachtrag Beispiel-Code
hallo,
wenn Du nur die Farben reduzieren willst, ein Beispielcode, wie es schnell geht.
Option Explicit
Private Type BITMAP
bmType As Long
bmWidth As Long
bmHeight As Long
bmWidthBytes As Long
bmPlanes As Integer
bmBitsPixel As Integer
bmBits As Long
End Type
Private Declare Function GetObject Lib "gdi32" Alias \_
"GetObjectA" (ByVal hObject As Long, ByVal nCount As Long, \_
lpObject As Any) As Long
Private Declare Function GetBitmapBits Lib "gdi32" \_
(ByVal hBitmap As Long, ByVal dwCount As Long, lpBits As Any) As Long
Private Declare Function SetBitmapBits Lib "gdi32" \_
(ByVal hBitmap As Long, ByVal dwCount As Long, lpBits As Any) As Long
Dim PicBits() As Byte, PicInfo As BITMAP
Dim Pos As Long, BPL As Long
Private Sub Command1\_Click()
GetObject Picture1.Image, Len(PicInfo), PicInfo
BPL = (PicInfo.bmWidth \* 3 + 3) And &HFFFFFFFC
ReDim PicBits(1 To BPL \* PicInfo.bmHeight \* 3) As Byte
GetBitmapBits Picture1.Image, UBound(PicBits), PicBits(1)
For Pos = 1 To UBound(PicBits)
PicBits(Pos) = Round(PicBits(Pos) / 255, 0) \* 255
Next
SetBitmapBits Picture1.Image, UBound(PicBits), PicBits(1)
Picture1.Refresh
End Sub
Gruß, Rainer