[pulseaudio-discuss] java sound implementation using pulseaudio - ports

Ioana Ivan iivan at redhat.com
Wed Aug 27 17:26:18 PDT 2008


Thanks, that's what we decided to do.

I have a question regarding closing the pulseaudio sinks/source. Should 
I use pa_context_suspend_sink/source_by_index/name or just mute them? 
I'm not sure exactly what pa_context_suspend_sink_by_index should do; 
I've tried using it and it didn't seem to have any effect (i.e. I could 
still hear the sound).

Colin Guthrie wrote:
> Ioana Ivan wrote:
>   
>> Hi,
>>
>> We've been trying to write an implementation of 
>> javax.sound.sampled.Mixer(and the associated classes: SourceDataLine, 
>> TargetDataLine, Clip, and Port) that uses pulseaudio as a backend. So 
>> far, SourceDataLine, TargetDataLine and Clip are working (somewhat, 
>> there are still issues that need to be fixed), but we're not sure how to 
>> approach Port.
>>
>>  From the java API:
>> "Ports are simple lines for input or output of audio to or from audio 
>> devices. Common examples of ports that act as source lines (mixer 
>> inputs) include the microphone, line input, and CD-ROM drive. Ports that 
>> act as target lines (mixer outputs) include the speaker, headphone, and 
>> line output. You can access port using a Port.Info  object."
>>
>> Ports should have an open() and close() method, and ideally they should 
>> also support volume and mute controls. There currently is an 
>> implementation of Port in openjdk that uses alsa to enumerate the 
>> devices that could connect to the sound system, and implement the 
>> required methods.
>>
>> We were wondering whether there's anything in the pulseaudio API that 
>> could be used to do something similar, and, if not, how problematic 
>> using the old version of Port(that uses alsa directly) with our mixer 
>> that uses pulseaudio is.
>>     
>
> I spoke to you on the mailing list but this is a little clearer I think.
>
> Basically you just want to expose the volume of the various Sinks and 
> Sources here. I would just get a list of all the Sinks and provide 
> playback Ports that allow volume control and muting etc. and do a 
> similar exposure for the Sources.
>
> I'd use the introspection stuff to do this (tho' not overly sure).
>
> http://0pointer.de/lennart/projects/pulseaudio/doxygen/introspect_8h.html
>
> You can probably use the source of pavucontrol to work out what to do here.
>
> You can of course export a volume on a "per stream" basis, but I'd 
> imagine this doesn't map too well to the Java API seeing as streams will 
> come and go quickly but sinks/sources will be slightly more long term 
> (tho can still come and go (e.g. when a usb audio device is plugged in 
> or a network sink is detected etc.)
>
>
> I think whatever is in the "Output devices" and "Input devices" tab in 
> pavucontrol (from git) is probably what you want...
>
>
> HTHs
>
> Col
>
>   




More information about the pulseaudio-discuss mailing list