forked from joejulian/gio
f73287be87
Signed-off-by: ddkwork
59 lines
1.4 KiB
Go
59 lines
1.4 KiB
Go
// SPDX-License-Identifier: Unlicense OR MIT
|
|
|
|
package f32color
|
|
|
|
import (
|
|
"image/color"
|
|
"testing"
|
|
)
|
|
|
|
func TestNRGBAToLinearRGBA_Boundary(t *testing.T) {
|
|
for col := 0; col <= 0xFF; col++ {
|
|
for alpha := 0; alpha <= 0xFF; alpha++ {
|
|
in := color.NRGBA{R: uint8(col), A: uint8(alpha)}
|
|
premul := NRGBAToLinearRGBA(in)
|
|
if premul.A != uint8(alpha) {
|
|
t.Errorf("%v: got %v expected %v", in, premul.A, alpha)
|
|
}
|
|
if premul.R > premul.A {
|
|
t.Errorf("%v: R=%v > A=%v", in, premul.R, premul.A)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestLinearToRGBARoundtrip(t *testing.T) {
|
|
for col := 0; col <= 0xFF; col++ {
|
|
for alpha := 0; alpha <= 0xFF; alpha++ {
|
|
want := color.NRGBA{R: uint8(col), A: uint8(alpha)}
|
|
if alpha == 0 {
|
|
want.R = 0
|
|
}
|
|
got := LinearFromSRGB(want).SRGB()
|
|
if want != got {
|
|
t.Errorf("got %v expected %v", got, want)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
var sink RGBA
|
|
|
|
func BenchmarkLinearFromSRGB(b *testing.B) {
|
|
b.Run("opaque", func(b *testing.B) {
|
|
for i := 0; b.Loop(); i++ {
|
|
sink = LinearFromSRGB(color.NRGBA{R: byte(i), G: byte(i >> 8), B: byte(i >> 16), A: 0xFF})
|
|
}
|
|
})
|
|
b.Run("translucent", func(b *testing.B) {
|
|
for i := 0; b.Loop(); i++ {
|
|
sink = LinearFromSRGB(color.NRGBA{R: byte(i), G: byte(i >> 8), B: byte(i >> 16), A: 0x50})
|
|
}
|
|
})
|
|
b.Run("transparent", func(b *testing.B) {
|
|
for i := 0; b.Loop(); i++ {
|
|
sink = LinearFromSRGB(color.NRGBA{R: byte(i), G: byte(i >> 8), B: byte(i >> 16), A: 0x00})
|
|
}
|
|
})
|
|
}
|