graphics: CompositionMode -> CompositeMode (#170)

This commit is contained in:
Hajime Hoshi 2016-03-01 02:16:32 +09:00
parent 1eb623cf16
commit c6fc5ab865
10 changed files with 73 additions and 73 deletions

View File

@ -43,7 +43,7 @@ func update(screen *ebiten.Image) error {
screen.DrawImage(ebitenImage, op) screen.DrawImage(ebitenImage, op)
op = &ebiten.DrawImageOptions{} op = &ebiten.DrawImageOptions{}
op.GeoM.Translate(ox+float64(w), oy) op.GeoM.Translate(ox+float64(w), oy)
op.CompositionMode = ebiten.CompositionModeLighter op.CompositeMode = ebiten.CompositeModeLighter
screen.DrawImage(ebitenImage, op) screen.DrawImage(ebitenImage, op)
return nil return nil
} }
@ -54,7 +54,7 @@ func main() {
if err != nil { if err != nil {
log.Fatal(err) log.Fatal(err)
} }
if err := ebiten.Run(update, screenWidth, screenHeight, 2, "Composition Mode (Ebiten Demo)"); err != nil { if err := ebiten.Run(update, screenWidth, screenHeight, 2, "Composite Mode (Ebiten Demo)"); err != nil {
log.Fatal(err) log.Fatal(err)
} }
} }

View File

@ -74,7 +74,7 @@ func update(screen *ebiten.Image) error {
} }
op = &ebiten.DrawImageOptions{} op = &ebiten.DrawImageOptions{}
op.CompositionMode = ebiten.CompositionModeSourceOut op.CompositeMode = ebiten.CompositeModeSourceOut
if err := maskImage.DrawImage(fiveyearsImage, op); err != nil { if err := maskImage.DrawImage(fiveyearsImage, op); err != nil {
return err return err
} }

View File

@ -36,22 +36,22 @@ func glFilter(c *opengl.Context, filter Filter) opengl.Filter {
panic("not reach") panic("not reach")
} }
// CompositionMode represents Porter-Duff composition mode. // CompositeMode represents Porter-Duff composition mode.
type CompositionMode int type CompositeMode int
// Note: This name convention follow CSS compositing: https://drafts.fxtf.org/compositing-2/ // Note: This name convention follow CSS compositing: https://drafts.fxtf.org/compositing-2/
const ( const (
CompositionModeSourceOver CompositionMode = CompositionMode(opengl.CompositionModeSourceOver) // regular alpha blending CompositeModeSourceOver CompositeMode = CompositeMode(opengl.CompositeModeSourceOver) // regular alpha blending
CompositionModeClear = CompositionMode(opengl.CompositionModeClear) CompositeModeClear = CompositeMode(opengl.CompositeModeClear)
CompositionModeCopy = CompositionMode(opengl.CompositionModeCopy) CompositeModeCopy = CompositeMode(opengl.CompositeModeCopy)
CompositionModeDestination = CompositionMode(opengl.CompositionModeDestination) CompositeModeDestination = CompositeMode(opengl.CompositeModeDestination)
CompositionModeSourceIn = CompositionMode(opengl.CompositionModeSourceIn) CompositeModeSourceIn = CompositeMode(opengl.CompositeModeSourceIn)
CompositionModeDestinationIn = CompositionMode(opengl.CompositionModeDestinationIn) CompositeModeDestinationIn = CompositeMode(opengl.CompositeModeDestinationIn)
CompositionModeSourceOut = CompositionMode(opengl.CompositionModeSourceOut) CompositeModeSourceOut = CompositeMode(opengl.CompositeModeSourceOut)
CompositionModeDestinationOut = CompositionMode(opengl.CompositionModeDestinationOut) CompositeModeDestinationOut = CompositeMode(opengl.CompositeModeDestinationOut)
CompositionModeSourceAtop = CompositionMode(opengl.CompositionModeSourceAtop) CompositeModeSourceAtop = CompositeMode(opengl.CompositeModeSourceAtop)
CompositionModeDestinationAtop = CompositionMode(opengl.CompositionModeDestinationAtop) CompositeModeDestinationAtop = CompositeMode(opengl.CompositeModeDestinationAtop)
CompositionModeXor = CompositionMode(opengl.CompositionModeXor) CompositeModeXor = CompositeMode(opengl.CompositeModeXor)
CompositionModeLighter = CompositionMode(opengl.CompositionModeLighter) // sum of source and destination (a.k.a. 'plus' or 'additive') CompositeModeLighter = CompositeMode(opengl.CompositeModeLighter) // sum of source and destination (a.k.a. 'plus' or 'additive')
) )

View File

@ -99,7 +99,7 @@ func (i *Image) DrawImage(image *Image, options *DrawImageOptions) (err error) {
} }
w, h := image.Size() w, h := image.Size()
quads := &textureQuads{parts: parts, width: w, height: h} quads := &textureQuads{parts: parts, width: w, height: h}
m := opengl.CompositionMode(options.CompositionMode) m := opengl.CompositeMode(options.CompositeMode)
return i.framebuffer.DrawTexture(glContext, image.texture, quads, &options.GeoM, &options.ColorM, m) return i.framebuffer.DrawTexture(glContext, image.texture, quads, &options.GeoM, &options.ColorM, m)
} }
@ -184,10 +184,10 @@ func (i *Image) ReplacePixels(p []uint8) error {
// A DrawImageOptions represents options to render an image on an image. // A DrawImageOptions represents options to render an image on an image.
type DrawImageOptions struct { type DrawImageOptions struct {
ImageParts ImageParts ImageParts ImageParts
GeoM GeoM GeoM GeoM
ColorM ColorM ColorM ColorM
CompositionMode CompositionMode CompositeMode CompositeMode
// Deprecated (as of 1.1.0-alpha): Use ImageParts instead. // Deprecated (as of 1.1.0-alpha): Use ImageParts instead.
Parts []ImagePart Parts []ImagePart

View File

@ -246,7 +246,7 @@ func min(a, b int) int {
return b return b
} }
func TestImageCompositionModeLighter(t *testing.T) { func TestImageCompositeModeLighter(t *testing.T) {
img0, _, err := openEbitenImage("testdata/ebiten.png") img0, _, err := openEbitenImage("testdata/ebiten.png")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
@ -261,7 +261,7 @@ func TestImageCompositionModeLighter(t *testing.T) {
} }
img1.Fill(color.RGBA{0x01, 0x02, 0x03, 0x04}) img1.Fill(color.RGBA{0x01, 0x02, 0x03, 0x04})
op := &DrawImageOptions{} op := &DrawImageOptions{}
op.CompositionMode = CompositionModeLighter op.CompositeMode = CompositeModeLighter
img1.DrawImage(img0, op) img1.DrawImage(img0, op)
for j := 0; j < img1.Bounds().Size().Y; j++ { for j := 0; j < img1.Bounds().Size().Y; j++ {
for i := 0; i < img1.Bounds().Size().X; i++ { for i := 0; i < img1.Bounds().Size().X; i++ {

View File

@ -37,7 +37,7 @@ var vertices = make([]int16, 16*quadsMaxNum)
var shadersInitialized = false var shadersInitialized = false
func drawTexture(c *opengl.Context, texture opengl.Texture, projectionMatrix *[4][4]float64, quads TextureQuads, geo Matrix, color Matrix, mode opengl.CompositionMode) error { func drawTexture(c *opengl.Context, texture opengl.Texture, projectionMatrix *[4][4]float64, quads TextureQuads, geo Matrix, color Matrix, mode opengl.CompositeMode) error {
c.BlendFunc(mode) c.BlendFunc(mode)
// NOTE: WebGL doesn't seem to have Check gl.MAX_ELEMENTS_VERTICES or gl.MAX_ELEMENTS_INDICES so far. // NOTE: WebGL doesn't seem to have Check gl.MAX_ELEMENTS_VERTICES or gl.MAX_ELEMENTS_INDICES so far.

View File

@ -116,7 +116,7 @@ func (f *Framebuffer) Fill(c *opengl.Context, clr color.Color) error {
return c.FillFramebuffer(r, g, b, a) return c.FillFramebuffer(r, g, b, a)
} }
func (f *Framebuffer) DrawTexture(c *opengl.Context, t *Texture, quads TextureQuads, geo, clr Matrix, mode opengl.CompositionMode) error { func (f *Framebuffer) DrawTexture(c *opengl.Context, t *Texture, quads TextureQuads, geo, clr Matrix, mode opengl.CompositeMode) error {
if err := f.setAsViewport(c); err != nil { if err := f.setAsViewport(c); err != nil {
return err return err
} }

View File

@ -47,9 +47,9 @@ func (p Program) id() programID {
} }
type context struct { type context struct {
locationCache *locationCache locationCache *locationCache
funcs chan func() funcs chan func()
lastCompositionMode CompositionMode lastCompositeMode CompositeMode
} }
func NewContext() *Context { func NewContext() *Context {
@ -73,7 +73,7 @@ func NewContext() *Context {
} }
c.locationCache = newLocationCache() c.locationCache = newLocationCache()
c.funcs = make(chan func()) c.funcs = make(chan func())
c.lastCompositionMode = CompositionModeUnknown c.lastCompositeMode = CompositeModeUnknown
return c return c
} }
@ -107,15 +107,15 @@ func (c *Context) Init() {
// Textures' pixel formats are alpha premultiplied. // Textures' pixel formats are alpha premultiplied.
gl.Enable(gl.BLEND) gl.Enable(gl.BLEND)
}) })
c.BlendFunc(CompositionModeSourceOver) c.BlendFunc(CompositeModeSourceOver)
} }
func (c *Context) BlendFunc(mode CompositionMode) { func (c *Context) BlendFunc(mode CompositeMode) {
c.RunOnContextThread(func() { c.RunOnContextThread(func() {
if c.lastCompositionMode == mode { if c.lastCompositeMode == mode {
return return
} }
c.lastCompositionMode = mode c.lastCompositeMode = mode
s, d := c.operations(mode) s, d := c.operations(mode)
gl.BlendFunc(uint32(s), uint32(d)) gl.BlendFunc(uint32(s), uint32(d))
}) })

View File

@ -63,11 +63,11 @@ func (p Program) id() programID {
} }
type context struct { type context struct {
gl *webgl.Context gl *webgl.Context
lastFramebuffer Framebuffer lastFramebuffer Framebuffer
locationCache *locationCache locationCache *locationCache
lastProgramID programID lastProgramID programID
lastCompositionMode CompositionMode lastCompositeMode CompositeMode
} }
func NewContext() *Context { func NewContext() *Context {
@ -115,7 +115,7 @@ func NewContext() *Context {
} }
c.gl = gl c.gl = gl
c.locationCache = newLocationCache() c.locationCache = newLocationCache()
c.lastCompositionMode = CompositionModeUnknown c.lastCompositeMode = CompositeModeUnknown
c.init() c.init()
return c return c
} }
@ -125,14 +125,14 @@ func (c *Context) init() {
// Textures' pixel formats are alpha premultiplied. // Textures' pixel formats are alpha premultiplied.
gl.Enable(gl.BLEND) gl.Enable(gl.BLEND)
//gl.BlendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA) //gl.BlendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA)
c.BlendFunc(CompositionModeSourceOver) c.BlendFunc(CompositeModeSourceOver)
} }
func (c *Context) BlendFunc(mode CompositionMode) { func (c *Context) BlendFunc(mode CompositeMode) {
if c.lastCompositionMode == mode { if c.lastCompositeMode == mode {
return return
} }
c.lastCompositionMode = mode c.lastCompositeMode = mode
s, d := c.operations(mode) s, d := c.operations(mode)
gl := c.gl gl := c.gl
gl.BlendFunc(int(s), int(d)) gl.BlendFunc(int(s), int(d))

View File

@ -41,52 +41,52 @@ type Context struct {
context context
} }
type CompositionMode int type CompositeMode int
const ( const (
CompositionModeSourceOver CompositionMode = iota // This value must be 0 (= initial value) CompositeModeSourceOver CompositeMode = iota // This value must be 0 (= initial value)
CompositionModeClear CompositeModeClear
CompositionModeCopy CompositeModeCopy
CompositionModeDestination CompositeModeDestination
CompositionModeDestinationOver CompositeModeDestinationOver
CompositionModeSourceIn CompositeModeSourceIn
CompositionModeDestinationIn CompositeModeDestinationIn
CompositionModeSourceOut CompositeModeSourceOut
CompositionModeDestinationOut CompositeModeDestinationOut
CompositionModeSourceAtop CompositeModeSourceAtop
CompositionModeDestinationAtop CompositeModeDestinationAtop
CompositionModeXor CompositeModeXor
CompositionModeLighter CompositeModeLighter
CompositionModeUnknown CompositeModeUnknown
) )
func (c *Context) operations(mode CompositionMode) (src operation, dst operation) { func (c *Context) operations(mode CompositeMode) (src operation, dst operation) {
switch mode { switch mode {
case CompositionModeSourceOver: case CompositeModeSourceOver:
return c.one, c.oneMinusSrcAlpha return c.one, c.oneMinusSrcAlpha
case CompositionModeClear: case CompositeModeClear:
return c.zero, c.zero return c.zero, c.zero
case CompositionModeCopy: case CompositeModeCopy:
return c.one, c.zero return c.one, c.zero
case CompositionModeDestination: case CompositeModeDestination:
return c.zero, c.one return c.zero, c.one
case CompositionModeDestinationOver: case CompositeModeDestinationOver:
return c.oneMinusDstAlpha, c.one return c.oneMinusDstAlpha, c.one
case CompositionModeSourceIn: case CompositeModeSourceIn:
return c.dstAlpha, c.zero return c.dstAlpha, c.zero
case CompositionModeDestinationIn: case CompositeModeDestinationIn:
return c.zero, c.srcAlpha return c.zero, c.srcAlpha
case CompositionModeSourceOut: case CompositeModeSourceOut:
return c.oneMinusDstAlpha, c.zero return c.oneMinusDstAlpha, c.zero
case CompositionModeDestinationOut: case CompositeModeDestinationOut:
return c.zero, c.oneMinusSrcAlpha return c.zero, c.oneMinusSrcAlpha
case CompositionModeSourceAtop: case CompositeModeSourceAtop:
return c.dstAlpha, c.oneMinusSrcAlpha return c.dstAlpha, c.oneMinusSrcAlpha
case CompositionModeDestinationAtop: case CompositeModeDestinationAtop:
return c.oneMinusDstAlpha, c.srcAlpha return c.oneMinusDstAlpha, c.srcAlpha
case CompositionModeXor: case CompositeModeXor:
return c.oneMinusDstAlpha, c.oneMinusSrcAlpha return c.oneMinusDstAlpha, c.oneMinusSrcAlpha
case CompositionModeLighter: case CompositeModeLighter:
return c.one, c.one return c.one, c.one
default: default:
panic("not reach") panic("not reach")