123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- #ifndef STUDIO_UTIL_GEOM_H_FB758F4A_2FB3_527A_81CE_74C1E91A4DFF
- #define STUDIO_UTIL_GEOM_H_FB758F4A_2FB3_527A_81CE_74C1E91A4DFF
- #include <QPoint>
- #include <QMatrix>
- #include <2geom/point.h>
- #include <core/std/traits.h>
- namespace rainynite::util {
- template <typename S, typename T>
- T point(S&& p);
- template <typename S>
- std::enable_if_t<is_same_v<std::decay_t<S>,Geom::Point>, QPointF>
- point(S&& p) {
- return { p.x(), p.y() };
- }
- template <typename S>
- std::enable_if_t<is_same_v<std::decay_t<S>,QPointF>, Geom::Point>
- point(S&& p) {
- return { p.x(), p.y() };
- }
- template <typename S>
- std::enable_if_t<is_same_v<std::decay_t<S>,QPoint>, Geom::Point>
- point(S&& p) {
- return { (Geom::Coord) p.x(), (Geom::Coord) p.y() };
- }
- template <typename S, typename T>
- T matrix(S&& m);
- template <typename S>
- std::enable_if_t<is_same_v<std::decay_t<S>,Geom::Affine>, QMatrix>
- matrix(S&& m) {
- return {m[0], m[1], m[2], m[3], m[4], m[5]};
- }
- template <typename S>
- std::enable_if_t<is_same_v<std::decay_t<S>,QMatrix>, Geom::Affine>
- matrix(S&& m) {
- return {m.m11(), m.m12(), m.m21(), m.m22(), m.dx(), m.dy()};
- }
- }
- #endif
|