ebiten: rename ColorSclaeFormat -> ColorScaleMode

This commit is contained in:
Hajime Hoshi 2022-11-01 13:09:52 +09:00
parent e237a70135
commit 8d854cbb82
3 changed files with 30 additions and 30 deletions

View File

@ -267,7 +267,7 @@ type Vertex struct {
// ColorR/ColorG/ColorB/ColorA represents color scaling values. // ColorR/ColorG/ColorB/ColorA represents color scaling values.
// Their interpretation depends on the concrete draw call used: // Their interpretation depends on the concrete draw call used:
// - DrawTriangles: straight-alpha or premultiplied-alpha encoded color multiplier. // - DrawTriangles: straight-alpha or premultiplied-alpha encoded color multiplier.
// The format is determined by ColorScaleFormat in DrawTrianglesOptions. // The format is determined by ColorScaleMode in DrawTrianglesOptions.
// If ColorA is 0, the vertex is fully transparent and color is ignored. // If ColorA is 0, the vertex is fully transparent and color is ignored.
// If ColorA is 1, the vertex has the color (ColorR, ColorG, ColorB). // If ColorA is 1, the vertex has the color (ColorR, ColorG, ColorB).
// Vertex colors are converted to premultiplied-alpha internally and // Vertex colors are converted to premultiplied-alpha internally and
@ -306,17 +306,17 @@ const (
EvenOdd EvenOdd
) )
// ColorScaleFormat is the format of color scales in vertices. // ColorScaleMode is the mode of color scales in vertices.
type ColorScaleFormat int type ColorScaleMode int
const ( const (
// ColorScaleFormatStraightAlpha indicates color scales in vertices are // ColorScaleModeStraightAlpha indicates color scales in vertices are
// straight-alpha encoded color multiplier. // straight-alpha encoded color multiplier.
ColorScaleFormatStraightAlpha ColorScaleFormat = iota ColorScaleModeStraightAlpha ColorScaleMode = iota
// ColorScaleFormatStraightAlpha indicates color scales in vertices are // ColorScaleModeStraightAlpha indicates color scales in vertices are
// premultiplied-alpha encoded color multiplier. // premultiplied-alpha encoded color multiplier.
ColorScaleFormatPremultipliedAlpha ColorScaleModePremultipliedAlpha
) )
// DrawTrianglesOptions represents options for DrawTriangles. // DrawTrianglesOptions represents options for DrawTriangles.
@ -326,9 +326,9 @@ type DrawTrianglesOptions struct {
// ColorM is applied before vertex color scale is applied. // ColorM is applied before vertex color scale is applied.
ColorM ColorM ColorM ColorM
// ColorScaleFormat is the format of color scales in vertices. // ColorScaleMode is the format of color scales in vertices.
// The default (zero) value is ColorScaleFormatStraightAlpha. // The default (zero) value is ColorScaleModeStraightAlpha.
ColorScaleFormat ColorScaleFormat ColorScaleMode ColorScaleMode
// CompositeMode is a composite mode to draw. // CompositeMode is a composite mode to draw.
// The default (zero) value is CompositeModeCustom (Blend is used). // The default (zero) value is CompositeModeCustom (Blend is used).
@ -435,7 +435,7 @@ func (i *Image) DrawTriangles(vertices []Vertex, indices []uint16, img *Image, o
vs := graphics.Vertices(len(vertices)) vs := graphics.Vertices(len(vertices))
dst := i dst := i
if options.ColorScaleFormat == ColorScaleFormatStraightAlpha { if options.ColorScaleMode == ColorScaleModeStraightAlpha {
for i, v := range vertices { for i, v := range vertices {
dx, dy := dst.adjustPositionF32(v.DstX, v.DstY) dx, dy := dst.adjustPositionF32(v.DstX, v.DstY)
vs[i*graphics.VertexFloatCount] = dx vs[i*graphics.VertexFloatCount] = dx

View File

@ -1984,21 +1984,21 @@ func TestImageDrawTrianglesWithColorM(t *testing.T) {
is := []uint16{0, 1, 2, 1, 2, 3} is := []uint16{0, 1, 2, 1, 2, 3}
dst0.DrawTriangles(vs0, is, src, op) dst0.DrawTriangles(vs0, is, src, op)
for _, format := range []ebiten.ColorScaleFormat{ for _, format := range []ebiten.ColorScaleMode{
ebiten.ColorScaleFormatStraightAlpha, ebiten.ColorScaleModeStraightAlpha,
ebiten.ColorScaleFormatPremultipliedAlpha, ebiten.ColorScaleModePremultipliedAlpha,
} { } {
format := format format := format
t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) { t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) {
var cr, cg, cb, ca float32 var cr, cg, cb, ca float32
switch format { switch format {
case ebiten.ColorScaleFormatStraightAlpha: case ebiten.ColorScaleModeStraightAlpha:
// The values are the same as ColorM.Scale // The values are the same as ColorM.Scale
cr = 0.2 cr = 0.2
cg = 0.4 cg = 0.4
cb = 0.6 cb = 0.6
ca = 0.8 ca = 0.8
case ebiten.ColorScaleFormatPremultipliedAlpha: case ebiten.ColorScaleModePremultipliedAlpha:
cr = 0.2 * 0.8 cr = 0.2 * 0.8
cg = 0.4 * 0.8 cg = 0.4 * 0.8
cb = 0.6 * 0.8 cb = 0.6 * 0.8
@ -2049,7 +2049,7 @@ func TestImageDrawTrianglesWithColorM(t *testing.T) {
dst1 := ebiten.NewImage(w, h) dst1 := ebiten.NewImage(w, h)
op := &ebiten.DrawTrianglesOptions{} op := &ebiten.DrawTrianglesOptions{}
op.ColorScaleFormat = format op.ColorScaleMode = format
dst1.DrawTriangles(vs1, is, src, op) dst1.DrawTriangles(vs1, is, src, op)
for j := 0; j < h; j++ { for j := 0; j < h; j++ {
@ -2113,9 +2113,9 @@ func TestImageDrawTrianglesInterpolatesColors(t *testing.T) {
}, },
} }
for _, format := range []ebiten.ColorScaleFormat{ for _, format := range []ebiten.ColorScaleMode{
ebiten.ColorScaleFormatStraightAlpha, ebiten.ColorScaleModeStraightAlpha,
ebiten.ColorScaleFormatPremultipliedAlpha, ebiten.ColorScaleModePremultipliedAlpha,
} { } {
format := format format := format
t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) { t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) {
@ -2123,7 +2123,7 @@ func TestImageDrawTrianglesInterpolatesColors(t *testing.T) {
dst.Fill(color.RGBA{0x00, 0x00, 0xff, 0xff}) dst.Fill(color.RGBA{0x00, 0x00, 0xff, 0xff})
op := &ebiten.DrawTrianglesOptions{} op := &ebiten.DrawTrianglesOptions{}
op.ColorScaleFormat = format op.ColorScaleMode = format
is := []uint16{0, 1, 2, 1, 2, 3} is := []uint16{0, 1, 2, 1, 2, 3}
dst.DrawTriangles(vs, is, src, op) dst.DrawTriangles(vs, is, src, op)
@ -2134,9 +2134,9 @@ func TestImageDrawTrianglesInterpolatesColors(t *testing.T) {
// and notices that colors on the left side of the texture are fully transparent. // and notices that colors on the left side of the texture are fully transparent.
var want color.RGBA var want color.RGBA
switch format { switch format {
case ebiten.ColorScaleFormatStraightAlpha: case ebiten.ColorScaleModeStraightAlpha:
want = color.RGBA{0x00, 0x80, 0x80, 0xff} want = color.RGBA{0x00, 0x80, 0x80, 0xff}
case ebiten.ColorScaleFormatPremultipliedAlpha: case ebiten.ColorScaleModePremultipliedAlpha:
want = color.RGBA{0x80, 0x80, 0x80, 0xff} want = color.RGBA{0x80, 0x80, 0x80, 0xff}
} }
@ -3518,9 +3518,9 @@ func TestImageColorMAndScale(t *testing.T) {
} }
is := []uint16{0, 1, 2, 1, 2, 3} is := []uint16{0, 1, 2, 1, 2, 3}
for _, format := range []ebiten.ColorScaleFormat{ for _, format := range []ebiten.ColorScaleMode{
ebiten.ColorScaleFormatStraightAlpha, ebiten.ColorScaleModeStraightAlpha,
ebiten.ColorScaleFormatPremultipliedAlpha, ebiten.ColorScaleModePremultipliedAlpha,
} { } {
format := format format := format
t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) { t.Run(fmt.Sprintf("format%d", format), func(t *testing.T) {
@ -3528,21 +3528,21 @@ func TestImageColorMAndScale(t *testing.T) {
op := &ebiten.DrawTrianglesOptions{} op := &ebiten.DrawTrianglesOptions{}
op.ColorM.Translate(0.25, 0.25, 0.25, 0) op.ColorM.Translate(0.25, 0.25, 0.25, 0)
op.ColorScaleFormat = format op.ColorScaleMode = format
dst.DrawTriangles(vs, is, src, op) dst.DrawTriangles(vs, is, src, op)
got := dst.At(0, 0).(color.RGBA) got := dst.At(0, 0).(color.RGBA)
alphaBeforeScale := 0.5 alphaBeforeScale := 0.5
var want color.RGBA var want color.RGBA
switch format { switch format {
case ebiten.ColorScaleFormatStraightAlpha: case ebiten.ColorScaleModeStraightAlpha:
want = color.RGBA{ want = color.RGBA{
byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5 * 0.75)), byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5 * 0.75)),
byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.25 * 0.75)), byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.25 * 0.75)),
byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5 * 0.75)), byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5 * 0.75)),
byte(math.Floor(0xff * alphaBeforeScale * 0.75)), byte(math.Floor(0xff * alphaBeforeScale * 0.75)),
} }
case ebiten.ColorScaleFormatPremultipliedAlpha: case ebiten.ColorScaleModePremultipliedAlpha:
want = color.RGBA{ want = color.RGBA{
byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5)), byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.5)),
byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.25)), byte(math.Floor(0xff * (0.5/alphaBeforeScale + 0.25) * alphaBeforeScale * 0.25)),

View File

@ -43,7 +43,7 @@ func drawVerticesForUtil(dst *ebiten.Image, vs []ebiten.Vertex, is []uint16, clr
} }
op := &ebiten.DrawTrianglesOptions{} op := &ebiten.DrawTrianglesOptions{}
op.ColorScaleFormat = ebiten.ColorScaleFormatPremultipliedAlpha op.ColorScaleMode = ebiten.ColorScaleModePremultipliedAlpha
op.AntiAlias = true op.AntiAlias = true
dst.DrawTriangles(vs, is, whiteSubImage, op) dst.DrawTriangles(vs, is, whiteSubImage, op)
} }