Removed connecting to soundcard, since the node is not registered
with the media_server inside the AutoStart() function. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3314 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
c30acb53ce
commit
e02a6254fc
@ -4,9 +4,7 @@
|
|||||||
// Marcus Overhagen, 2003
|
// Marcus Overhagen, 2003
|
||||||
//
|
//
|
||||||
// Allows AudioMixer to be used as an addon.
|
// Allows AudioMixer to be used as an addon.
|
||||||
// The add-on will request to be auto-started,
|
// The add-on will request to be auto-started.
|
||||||
// if this happens, it will try to connect
|
|
||||||
// itself to the default audio output.
|
|
||||||
|
|
||||||
#include <MediaRoster.h>
|
#include <MediaRoster.h>
|
||||||
#include <MediaNode.h>
|
#include <MediaNode.h>
|
||||||
@ -112,66 +110,6 @@ AudioMixerAddon::AutoStart(int in_index, BMediaNode ** out_node,
|
|||||||
return B_ERROR;
|
return B_ERROR;
|
||||||
|
|
||||||
*out_internal_id = 0;
|
*out_internal_id = 0;
|
||||||
*out_node = new AudioMixer(this);
|
*out_node = new AudioMixer(this);
|
||||||
|
|
||||||
// The mixer has been created.
|
|
||||||
// We now try to connect it with the default audio output.
|
|
||||||
|
|
||||||
if (ConnectToOutput(*out_node) != B_OK) {
|
|
||||||
printf("AudioMixerAddon::AutoStart: failed to ConnectToOutput()\n");
|
|
||||||
// cleanup
|
|
||||||
// return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
return B_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
status_t
|
|
||||||
AudioMixerAddon::ConnectToOutput(BMediaNode *node)
|
|
||||||
{
|
|
||||||
BMediaRoster *roster;
|
|
||||||
media_node mixer;
|
|
||||||
media_node soundcard;
|
|
||||||
media_input input;
|
|
||||||
media_output output;
|
|
||||||
int32 count;
|
|
||||||
status_t rv;
|
|
||||||
|
|
||||||
roster = BMediaRoster::Roster();
|
|
||||||
mixer = node->Node();
|
|
||||||
|
|
||||||
// XXX this connects to *any* physical output, but not the default logical input
|
|
||||||
|
|
||||||
rv = roster->GetAudioOutput(&soundcard);
|
|
||||||
if (rv < B_OK) {
|
|
||||||
printf("AudioMixerAddon::AutoStart: failed to find soundcard (physical audio output)\n");
|
|
||||||
return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
// we now have the mixer and soundcard nodes,
|
|
||||||
// find a free input/output and connect them
|
|
||||||
|
|
||||||
rv = roster->GetFreeOutputsFor(mixer, &output, 1, &count, B_MEDIA_RAW_AUDIO);
|
|
||||||
if (rv < B_OK || count != 1) {
|
|
||||||
printf("AudioMixerAddon::AutoStart: can't find free mixer output\n");
|
|
||||||
return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
rv = roster->GetFreeInputsFor(soundcard, &input, 1, &count, B_MEDIA_RAW_AUDIO);
|
|
||||||
if (rv < B_OK || count != 1) {
|
|
||||||
printf("AudioMixerAddon::AutoStart: can't find free soundcard input\n");
|
|
||||||
return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
media_format format;
|
|
||||||
memset(&format, 0, sizeof(format));
|
|
||||||
format.type = B_MEDIA_RAW_AUDIO;
|
|
||||||
|
|
||||||
rv = roster->Connect(output.source, input.destination, &format, &output, &input);
|
|
||||||
if (rv < B_OK) {
|
|
||||||
printf("AudioMixerAddon::AutoStart: connect failed\n");
|
|
||||||
return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
@ -40,9 +40,7 @@ virtual status_t AutoStart(
|
|||||||
BMediaNode ** out_node,
|
BMediaNode ** out_node,
|
||||||
int32 * out_internal_id,
|
int32 * out_internal_id,
|
||||||
bool * out_has_more);
|
bool * out_has_more);
|
||||||
private:
|
|
||||||
status_t ConnectToOutput(BMediaNode *node);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
media_format *fFormat;
|
media_format *fFormat;
|
||||||
flavor_info *fInfo;
|
flavor_info *fInfo;
|
||||||
|
Loading…
Reference in New Issue
Block a user