Nabend zusammen
ich hab ein hoffentlich kleines problem mit meiner picturebox.
und zwar möchte ich ein bild was in meiner picturebox liegt
in 16 farben umwandeln. oder 256. am besten aber 16 *g
ich hab schon seit paar tagen gegooglet aber irgendwie finde
ich immer nur 16-bit.
hoffe jemand von euch kann mir helfen.
ci@oi fressbrett
Hallo,
ich hab ein hoffentlich kleines problem mit meiner picturebox.
und zwar möchte ich ein bild was in meiner picturebox liegt
in 16 farben umwandeln. oder 256. am besten aber 16 *g
ich hab schon seit paar tagen gegooglet aber irgendwie finde
ich immer nur 16-bit.
Willst Du nur die Farbauflösung reduzieren, oder willst Du das mit der 4-Bit Auflösung speichern? Die Farben reduzieren geht einfach mit runden. Das Bild mit 4-Bit oder 8-Bit (256 Farben) schreiben kann VB IMHO nicht. Bei 256 Farben ist auch zusätzlich noch eine Palette nötig, wie man damit umgeht weiß ich nicht. Wenn Du das Bild nur verändert speichern möchtest, würde ich dafür Irfanview nehmen und kein eigenes Programm schreiben wollen.
Gruß, Rainer
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
Hi,
noch etwas gefunden.
Wenn Du das Bild in einer anderen Farbauflösung speichern willst, sieh Dir mal das hier an …
http://www.activevb.de/tipps/vb6tipps/tipp0493.html
Gruß, Rainer
hey supi. das war genau der richtige tipp.
wie geht es denn dann auf 256 farben???
hey supi. das war genau der richtige tipp.
wie geht es denn dann auf 256 farben???
Hallo,
bei 256 Farben müssen die Pixel Paletten zugeordnet werden das ist dann etwas komplizierter. Sieh Dir den Code eine Zeile höher an, da hat das ein Experte von AVB gemacht.
Gruß, Rainer
ja supi hat alles geklappt.
hab es hier mit gemacht:
http://www.activevb.de/tipps/vb6tipps/tipp0493.html
danke nochmal.