MatrixTests.cs 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. using System;
  2. using Avalonia.Utilities;
  3. using Xunit;
  4. namespace Avalonia.Base.UnitTests.Media
  5. {
  6. public class MatrixTests
  7. {
  8. [Fact]
  9. public void Can_Parse()
  10. {
  11. var matrix = Matrix.Parse("1,2,3,-4,5 6");
  12. var expected = new Matrix(1, 2, 3, -4, 5, 6);
  13. Assert.Equal(expected, matrix);
  14. }
  15. [Fact]
  16. public void Singular_Has_No_Inverse()
  17. {
  18. var matrix = new Matrix(0, 0, 0, 0, 0, 0);
  19. Assert.False(matrix.HasInverse);
  20. }
  21. [Fact]
  22. public void Identity_Has_Inverse()
  23. {
  24. var matrix = Matrix.Identity;
  25. Assert.True(matrix.HasInverse);
  26. }
  27. [Fact]
  28. public void Invert_Should_Work()
  29. {
  30. var matrix = new Matrix(1, 2, 3, 0, 1, 4, 5, 6, 0);
  31. var inverted = matrix.Invert();
  32. Assert.Equal(matrix * inverted, Matrix.Identity);
  33. Assert.Equal(inverted * matrix, Matrix.Identity);
  34. }
  35. [Fact]
  36. public void Can_Decompose_Translation()
  37. {
  38. var matrix = Matrix.CreateTranslation(5, 10);
  39. var result = Matrix.TryDecomposeTransform(matrix, out Matrix.Decomposed decomposed);
  40. Assert.Equal(true, result);
  41. Assert.Equal(5, decomposed.Translate.X);
  42. Assert.Equal(10, decomposed.Translate.Y);
  43. }
  44. [Theory]
  45. [InlineData(30d)]
  46. [InlineData(0d)]
  47. [InlineData(90d)]
  48. [InlineData(270d)]
  49. public void Can_Decompose_Angle(double angleDeg)
  50. {
  51. var angleRad = MathUtilities.Deg2Rad(angleDeg);
  52. var matrix = Matrix.CreateRotation(angleRad);
  53. var result = Matrix.TryDecomposeTransform(matrix, out Matrix.Decomposed decomposed);
  54. Assert.Equal(true, result);
  55. var expected = NormalizeAngle(angleRad);
  56. var actual = NormalizeAngle(decomposed.Angle);
  57. Assert.Equal(expected, actual, 4);
  58. }
  59. [Theory]
  60. [InlineData(1d, 1d)]
  61. [InlineData(-1d, 1d)]
  62. [InlineData(1d, -1d)]
  63. [InlineData(5d, 10d)]
  64. public void Can_Decompose_Scale(double x, double y)
  65. {
  66. var matrix = Matrix.CreateScale(x, y);
  67. var result = Matrix.TryDecomposeTransform(matrix, out Matrix.Decomposed decomposed);
  68. Assert.Equal(true, result);
  69. Assert.Equal(x, decomposed.Scale.X);
  70. Assert.Equal(y, decomposed.Scale.Y);
  71. }
  72. private static double NormalizeAngle(double rad)
  73. {
  74. double twoPi = 2 * Math.PI;
  75. while (rad < 0)
  76. {
  77. rad += twoPi;
  78. }
  79. while (rad > twoPi)
  80. {
  81. rad -= twoPi;
  82. }
  83. return rad;
  84. }
  85. }
  86. }