Projection.cpp 935 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. #include "Projection.h"
  2. namespace msdfgen {
  3. Projection::Projection() : scale(1), translate(0) { }
  4. Projection::Projection(const Vector2 &scale, const Vector2 &translate) : scale(scale), translate(translate) { }
  5. Point2 Projection::project(const Point2 &coord) const {
  6. return scale*(coord+translate);
  7. }
  8. Point2 Projection::unproject(const Point2 &coord) const {
  9. return coord/scale-translate;
  10. }
  11. Vector2 Projection::projectVector(const Vector2 &vector) const {
  12. return scale*vector;
  13. }
  14. Vector2 Projection::unprojectVector(const Vector2 &vector) const {
  15. return vector/scale;
  16. }
  17. double Projection::projectX(double x) const {
  18. return scale.x*(x+translate.x);
  19. }
  20. double Projection::projectY(double y) const {
  21. return scale.y*(y+translate.y);
  22. }
  23. double Projection::unprojectX(double x) const {
  24. return x/scale.x-translate.x;
  25. }
  26. double Projection::unprojectY(double y) const {
  27. return y/scale.y-translate.y;
  28. }
  29. }