Skip to content

Commit

Permalink
Merge pull request #58 from Photoroom/ben/robust_img_types
Browse files Browse the repository at this point in the history
[feat] Supporting 16bits images
  • Loading branch information
blefaudeux authored Dec 17, 2024
2 parents e4ff54a + 27a4c52 commit 925f90f
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 1 deletion.
1 change: 1 addition & 0 deletions pkg/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ type ImagePayload struct {
Height int // Useful to decode the current payload
Width int
Channels int
BitDepth int
}

type Sample struct {
Expand Down
10 changes: 10 additions & 0 deletions pkg/serdes.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,8 @@ func imageFromBuffer(buffer []byte, transform *ARAwareTransform, aspect_ratio fl
// If requested, re-encode the image to a jpg or png
var img_bytes []byte
var channels int
var bit_depth int

if pre_encode_image {
if err != nil {
return nil, -1., err
Expand All @@ -107,6 +109,13 @@ func imageFromBuffer(buffer []byte, transform *ARAwareTransform, aspect_ratio fl
return nil, -1., err
}
channels = img.Bands()

// Define bit depth de facto, not exposed in the vips interface
bit_depth = len(img_bytes) / (width * height * channels)
}

if bit_depth == 0 && !pre_encode_image {
panic("Bit depth not set")
}

img_payload := ImagePayload{
Expand All @@ -116,6 +125,7 @@ func imageFromBuffer(buffer []byte, transform *ARAwareTransform, aspect_ratio fl
Height: height,
Width: width,
Channels: channels,
BitDepth: bit_depth,
}

return &img_payload, aspect_ratio, nil
Expand Down
4 changes: 3 additions & 1 deletion python/go_types.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,10 @@ def uint8_array_to_numpy(go_array):
# We export them from Go with a Channels dimension of -1 to mark them as dimensionless.
# Anything else is a valid number of channels and will thus lead to a reshape
num_final_channels = max(go_array.Channels, 1)
bit_depth = getattr(go_array, "BitDepth", 8)

length = (
go_array.Width * go_array.Height * num_final_channels
go_array.Width * go_array.Height * num_final_channels * bit_depth
if go_array.Channels > 0
else len(go_array.Data)
)
Expand Down

0 comments on commit 925f90f

Please sign in to comment.