mirror of
https://github.com/odin-lang/Odin.git
synced 2026-04-21 13:55:19 +00:00
Clean up PNG code.
This commit is contained in:
@@ -735,18 +735,11 @@ load_from_context :: proc(ctx: ^$C, options := Options{}, allocator := context.a
|
||||
return {}, .Unable_To_Allocate_Or_Resize
|
||||
}
|
||||
|
||||
i := 0; j := 0
|
||||
|
||||
// If we don't have transparency or drop it without applying it, we can do this:
|
||||
if (!seen_trns || (seen_trns && .alpha_drop_if_present in options && .alpha_premultiply not_in options)) && .alpha_add_if_missing not_in options {
|
||||
for h := 0; h < int(img.height); h += 1 {
|
||||
for w := 0; w < int(img.width); w += 1 {
|
||||
c := _plte.entries[temp.buf[i]]
|
||||
t.buf[j ] = c.r
|
||||
t.buf[j+1] = c.g
|
||||
t.buf[j+2] = c.b
|
||||
i += 1; j += 3
|
||||
}
|
||||
output := mem.slice_data_cast([]image.RGB_Pixel, t.buf[:])
|
||||
for pal_idx, idx in temp.buf {
|
||||
output[idx] = _plte.entries[pal_idx]
|
||||
}
|
||||
} else if add_alpha || .alpha_drop_if_present in options {
|
||||
bg := PLTE_Entry{0, 0, 0}
|
||||
@@ -758,12 +751,23 @@ load_from_context :: proc(ctx: ^$C, options := Options{}, allocator := context.a
|
||||
no_alpha := (.alpha_drop_if_present in options || premultiply) && .alpha_add_if_missing not_in options
|
||||
blend_background := seen_bkgd && .blend_background in options
|
||||
|
||||
for h := 0; h < int(img.height); h += 1 {
|
||||
for w := 0; w < int(img.width); w += 1 {
|
||||
index := temp.buf[i]
|
||||
if no_alpha {
|
||||
output := mem.slice_data_cast([]image.RGB_Pixel, t.buf[:])
|
||||
for orig, idx in temp.buf {
|
||||
c := _plte.entries[orig]
|
||||
a := int(orig) < len(trns.data) ? trns.data[orig] : 255
|
||||
|
||||
c := _plte.entries[index]
|
||||
a := int(index) < len(trns.data) ? trns.data[index] : 255
|
||||
if blend_background {
|
||||
output[idx] = image.blend(c, a, bg)
|
||||
} else if premultiply {
|
||||
output[idx] = image.blend(PLTE_Entry{}, a, c)
|
||||
}
|
||||
}
|
||||
} else {
|
||||
output := mem.slice_data_cast([]image.RGBA_Pixel, t.buf[:])
|
||||
for orig, idx in temp.buf {
|
||||
c := _plte.entries[orig]
|
||||
a := int(orig) < len(trns.data) ? trns.data[orig] : 255
|
||||
|
||||
if blend_background {
|
||||
c = image.blend(c, a, bg)
|
||||
@@ -772,17 +776,7 @@ load_from_context :: proc(ctx: ^$C, options := Options{}, allocator := context.a
|
||||
c = image.blend(PLTE_Entry{}, a, c)
|
||||
}
|
||||
|
||||
t.buf[j ] = c.r
|
||||
t.buf[j+1] = c.g
|
||||
t.buf[j+2] = c.b
|
||||
i += 1
|
||||
|
||||
if no_alpha {
|
||||
j += 3
|
||||
} else {
|
||||
t.buf[j+3] = u8(a)
|
||||
j += 4
|
||||
}
|
||||
output[idx] = {c.r, c.g, c.b, u8(a)}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
|
||||
@@ -1479,7 +1479,6 @@ run_png_suite :: proc(t: ^testing.T, suite: []Test) {
|
||||
|
||||
png_hash := hash.crc32(pixels)
|
||||
testing.expectf(t, test.hash == png_hash, "%v test %v hash is %08x, expected %08x with %v", file.file, count, png_hash, test.hash, test.options)
|
||||
|
||||
passed &= test.hash == png_hash
|
||||
|
||||
if passed {
|
||||
|
||||
Reference in New Issue
Block a user