2003-09-13 13:42:08 +00:00
|
|
|
/* GStreamer Mixer
|
|
|
|
* Copyright (C) 2003 Ronald Bultje <rbultje@ronald.bitfreak.net>
|
2003-09-13 01:20:04 +00:00
|
|
|
*
|
|
|
|
* mixer.c: mixer design virtual class function wrappers
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2003-10-10 12:24:20 +00:00
|
|
|
#include "mixer.h"
|
2004-02-03 16:49:54 +00:00
|
|
|
#include "mixer-marshal.h"
|
2003-12-07 12:11:30 +00:00
|
|
|
|
|
|
|
enum {
|
|
|
|
MUTE_TOGGLED,
|
|
|
|
RECORD_TOGGLED,
|
|
|
|
VOLUME_CHANGED,
|
|
|
|
LAST_SIGNAL
|
|
|
|
};
|
2003-09-13 01:20:04 +00:00
|
|
|
|
|
|
|
static void gst_mixer_class_init (GstMixerClass *klass);
|
|
|
|
|
2003-12-07 12:11:30 +00:00
|
|
|
static guint gst_mixer_signals[LAST_SIGNAL] = { 0 };
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
GType
|
|
|
|
gst_mixer_get_type (void)
|
|
|
|
{
|
|
|
|
static GType gst_mixer_type = 0;
|
|
|
|
|
|
|
|
if (!gst_mixer_type) {
|
|
|
|
static const GTypeInfo gst_mixer_info = {
|
|
|
|
sizeof (GstMixerClass),
|
|
|
|
(GBaseInitFunc) gst_mixer_class_init,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
NULL,
|
|
|
|
};
|
|
|
|
|
|
|
|
gst_mixer_type = g_type_register_static (G_TYPE_INTERFACE,
|
|
|
|
"GstMixer",
|
|
|
|
&gst_mixer_info, 0);
|
|
|
|
g_type_interface_add_prerequisite (gst_mixer_type,
|
2003-12-07 12:11:30 +00:00
|
|
|
GST_TYPE_IMPLEMENTS_INTERFACE);
|
2003-09-13 01:20:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return gst_mixer_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gst_mixer_class_init (GstMixerClass *klass)
|
|
|
|
{
|
2003-12-07 12:11:30 +00:00
|
|
|
static gboolean initialized = FALSE;
|
|
|
|
|
|
|
|
if (!initialized) {
|
|
|
|
gst_mixer_signals[RECORD_TOGGLED] =
|
2004-03-04 21:39:15 +00:00
|
|
|
g_signal_new ("record-toggled",
|
2003-12-07 12:11:30 +00:00
|
|
|
GST_TYPE_MIXER, G_SIGNAL_RUN_LAST,
|
|
|
|
G_STRUCT_OFFSET (GstMixerClass, record_toggled),
|
|
|
|
NULL, NULL,
|
|
|
|
gst_mixer_marshal_VOID__OBJECT_BOOLEAN, G_TYPE_NONE, 1,
|
|
|
|
GST_TYPE_MIXER_TRACK, G_TYPE_BOOLEAN);
|
|
|
|
gst_mixer_signals[MUTE_TOGGLED] =
|
2004-03-04 21:39:15 +00:00
|
|
|
g_signal_new ("mute-toggled",
|
2003-12-07 12:11:30 +00:00
|
|
|
GST_TYPE_MIXER, G_SIGNAL_RUN_LAST,
|
|
|
|
G_STRUCT_OFFSET (GstMixerClass, mute_toggled),
|
|
|
|
NULL, NULL,
|
|
|
|
gst_mixer_marshal_VOID__OBJECT_BOOLEAN, G_TYPE_NONE, 1,
|
|
|
|
GST_TYPE_MIXER_TRACK, G_TYPE_BOOLEAN);
|
|
|
|
gst_mixer_signals[VOLUME_CHANGED] =
|
2004-03-04 21:39:15 +00:00
|
|
|
g_signal_new ("volume-changed",
|
2003-12-07 12:11:30 +00:00
|
|
|
GST_TYPE_MIXER, G_SIGNAL_RUN_LAST,
|
|
|
|
G_STRUCT_OFFSET (GstMixerClass, volume_changed),
|
|
|
|
NULL, NULL,
|
|
|
|
gst_mixer_marshal_VOID__OBJECT_POINTER, G_TYPE_NONE, 1,
|
|
|
|
GST_TYPE_MIXER_TRACK, G_TYPE_POINTER);
|
|
|
|
|
|
|
|
initialized = TRUE;
|
|
|
|
}
|
|
|
|
|
ext/alsa/gstalsamixer.c: Setting mixer interface type to HARDWARE.
Original commit message from CVS:
2004-01-15 Julien MOUTTE <julien@moutte.net>
* ext/alsa/gstalsamixer.c: (gst_alsa_mixer_interface_init): Setting
mixer interface type to HARDWARE.
* gst-libs/gst/mixer/mixer.c: (gst_mixer_class_init): Adding a default
type to SOFTWARE.
* gst-libs/gst/mixer/mixer.h: Adding mixer interface type and macro.
* gst-libs/gst/mixer/mixertrack.h: Adding mixertrack flag SOFTWARE.
* gst/volume/gstvolume.c: (gst_volume_interface_supported),
(gst_volume_interface_init), (gst_volume_list_tracks),
(gst_volume_set_volume), (gst_volume_get_volume),
(gst_volume_set_mute), (gst_volume_mixer_init),
(gst_volume_dispose), (gst_volume_get_type), (volume_class_init),
(volume_init): Implementing mixer interface.
* gst/volume/gstvolume.h: Adding tracklist for mixer interface.
* sys/oss/gstosselement.c: (gst_osselement_get_type),
(gst_osselement_change_state): Removing some trailing commas in
structures.
* sys/oss/gstossmixer.c: (gst_ossmixer_interface_init): Setting mixer
interface type to HARDWARE.
* sys/v4l/gstv4lcolorbalance.c:
(gst_v4l_color_balance_interface_init): Setting colorbalance interface
type to HARDWARE.
* sys/v4l2/gstv4l2colorbalance.c:
(gst_v4l2_color_balance_interface_init): Setting colorbalance
interface type to HARDWARE.
* sys/xvimage/xvimagesink.c: (gst_xvimagesink_chain): use exactly the
same code than ximagesink for event handling.
2004-01-15 15:50:10 +00:00
|
|
|
klass->mixer_type = GST_MIXER_SOFTWARE;
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
/* default virtual functions */
|
2003-10-09 22:02:35 +00:00
|
|
|
klass->list_tracks = NULL;
|
2003-09-13 01:20:04 +00:00
|
|
|
klass->set_volume = NULL;
|
|
|
|
klass->get_volume = NULL;
|
|
|
|
klass->set_mute = NULL;
|
|
|
|
klass->set_record = NULL;
|
|
|
|
}
|
|
|
|
|
2004-01-25 22:07:16 +00:00
|
|
|
/**
|
|
|
|
*agst_mixer_list_tracks:
|
|
|
|
* @mixer: the #GstMixer (a #GstElement) to get the tracks from.
|
|
|
|
*
|
|
|
|
* Returns a list of avialable tracks for this mixer/element. Note
|
|
|
|
* that it is allowed for sink (output) elements to only provide
|
|
|
|
* the output tracks in this list. Likewise, for sources (inputs),
|
|
|
|
* it is allowed to only provide input elements in this list.
|
|
|
|
*
|
|
|
|
* Returns: A #GList consisting of zero or more #GstMixerTracks.
|
|
|
|
*/
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
const GList *
|
2003-10-10 12:24:20 +00:00
|
|
|
gst_mixer_list_tracks (GstMixer *mixer)
|
2003-09-13 01:20:04 +00:00
|
|
|
{
|
|
|
|
GstMixerClass *klass = GST_MIXER_GET_CLASS (mixer);
|
|
|
|
|
2003-10-09 22:02:35 +00:00
|
|
|
if (klass->list_tracks) {
|
|
|
|
return klass->list_tracks (mixer);
|
2003-09-13 01:20:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2004-01-25 22:07:16 +00:00
|
|
|
/**
|
|
|
|
* gst_mixer_set_volume:
|
|
|
|
* @mixer: The #GstMixer (a #GstElement) that owns the track.
|
|
|
|
* @track: The #GstMixerTrack to set the volume on.
|
|
|
|
* @volumes: an array of integers (of size track->num_channels)
|
|
|
|
* that gives the wanted volume for each channel in
|
|
|
|
* this track.
|
|
|
|
*
|
|
|
|
* Sets the volume on each channel in a track. Short note about
|
|
|
|
* naming: a track is defined as one separate stream owned by
|
|
|
|
* the mixer/element, such as 'Line-in' or 'Microphone'. A
|
|
|
|
* channel is said to be a mono-stream inside this track. A
|
|
|
|
* stereo track thus contains two channels.
|
|
|
|
*/
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
void
|
2003-10-09 22:02:35 +00:00
|
|
|
gst_mixer_set_volume (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gint *volumes)
|
2003-09-13 01:20:04 +00:00
|
|
|
{
|
|
|
|
GstMixerClass *klass = GST_MIXER_GET_CLASS (mixer);
|
|
|
|
|
|
|
|
if (klass->set_volume) {
|
2003-10-09 22:02:35 +00:00
|
|
|
klass->set_volume (mixer, track, volumes);
|
2003-09-13 01:20:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-01-25 22:07:16 +00:00
|
|
|
/*
|
|
|
|
* gst_mixer_get_volume:
|
|
|
|
* @mixer: the #GstMixer (a #GstElement) that owns the track
|
|
|
|
* @track: the GstMixerTrack to get the volume from.
|
|
|
|
* @volumes: a pre-allocated array of integers (of size
|
|
|
|
* track->num_channels) to store the current volume
|
|
|
|
* of each channel in the given track in.
|
|
|
|
*
|
|
|
|
* Get the current volume(s) on the given track.
|
|
|
|
*/
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
void
|
2003-10-09 22:02:35 +00:00
|
|
|
gst_mixer_get_volume (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gint *volumes)
|
2003-09-13 01:20:04 +00:00
|
|
|
{
|
|
|
|
GstMixerClass *klass = GST_MIXER_GET_CLASS (mixer);
|
|
|
|
|
|
|
|
if (klass->get_volume) {
|
2003-10-09 22:02:35 +00:00
|
|
|
klass->get_volume (mixer, track, volumes);
|
2003-09-13 01:20:04 +00:00
|
|
|
} else {
|
|
|
|
gint i;
|
|
|
|
|
2003-10-09 22:02:35 +00:00
|
|
|
for (i = 0; i < track->num_channels; i++) {
|
2003-09-13 01:20:04 +00:00
|
|
|
volumes[i] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-01-25 22:07:16 +00:00
|
|
|
/**
|
|
|
|
* gst_mixer_set_mute:
|
|
|
|
* @mixer: the #GstMixer (a #GstElement) that owns the track.
|
|
|
|
* @track: the #GstMixerTrack to operate on.
|
|
|
|
* @mute: a boolean value indicating whether to turn on or off
|
|
|
|
* muting.
|
|
|
|
*
|
|
|
|
* Mutes or unmutes the given channel. To find out whether a
|
|
|
|
* track is currently muted, use GST_MIXER_TRACK_HAS_FLAG ().
|
|
|
|
*/
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
void
|
2003-10-09 22:02:35 +00:00
|
|
|
gst_mixer_set_mute (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gboolean mute)
|
2003-09-13 01:20:04 +00:00
|
|
|
{
|
|
|
|
GstMixerClass *klass = GST_MIXER_GET_CLASS (mixer);
|
|
|
|
|
|
|
|
if (klass->set_mute) {
|
2003-10-09 22:02:35 +00:00
|
|
|
klass->set_mute (mixer, track, mute);
|
2003-09-13 01:20:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-01-25 22:07:16 +00:00
|
|
|
/**
|
|
|
|
* gst_mixer_set_record:
|
|
|
|
* @mixer: The #GstMixer (a #GstElement) that owns the track.
|
|
|
|
* @track: the #GstMixerTrack to operate on.
|
|
|
|
* @record: a boolean value that indicates whether to turn on
|
|
|
|
* or off recording.
|
|
|
|
*
|
|
|
|
* Enables or disables recording on the given track. Note that
|
|
|
|
* this is only possible on input tracks, not on output tracks
|
|
|
|
* (see GST_MIXER_TRACK_HAS_FLAG () and the GST_MIXER_TRACK_INPUT
|
|
|
|
* flag).
|
|
|
|
*/
|
|
|
|
|
2003-09-13 01:20:04 +00:00
|
|
|
void
|
2003-10-09 22:02:35 +00:00
|
|
|
gst_mixer_set_record (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gboolean record)
|
2003-09-13 01:20:04 +00:00
|
|
|
{
|
|
|
|
GstMixerClass *klass = GST_MIXER_GET_CLASS (mixer);
|
|
|
|
|
|
|
|
if (klass->set_record) {
|
2003-10-09 22:02:35 +00:00
|
|
|
klass->set_record (mixer, track, record);
|
2003-09-13 01:20:04 +00:00
|
|
|
}
|
|
|
|
}
|
2003-12-07 12:11:30 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
gst_mixer_mute_toggled (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gboolean mute)
|
|
|
|
{
|
|
|
|
g_signal_emit (G_OBJECT (mixer),
|
|
|
|
gst_mixer_signals[MUTE_TOGGLED], 0,
|
|
|
|
track, mute);
|
|
|
|
|
|
|
|
g_signal_emit_by_name (G_OBJECT (track),
|
|
|
|
"mute_toggled",
|
|
|
|
mute);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
gst_mixer_record_toggled (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gboolean record)
|
|
|
|
{
|
|
|
|
g_signal_emit (G_OBJECT (mixer),
|
|
|
|
gst_mixer_signals[RECORD_TOGGLED], 0,
|
|
|
|
track, record);
|
|
|
|
|
|
|
|
g_signal_emit_by_name (G_OBJECT (track),
|
|
|
|
"record_toggled",
|
|
|
|
record);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
gst_mixer_volume_changed (GstMixer *mixer,
|
|
|
|
GstMixerTrack *track,
|
|
|
|
gint *volumes)
|
|
|
|
{
|
|
|
|
g_signal_emit (G_OBJECT (mixer),
|
|
|
|
gst_mixer_signals[VOLUME_CHANGED], 0,
|
|
|
|
track, volumes);
|
|
|
|
|
|
|
|
g_signal_emit_by_name (G_OBJECT (track),
|
|
|
|
"volume_changed",
|
|
|
|
volumes);
|
|
|
|
}
|