diff options
| author | Lennart Poettering <lennart@poettering.net> | 2009-09-11 02:32:21 +0200 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2009-09-11 02:32:21 +0200 | 
| commit | 6fa2445e1131c9c42b685451fd47d79ae2884871 (patch) | |
| tree | dde1704dbd1ec07627ef205e45ecf5fa3233d56c /src/modules | |
| parent | 5919337433e97c36be904c4f7839f22045aa7947 (diff) | |
position-event-sounds: honour window position if set, position both vertically and horizontally
Diffstat (limited to 'src/modules')
| -rw-r--r-- | src/modules/module-position-event-sounds.c | 55 | 
1 files changed, 44 insertions, 11 deletions
| diff --git a/src/modules/module-position-event-sounds.c b/src/modules/module-position-event-sounds.c index e191ec33..c3329f88 100644 --- a/src/modules/module-position-event-sounds.c +++ b/src/modules/module-position-event-sounds.c @@ -57,34 +57,67 @@ struct userdata {      pa_hook_slot *sink_input_fixate_hook_slot;  }; +static int parse_pos(const char *pos, double *f) { + +    if (pa_atod(pos, f) < 0) { +        pa_log_warn("Failed to parse hpos/vpos property '%s'.", pos); +        return -1; +    } + +    if (*f < 0.0 || *f > 1.0) { +        pa_log_warn("Property hpos/vpos out of range %0.2f", *f); +        return -1; +    } + +    return 0; +} +  static pa_hook_result_t sink_input_fixate_hook_callback(pa_core *core, pa_sink_input_new_data *data, struct userdata *u) { -    const char *hpos; +    const char *hpos, *vpos, *role;      double f;      char t[PA_CVOLUME_SNPRINT_MAX];      pa_cvolume v;      pa_assert(data); -    if (!(hpos = pa_proplist_gets(data->proplist, PA_PROP_EVENT_MOUSE_HPOS))) +    if (!(role = pa_proplist_gets(data->proplist, PA_PROP_MEDIA_ROLE)))          return PA_HOOK_OK; -    if (pa_atod(hpos, &f) < 0) { -        pa_log_warn("Failed to parse "PA_PROP_EVENT_MOUSE_HPOS" property '%s'.", hpos); +    if (!pa_streq(role, "event"))          return PA_HOOK_OK; -    } -    if (f < 0.0 || f > 1.0) { -        pa_log_warn("Property "PA_PROP_EVENT_MOUSE_HPOS" out of range %0.2f", f); +    if (!(hpos = pa_proplist_gets(data->proplist, PA_PROP_EVENT_MOUSE_HPOS))) +        hpos = pa_proplist_gets(data->proplist, PA_PROP_WINDOW_HPOS); + +    if (!(vpos = pa_proplist_gets(data->proplist, PA_PROP_EVENT_MOUSE_VPOS))) +        vpos = pa_proplist_gets(data->proplist, PA_PROP_WINDOW_VPOS); + +    if (!hpos && !vpos)          return PA_HOOK_OK; + +    pa_cvolume_reset(&v, data->sample_spec.channels); + +    if (hpos) { +        if (parse_pos(hpos, &f) < 0) +            return PA_HOOK_OK; + +        if (pa_channel_map_can_balance(&data->channel_map)) { +            pa_log_debug("Positioning event sound '%s' horizontally at %0.2f.", pa_strnull(pa_proplist_gets(data->proplist, PA_PROP_EVENT_ID)), f); +            pa_cvolume_set_balance(&v, &data->channel_map, f*2.0-1.0); +        }      } -    pa_log_debug("Positioning event sound '%s' at %0.2f.", pa_strnull(pa_proplist_gets(data->proplist, PA_PROP_EVENT_ID)), f); +    if (vpos) { +        if (parse_pos(vpos, &f) < 0) +            return PA_HOOK_OK; -    pa_cvolume_reset(&v, data->sample_spec.channels); -    pa_cvolume_set_balance(&v, &data->channel_map, f*2.0-1.0); +        if (pa_channel_map_can_fade(&data->channel_map)) { +            pa_log_debug("Positioning event sound '%s' vertically at %0.2f.", pa_strnull(pa_proplist_gets(data->proplist, PA_PROP_EVENT_ID)), f); +            pa_cvolume_set_fade(&v, &data->channel_map, f*2.0-1.0); +        } +    }      pa_log_debug("Final volume factor %s.", pa_cvolume_snprint(t, sizeof(t), &v)); -      pa_sink_input_new_data_apply_volume_factor(data, &v);      return PA_HOOK_OK; | 
