Files
flame/test/vector2_test.dart
Renan ccee9a466b Move files to src and comply with the dart package layout convention (#621)
* 👌 Use `Offset` type directly in `JoystickAction.update` calculations (#631)

* Move files to src and comply with the dart package layout convention

* Fixing widgets example

Co-authored-by: Serge Matveenko <lig@countzero.co>
Co-authored-by: Erick Zanardo <erickzanardoo@gmail.com>
2021-01-20 09:05:43 -03:00

104 lines
2.5 KiB
Dart

import 'package:flame/extensions.dart';
import 'package:test/test.dart';
import 'dart:math' as math;
void expectDouble(double d1, double d2) {
expect((d1 - d2).abs() <= 0.0001, true);
}
void main() {
group('position test', () {
test('test add', () {
final Vector2 p = Vector2(0.0, 5.0) + Vector2(5.0, 5.0);
expectDouble(p.x, 5.0);
expectDouble(p.y, 10.0);
});
test('test clone', () {
final Vector2 p = Vector2(1.0, 0.0);
final Vector2 clone = p.clone();
clone.scale(2.0);
expectDouble(p.x, 1.0);
expectDouble(clone.x, 2.0);
});
test('test rotate', () {
final Vector2 p = Vector2(1.0, 0.0)..rotate(math.pi / 2);
expectDouble(p.x, 0.0);
expectDouble(p.y, 1.0);
});
test('test length', () {
final Vector2 p1 = Vector2(3.0, 4.0);
expectDouble(p1.length, 5.0);
final Vector2 p2 = Vector2(2.0, 0.0);
expectDouble(p2.length, 2.0);
final Vector2 p3 = Vector2(0.0, 1.5);
expectDouble(p3.length, 1.5);
});
test('test distance', () {
final Vector2 p1 = Vector2(10.0, 20.0);
final Vector2 p2 = Vector2(13.0, 24.0);
final double result = p1.distanceTo(p2);
expectDouble(result, 5.0);
});
test('equality', () {
final Vector2 p1 = Vector2.zero();
final Vector2 p2 = Vector2.zero();
expect(p1 == p2, true);
});
test('non equality', () {
final Vector2 p1 = Vector2.zero();
final Vector2 p2 = Vector2(1.0, 0.0);
expect(p1 == p2, false);
});
test('hashCode', () {
final Vector2 p1 = Vector2(2.0, -1.0);
final Vector2 p2 = Vector2(1.0, 0.0);
expect(p1.hashCode == p2.hashCode, false);
});
test('scaleTo', () {
final Vector2 p = Vector2(1.0, 0.0)
..rotate(math.pi / 4)
..scaleTo(2.0);
expect(p.length, 2.0);
p.rotate(-math.pi / 4);
expect(p.length, 2.0);
expect(p.x, 2.0);
expect(p.y, 0.0);
});
test('scaleTo the zero vector', () {
final Vector2 p = Vector2.zero();
expect(p.normalized().length, 0.0);
});
test('limit', () {
final Vector2 p1 = Vector2(1.0, 0.0);
p1.clampScalar(0, 0.75);
expect(p1.length, 0.75);
expect(p1.x, 0.75);
expect(p1.y, 0.0);
final Vector2 p2 = Vector2(1.0, 1.0);
p2.clampScalar(0, 3.0);
expectDouble(p2.length, math.sqrt(2));
expect(p2.x, 1.0);
expect(p2.y, 1.0);
p2.clampScalar(0, 1.0);
expectDouble(p2.length, math.sqrt(2));
expect(p2.x, p2.y);
});
});
}