Skip to content

Commit

Permalink
bmp: support to decode 8-bit format with up to 256 color palette
Browse files Browse the repository at this point in the history
If colorUsed is 0, the number of palette is 2 to the power of bit per pixel.
testdata/colormap-251.{bmp,png} are added for testing 8-bit format with colorUsed less than 256.
testdata/colormap-0.{bmp,png} are added for testing 8-bit format with colorUsed 0.

Fixes golang/go#61240

Change-Id: I1a627a570f667874a91c517f4a771e9e97d2af6b
Reviewed-on: https://go-review.googlesource.com/c/image/+/508575
TryBot-Result: Gopher Robot <[email protected]>
Reviewed-by: Dmitri Shuralyov <[email protected]>
Reviewed-by: Nigel Tao <[email protected]>
Reviewed-by: Nigel Tao (INACTIVE; USE @golang.org INSTEAD) <[email protected]>
Auto-Submit: Dmitri Shuralyov <[email protected]>
Run-TryBot: Nigel Tao <[email protected]>
  • Loading branch information
entooone authored and gopherbot committed Jul 17, 2023
1 parent f9550b0 commit a5392f0
Show file tree
Hide file tree
Showing 6 changed files with 13 additions and 3 deletions.
14 changes: 11 additions & 3 deletions bmp/reader.go
Original file line number Diff line number Diff line change
Expand Up @@ -191,14 +191,22 @@ func decodeConfig(r io.Reader) (config image.Config, bitsPerPixel int, topDown b
}
switch bpp {
case 8:
if offset != fileHeaderLen+infoLen+256*4 {
colorUsed := readUint32(b[46:50])
// If colorUsed is 0, it is set to the maximum number of colors for the given bpp, which is 2^bpp.
if colorUsed == 0 {
colorUsed = 256
} else if colorUsed > 256 {
return image.Config{}, 0, false, false, ErrUnsupported
}
_, err = io.ReadFull(r, b[:256*4])

if offset != fileHeaderLen+infoLen+colorUsed*4 {
return image.Config{}, 0, false, false, ErrUnsupported
}
_, err = io.ReadFull(r, b[:colorUsed*4])
if err != nil {
return image.Config{}, 0, false, false, err
}
pcm := make(color.Palette, 256)
pcm := make(color.Palette, colorUsed)
for i := range pcm {
// BMP images are stored in BGR order rather than RGB order.
// Every 4th byte is padding.
Expand Down
2 changes: 2 additions & 0 deletions bmp/reader_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ func compare(img0, img1 image.Image) error {
func TestDecode(t *testing.T) {
testCases := []string{
"colormap",
"colormap-0",
"colormap-251",
"video-001",
"yellow_rose-small",
"yellow_rose-small-v5",
Expand Down
Binary file added testdata/colormap-0.bmp
Binary file not shown.
Binary file added testdata/colormap-0.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added testdata/colormap-251.bmp
Binary file not shown.
Binary file added testdata/colormap-251.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit a5392f0

Please sign in to comment.