diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2015-10-02 15:52:04 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2015-10-02 15:52:04 +0200 |
commit | 4b8c1d92c864762fe9a470d026e32d3860abf591 (patch) | |
tree | 089f64cb1cd14025893fa6b20d7e838da7367799 /opentrack/tracker.cpp | |
parent | a457eec3d0cb5fa59f260a1cd569ee42690d912f (diff) | |
parent | 851116d818ddd01d5935c1bba10fe4900771d980 (diff) |
trackhat: use only absolute centering
Merged:
* unstable:
main: add relative and absolute center options
Diffstat (limited to 'opentrack/tracker.cpp')
-rw-r--r-- | opentrack/tracker.cpp | 39 |
1 files changed, 19 insertions, 20 deletions
diff --git a/opentrack/tracker.cpp b/opentrack/tracker.cpp index 88c90032..8a9a0511 100644 --- a/opentrack/tracker.cpp +++ b/opentrack/tracker.cpp @@ -78,26 +78,15 @@ void Tracker::logic() Pose value, raw; - if (!zero_) - for (int i = 0; i < 6; i++) - { - auto& axis = m(i); - int k = axis.opts.src; - if (k < 0 || k >= 6) - value(i) = 0; - else - value(i) = newpose[k]; - raw(i) = newpose[i]; - } - else + for (int i = 0; i < 6; i++) { - auto mat = rmat::rmat_to_euler(r_b); - - for (int i = 0; i < 3; i++) - { - raw(i+3) = value(i+3) = mat(i) * r2d; - raw(i) = value(i) = t_b[i]; - } + auto& axis = m(i); + int k = axis.opts.src; + if (k < 0 || k >= 6) + value(i) = 0; + else + value(i) = newpose[k]; + raw(i) = newpose[i]; } const double off[] = { @@ -134,7 +123,17 @@ void Tracker::logic() { double tmp[3] = { t(0) - t_b[0], t(1) - t_b[1], t(2) - t_b[2] }; t_compensate(cam, tmp, tmp, false); - const rmat m_ = r * r_b.t(); + rmat m_; + switch (1) + { + case 0: + default: + m_ = r * r_b.t(); + break; + case 1: + m_ = r_b.t() * r; + } + const dmat<3, 1> euler = rmat::rmat_to_euler(m_); for (int i = 0; i < 3; i++) { |