fix width handling in vbap panner
authorPaul Davis <paul@linuxaudiosystems.com>
Tue, 1 Mar 2011 21:53:54 +0000 (21:53 +0000)
committerPaul Davis <paul@linuxaudiosystems.com>
Tue, 1 Mar 2011 21:53:54 +0000 (21:53 +0000)
git-svn-id: svn://localhost/ardour2/branches/3.0@9013 d708f5d6-7413-0410-9779-e7cbd77b26cf

libs/panners/vbap/vbap.cc

index b053b670f92f2e5e39b4eb5163acaffeab306d02..df1f5d0876d1ae25609bbc13ef1e20b7530c29a6 100644 (file)
@@ -105,13 +105,13 @@ VBAPanner::update ()
 
                 double w = fabs (_pannable->pan_width_control->get_value()) * 360.0;
                 
-                double min_dir = center - w;
+                double min_dir = center - (w/2.0);
                 if (min_dir < 0) {
                         min_dir = 360.0 + min_dir; // its already negative
                 }
                 min_dir = max (min (min_dir, 360.0), 0.0);
                 
-                double max_dir = center + w;
+                double max_dir = center + (w/2.0);
                 if (max_dir > 360.0) {
                         max_dir = max_dir - 360.0;
                 }
@@ -125,6 +125,9 @@ VBAPanner::update ()
                 double signal_direction = min_dir;
 
                 if (w >= 0.0) {
+
+                        /* positive width - normal order of signal spread */
+
                         for (vector<Signal*>::iterator s = _signals.begin(); s != _signals.end(); ++s) {
                         
                                 Signal* signal = *s;
@@ -134,6 +137,9 @@ VBAPanner::update ()
                                 signal_direction += degree_step_per_signal;
                         }
                 } else {
+
+                        /* inverted width - reverse order of signal spread */
+
                         for (vector<Signal*>::reverse_iterator s = _signals.rbegin(); s != _signals.rend(); ++s) {
                         
                                 Signal* signal = *s;