mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-27 03:02:49 +01:00
graphics: ReplacePixels should work on shared textures
This commit is contained in:
parent
4ae9d5780c
commit
caf4e9504f
45
image.go
45
image.go
@ -147,16 +147,6 @@ func (i *Image) isDisposed() bool {
|
|||||||
return i.restorable == nil && i.sharedImagePart == nil
|
return i.restorable == nil && i.sharedImagePart == nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (i *Image) restorableImage() *restorable.Image {
|
|
||||||
if i.restorable != nil {
|
|
||||||
return i.restorable
|
|
||||||
}
|
|
||||||
if i.sharedImagePart != nil {
|
|
||||||
return i.sharedImagePart.image()
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// DrawImage draws the given image on the image i.
|
// DrawImage draws the given image on the image i.
|
||||||
//
|
//
|
||||||
// DrawImage accepts the options. For details, see the document of DrawImageOptions.
|
// DrawImage accepts the options. For details, see the document of DrawImageOptions.
|
||||||
@ -355,6 +345,27 @@ func (i *Image) Dispose() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (i *Image) region() (x, y, width, height int) {
|
||||||
|
if i.restorable != nil {
|
||||||
|
w, h := i.restorable.Size()
|
||||||
|
return 0, 0, w, h
|
||||||
|
}
|
||||||
|
if i.sharedImagePart != nil {
|
||||||
|
return i.sharedImagePart.region()
|
||||||
|
}
|
||||||
|
panic("not reached")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *Image) restorableImage() *restorable.Image {
|
||||||
|
if i.restorable != nil {
|
||||||
|
return i.restorable
|
||||||
|
}
|
||||||
|
if i.sharedImagePart != nil {
|
||||||
|
return i.sharedImagePart.image()
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// ReplacePixels replaces the pixels of the image with p.
|
// ReplacePixels replaces the pixels of the image with p.
|
||||||
//
|
//
|
||||||
// The given p must represent RGBA pre-multiplied alpha values. len(p) must equal to 4 * (image width) * (image height).
|
// The given p must represent RGBA pre-multiplied alpha values. len(p) must equal to 4 * (image width) * (image height).
|
||||||
@ -368,15 +379,14 @@ func (i *Image) Dispose() error {
|
|||||||
// ReplacePixels always returns nil as of 1.5.0-alpha.
|
// ReplacePixels always returns nil as of 1.5.0-alpha.
|
||||||
func (i *Image) ReplacePixels(p []byte) error {
|
func (i *Image) ReplacePixels(p []byte) error {
|
||||||
i.copyCheck()
|
i.copyCheck()
|
||||||
i.ensureNotShared()
|
|
||||||
if i.isDisposed() {
|
if i.isDisposed() {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
w, h := i.Size()
|
x, y, w, h := i.region()
|
||||||
if l := 4 * w * h; len(p) != l {
|
if l := 4 * w * h; len(p) != l {
|
||||||
panic(fmt.Sprintf("ebiten: len(p) was %d but must be %d", len(p), l))
|
panic(fmt.Sprintf("ebiten: len(p) was %d but must be %d", len(p), l))
|
||||||
}
|
}
|
||||||
i.restorable.ReplacePixels(p, 0, 0, w, h)
|
i.restorableImage().ReplacePixels(p, x, y, w, h)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -515,14 +525,7 @@ func NewImageFromImage(source image.Image, filter Filter) (*Image, error) {
|
|||||||
for j := 0; j < height; j++ {
|
for j := 0; j < height; j++ {
|
||||||
copy(p[j*width*4:(j+1)*width*4], rgbaImg.Pix[j*rgbaImg.Stride:])
|
copy(p[j*width*4:(j+1)*width*4], rgbaImg.Pix[j*rgbaImg.Stride:])
|
||||||
}
|
}
|
||||||
|
_ = i.ReplacePixels(p)
|
||||||
if s == nil {
|
|
||||||
_ = i.ReplacePixels(p)
|
|
||||||
} else {
|
|
||||||
x, y, width, height := s.region()
|
|
||||||
s.image().ReplacePixels(p, x, y, width, height)
|
|
||||||
}
|
|
||||||
|
|
||||||
return i, nil
|
return i, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -318,6 +318,10 @@ func TestImageDotByDotInversion(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestReplacePixels(t *testing.T) {
|
func TestReplacePixels(t *testing.T) {
|
||||||
|
// Create a dummy image so that the shared texture is use and origImg's position is shfited.
|
||||||
|
dummyImg, _ := NewImageFromImage(image.NewRGBA(image.Rect(0, 0, 16, 16)), FilterDefault)
|
||||||
|
defer dummyImg.Dispose()
|
||||||
|
|
||||||
origImg, err := openImage("testdata/ebiten.png")
|
origImg, err := openImage("testdata/ebiten.png")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
@ -369,7 +373,6 @@ func TestReplacePixels(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestImageDispose(t *testing.T) {
|
func TestImageDispose(t *testing.T) {
|
||||||
|
Loading…
Reference in New Issue
Block a user