2014-12-24 03:04:10 +01:00
|
|
|
// Copyright 2014 Hajime Hoshi
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2014-12-09 15:16:04 +01:00
|
|
|
|
2018-11-17 12:20:46 +01:00
|
|
|
package graphics_test
|
2013-06-15 10:07:14 +02:00
|
|
|
|
|
|
|
import (
|
2013-06-19 16:51:41 +02:00
|
|
|
"testing"
|
2017-08-06 13:05:14 +02:00
|
|
|
|
2021-10-02 12:58:48 +02:00
|
|
|
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
2013-06-15 10:07:14 +02:00
|
|
|
)
|
|
|
|
|
2019-02-14 13:04:34 +01:00
|
|
|
func TestInternalImageSize(t *testing.T) {
|
2013-06-15 10:07:14 +02:00
|
|
|
testCases := []struct {
|
2016-10-22 18:58:58 +02:00
|
|
|
expected int
|
|
|
|
arg int
|
2013-06-15 10:07:14 +02:00
|
|
|
}{
|
|
|
|
{256, 255},
|
|
|
|
{256, 256},
|
|
|
|
{512, 257},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, testCase := range testCases {
|
2021-10-02 12:58:48 +02:00
|
|
|
got := graphics.InternalImageSize(testCase.arg)
|
2013-06-15 10:07:14 +02:00
|
|
|
wanted := testCase.expected
|
|
|
|
if wanted != got {
|
2014-12-19 21:22:10 +01:00
|
|
|
t.Errorf("Clp(%d) = %d, wanted %d", testCase.arg, got, wanted)
|
2013-06-15 10:07:14 +02:00
|
|
|
}
|
2013-06-19 16:51:41 +02:00
|
|
|
|
2013-06-15 10:07:14 +02:00
|
|
|
}
|
|
|
|
}
|
2022-10-10 19:05:20 +02:00
|
|
|
|
|
|
|
func TestAdjustPixel(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
X float32
|
|
|
|
Y float32
|
|
|
|
Delta float32
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
X: -0.1,
|
|
|
|
Y: 0.9,
|
|
|
|
Delta: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
X: -1,
|
|
|
|
Y: 0,
|
|
|
|
Delta: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
X: -1.9,
|
|
|
|
Y: 1.1,
|
|
|
|
Delta: 3,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
X: -2,
|
|
|
|
Y: 1,
|
|
|
|
Delta: 3,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tc := range tests {
|
|
|
|
if rx, ry := graphics.AdjustDestinationPixelForTesting(tc.X)+tc.Delta, graphics.AdjustDestinationPixelForTesting(tc.Y); rx != ry {
|
|
|
|
t.Errorf("adjustDestinationPixel(%f) + 1 must equal to adjustDestinationPixel(%f) but not (%f vs %f)", tc.X, tc.Y, rx, ry)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkAdjustPixel(b *testing.B) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
graphics.AdjustDestinationPixelForTesting(float32(i) / 17)
|
|
|
|
}
|
|
|
|
}
|