Sha256: 09122df1fb7da71bc28aa2ac6b653b00ae42fb6498d611c4a18223a04aa1f765
Contents?: true
Size: 1.86 KB
Versions: 12
Compression:
Stored size: 1.86 KB
Contents
// Default matrices, adapted from original Transform support // contribution by erisdiscord. Thank you! #include "GraphicsImpl.hpp" #include <Gosu/GraphicsBase.hpp> #include <Gosu/Math.hpp> #include <cmath> Gosu::Transform Gosu::rotate(double angle, double around_x, double around_y) { double c = std::cos(degrees_to_radians(angle)); double s = std::sin(degrees_to_radians(angle)); Gosu::Transform result = { +c, +s, 0, 0, -s, +c, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 }; if (around_x != 0 || around_y != 0) { result = concat(concat(translate(-around_x, -around_y), result), translate(around_x, around_y)); } return result; } Gosu::Transform Gosu::translate(double x, double y) { Gosu::Transform result = { 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, x, y, 0, 1 }; return result; } Gosu::Transform Gosu::scale(double factor) { Gosu::Transform result = { factor, 0, 0, 0, 0, factor, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 }; return result; } Gosu::Transform Gosu::scale(double scale_x, double scale_y, double around_x, double around_y) { Gosu::Transform result = { scale_x, 0, 0, 0, 0, scale_y, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 }; if (around_x != 0 || around_y != 0) { result = concat(concat(translate(-around_x, -around_y), result), translate(around_x, around_y)); } return result; } Gosu::Transform Gosu::concat(const Transform& left, const Transform& right) { Gosu::Transform result; for (int i = 0; i < 16; ++i) { result[i] = 0; for (int j = 0; j < 4; ++j) { result[i] += left[i / 4 * 4 + j] * right[i % 4 + j * 4]; } } return result; }
Version data entries
12 entries across 12 versions & 1 rubygems