This code is an import from my long-defunct graphics library, code.google.com/p/graphics-go. It was reviewed by nigeltao back in the day. LGTM=nigeltao R=nigeltao CC=golang-codereviews https://golang.org/cl/142520043
34 lines
734 B
Go
34 lines
734 B
Go
// Copyright 2014 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package portable
|
|
|
|
import (
|
|
"image"
|
|
"image/color"
|
|
"image/draw"
|
|
"testing"
|
|
)
|
|
|
|
func TestAffine(t *testing.T) {
|
|
red := color.RGBA{0xff, 0, 0, 0xff}
|
|
dst := image.NewRGBA(image.Rect(0, 0, 30, 30))
|
|
src := image.NewRGBA(dst.Bounds())
|
|
draw.Draw(src, src.Bounds(), image.NewUniform(red), image.Point{}, draw.Src)
|
|
|
|
affine(dst, src, [3][3]float32{
|
|
{1, 0, 0},
|
|
{0, 1, 0},
|
|
{0, 0, 1},
|
|
})
|
|
|
|
for y := 0; y < dst.Bounds().Dy(); y++ {
|
|
for x := 0; x < dst.Bounds().Dx(); x++ {
|
|
if c := dst.At(x, y); c != red {
|
|
t.Fatalf("At(%d, %d) = %v, want red", x, y, c)
|
|
}
|
|
}
|
|
}
|
|
}
|