afxCurveEval.cpp 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. //~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
  2. // Arcane-FX for MIT Licensed Open Source version of Torque 3D from GarageGames
  3. // Copyright (C) 2015 Faust Logic, Inc.
  4. //
  5. // Permission is hereby granted, free of charge, to any person obtaining a copy
  6. // of this software and associated documentation files (the "Software"), to
  7. // deal in the Software without restriction, including without limitation the
  8. // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  9. // sell copies of the Software, and to permit persons to whom the Software is
  10. // furnished to do so, subject to the following conditions:
  11. //
  12. // The above copyright notice and this permission notice shall be included in
  13. // all copies or substantial portions of the Software.
  14. //
  15. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  18. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  20. // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  21. // IN THE SOFTWARE.
  22. //
  23. //~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
  24. #include "afx/arcaneFX.h"
  25. #include "afx/util/afxCurveEval.h"
  26. Point2F afxHermiteEval::evaluateCurve( Point2F &v0, Point2F &v1,
  27. Point2F &t0, Point2F &t1, F32 t )
  28. {
  29. F32 t_3 = t*t*t;
  30. F32 t_2 = t*t;
  31. F32 h1 = ( 2.0f * t_3 ) - ( 3.0f * t_2 ) + 1;
  32. F32 h2 = (-2.0f * t_3 ) + ( 3.0f * t_2 );
  33. F32 h3 = t_3 - ( 2.0f * t_2 ) + t;
  34. F32 h4 = t_3 - t_2;
  35. Point2F v(
  36. (h1*v0.x)+(h2*v1.x)+(h3*t0.x)+(h4*t1.x),
  37. (h1*v0.y)+(h2*v1.y)+(h3*t0.y)+(h4*t1.y) );
  38. return v;
  39. }
  40. Point2F afxHermiteEval::evaluateCurve( Point2F &v0, Point2F &v1, F32 t )
  41. {
  42. Point2F tangent( 1, 0 );
  43. return( evaluateCurve( v0, v1, tangent, tangent, t ) );
  44. }
  45. Point2F afxHermiteEval::evaluateCurveTangent( Point2F &v0, Point2F &v1,
  46. Point2F &t0, Point2F &t1, F32 t )
  47. {
  48. F32 t_2 = t*t;
  49. F32 h1_der = ( 6.0f * t_2 ) - ( 6.0f * t );
  50. F32 h2_der = (-6.0f * t_2 ) + ( 6.0f * t );
  51. F32 h3_der = ( 3.0f * t_2 ) - ( 4.0f * t ) + 1;
  52. F32 h4_der = ( 3.0f * t_2 ) - ( 2.0f * t );
  53. Point2F tangent(
  54. (h1_der*v0.x)+(h2_der*v1.x)+(h3_der*t0.x)+(h4_der*t1.x),
  55. (h1_der*v0.y)+(h2_der*v1.y)+(h3_der*t0.y)+(h4_der*t1.y) );
  56. return tangent;
  57. }
  58. Point2F afxHermiteEval::evaluateCurveTangent( Point2F &v0, Point2F &v1, F32 t )
  59. {
  60. Point2F tangent( 1, 0 );
  61. return( evaluateCurveTangent( v0, v1, tangent, tangent, t ) );
  62. }
  63. Point3F afxHermiteEval::evaluateCurve( Point3F &v0, Point3F &v1,
  64. Point3F &t0, Point3F &t1, F32 t )
  65. {
  66. F32 t_3 = t*t*t;
  67. F32 t_2 = t*t;
  68. F32 h1 = ( 2.0f * t_3 ) - ( 3.0f * t_2 ) + 1;
  69. F32 h2 = (-2.0f * t_3 ) + ( 3.0f * t_2 );
  70. F32 h3 = t_3 - ( 2.0f * t_2 ) + t;
  71. F32 h4 = t_3 - t_2;
  72. Point3F v(
  73. (h1*v0.x)+(h2*v1.x)+(h3*t0.x)+(h4*t1.x),
  74. (h1*v0.y)+(h2*v1.y)+(h3*t0.y)+(h4*t1.y),
  75. (h1*v0.z)+(h2*v1.z)+(h3*t0.z)+(h4*t1.z) );
  76. return v;
  77. }
  78. Point3F afxHermiteEval::evaluateCurve( Point3F &v0, Point3F &v1, F32 t )
  79. {
  80. Point3F tangent( 1, 0, 0 );
  81. return( evaluateCurve( v0, v1, tangent, tangent, t ) );
  82. }
  83. Point3F afxHermiteEval::evaluateCurveTangent( Point3F &v0, Point3F &v1,
  84. Point3F &t0, Point3F &t1, F32 t )
  85. {
  86. F32 t_2 = t*t;
  87. F32 h1_der = ( 6.0f * t_2 ) - ( 6.0f * t );
  88. F32 h2_der = (-6.0f * t_2 ) + ( 6.0f * t );
  89. F32 h3_der = ( 3.0f * t_2 ) - ( 4.0f * t ) + 1;
  90. F32 h4_der = ( 3.0f * t_2 ) - ( 2.0f * t );
  91. Point3F tangent(
  92. (h1_der*v0.x)+(h2_der*v1.x)+(h3_der*t0.x)+(h4_der*t1.x),
  93. (h1_der*v0.y)+(h2_der*v1.y)+(h3_der*t0.y)+(h4_der*t1.y),
  94. (h1_der*v0.z)+(h2_der*v1.z)+(h3_der*t0.z)+(h4_der*t1.z) );
  95. return tangent;
  96. }
  97. Point3F afxHermiteEval::evaluateCurveTangent( Point3F &v0, Point3F &v1, F32 t )
  98. {
  99. Point3F tangent( 1, 0, 0 );
  100. return( evaluateCurveTangent( v0, v1, tangent, tangent, t ) );
  101. }
  102. //~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//