Mixer: Cleanup OSC value scaling/clamping behavior.

This commit is contained in:
Jonathan Moore Liles 2012-02-10 00:42:58 -08:00
parent 9ff41fe8fa
commit a11961f9b6
2 changed files with 21 additions and 21 deletions

View File

@ -235,28 +235,25 @@ Module::Port::change_osc_path ( char *path )
if ( _osc_path ) if ( _osc_path )
{ {
mixer->osc_endpoint->del_method( _osc_path, "f" ); mixer->osc_endpoint->del_method( _osc_path, "f" );
mixer->osc_endpoint->del_method( _osc_path_cv, "f" ); mixer->osc_endpoint->del_method( _osc_path_unscaled, "f" );
free( _osc_path ); free( _osc_path );
free( _osc_path_cv ); free( _osc_path_unscaled );
_osc_path = NULL; _osc_path = NULL;
_osc_path_cv = NULL; _osc_path_unscaled = NULL;
} }
if ( path ) if ( path )
{ {
_osc_path_cv = NULL; _osc_path_unscaled = NULL;
asprintf( &_osc_path_cv, "%s/unscaled", path );
mixer->osc_endpoint->add_method( path, "f", &Module::Port::osc_control_change_cv, this, "value" );
mixer->osc_endpoint->add_method( _osc_path_cv, "f", &Module::Port::osc_control_change_exact, this, "value" );
_osc_path = path; _osc_path = path;
// tooltip( _osc_path ); asprintf( &_osc_path_unscaled, "%s/unscaled", path );
mixer->osc_endpoint->add_method( _osc_path, "f", &Module::Port::osc_control_change_cv, this, "value" );
mixer->osc_endpoint->add_method( _osc_path_unscaled, "f", &Module::Port::osc_control_change_exact, this, "value" );
} }
} }
@ -266,8 +263,6 @@ Module::Port::osc_control_change_exact ( const char *path, const char *types, lo
{ {
Module::Port *p = (Module::Port*)user_data; Module::Port *p = (Module::Port*)user_data;
OSC_DMSG();
float f = argv[0]->f; float f = argv[0]->f;
if ( p->hints.ranged ) if ( p->hints.ranged )
@ -281,7 +276,7 @@ Module::Port::osc_control_change_exact ( const char *path, const char *types, lo
p->control_value( f ); p->control_value( f );
// mixer->osc_endpoint->send( lo_message_get_source( msg ), "/reply", path, "ok" ); // mixer->osc_endpoint->send( lo_message_get_source( msg ), "/reply", path, "ok" );
mixer->osc_endpoint->send( lo_message_get_source( msg ), path, argv[0]->f ); mixer->osc_endpoint->send( lo_message_get_source( msg ), path, f );
return 0; return 0;
} }
@ -293,10 +288,15 @@ Module::Port::osc_control_change_cv ( const char *path, const char *types, lo_ar
float f = argv[0]->f; float f = argv[0]->f;
// clamp value to control voltage range.
if ( f > 1.0 )
f = 1.0;
else if ( f < 0.0 )
f = 0.0;
if ( p->hints.ranged ) if ( p->hints.ranged )
{ {
// scale value to range. // scale value to range.
// we assume that CV values are between 0 and 1
float scale = p->hints.maximum - p->hints.minimum; float scale = p->hints.maximum - p->hints.minimum;
float offset = p->hints.minimum; float offset = p->hints.minimum;
@ -307,7 +307,7 @@ Module::Port::osc_control_change_cv ( const char *path, const char *types, lo_ar
p->control_value( f ); p->control_value( f );
// mixer->osc_endpoint->send( lo_message_get_source( msg ), "/reply", path, "ok" ); // mixer->osc_endpoint->send( lo_message_get_source( msg ), "/reply", path, "ok" );
mixer->osc_endpoint->send( lo_message_get_source( msg ), path, argv[0]->f ); mixer->osc_endpoint->send( lo_message_get_source( msg ), path, f );
return 0; return 0;
} }

View File

@ -125,7 +125,7 @@ public:
_connected = 0; _connected = 0;
_module = module; _module = module;
_osc_path = 0; _osc_path = 0;
_osc_path_cv = 0; _osc_path_unscaled = 0;
} }
Port ( const Port& p ) Port ( const Port& p )
@ -139,7 +139,7 @@ public:
_module = p._module; _module = p._module;
hints = p.hints; hints = p.hints;
_osc_path = p._osc_path; _osc_path = p._osc_path;
_osc_path_cv = p._osc_path; _osc_path_unscaled = p._osc_path_unscaled;
} }
virtual ~Port ( ) virtual ~Port ( )
@ -247,7 +247,7 @@ public:
Module *_module; Module *_module;
char *_osc_path; char *_osc_path;
char *_osc_path_cv; char *_osc_path_unscaled;
}; };
void bbox ( int &X, int &Y, int &W, int &H ) void bbox ( int &X, int &Y, int &W, int &H )