mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-01 21:18:52 +00:00
sbc: Add mp3 support for gstreamer plugin.
This commit is contained in:
parent
76c77b1c60
commit
84dcb6bb34
2 changed files with 70 additions and 4 deletions
|
@ -95,13 +95,23 @@ gst_sbc_get_allocation_from_list (const GValue * value)
|
|||
|
||||
/*
|
||||
* Selects one mode from the ones on the list
|
||||
* TODO - use a better aproach
|
||||
*/
|
||||
const gchar *
|
||||
gst_sbc_get_mode_from_list (const GValue * value)
|
||||
gst_sbc_get_mode_from_list (const GValue * list)
|
||||
{
|
||||
guint size = gst_value_list_get_size (value);
|
||||
return g_value_get_string (gst_value_list_get_value (value, size - 1));
|
||||
int i;
|
||||
const GValue *value;
|
||||
const gchar *aux;
|
||||
|
||||
guint size = gst_value_list_get_size (list);
|
||||
for (i = 0; i < size; i++) {
|
||||
value = gst_value_list_get_value (list, i);
|
||||
aux = g_value_get_string (value);
|
||||
if (strcmp ("stereo", aux) == 0) {
|
||||
return "stereo";
|
||||
}
|
||||
}
|
||||
return g_value_get_string (gst_value_list_get_value (list, size - 1));
|
||||
}
|
||||
|
||||
gint
|
||||
|
@ -168,6 +178,61 @@ gst_sbc_get_allocation_string (int alloc)
|
|||
}
|
||||
}
|
||||
|
||||
/* channel mode */
|
||||
#define SBC_CM_MONO 0x00
|
||||
#define SBC_CM_DUAL_CHANNEL 0x01
|
||||
#define SBC_CM_STEREO 0x02
|
||||
#define SBC_CM_JOINT_STEREO 0x03
|
||||
|
||||
/* allocation mode */
|
||||
#define SBC_AM_LOUDNESS 0x00
|
||||
#define SBC_AM_SNR 0x01
|
||||
|
||||
const gchar *
|
||||
gst_sbc_get_mode_string_from_sbc_t (int channels, int joint)
|
||||
{
|
||||
if (channels == 2 && joint == 1)
|
||||
return "joint";
|
||||
else if (channels == 2 && joint == 0)
|
||||
return "stereo";
|
||||
else
|
||||
return NULL;
|
||||
}
|
||||
|
||||
const gchar *
|
||||
gst_sbc_get_allocation_string_from_sbc_t (int alloc)
|
||||
{
|
||||
switch (alloc) {
|
||||
case SBC_AM_LOUDNESS:
|
||||
return "loudness";
|
||||
case SBC_AM_SNR:
|
||||
return "snr";
|
||||
default:
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
GstCaps *
|
||||
gst_sbc_parse_caps_from_sbc (sbc_t * sbc)
|
||||
{
|
||||
GstCaps *caps;
|
||||
const gchar *mode_str;
|
||||
const gchar *allocation_str;
|
||||
|
||||
mode_str = gst_sbc_get_mode_string_from_sbc_t (sbc->channels, sbc->joint);
|
||||
allocation_str = gst_sbc_get_allocation_string_from_sbc_t (sbc->allocation);
|
||||
caps = gst_caps_new_simple ("audio/x-sbc",
|
||||
"rate", G_TYPE_INT, sbc->rate,
|
||||
"channels", G_TYPE_INT, sbc->channels,
|
||||
"mode", G_TYPE_STRING, mode_str,
|
||||
"subbands", G_TYPE_INT, sbc->subbands,
|
||||
"blocks", G_TYPE_INT, sbc->blocks,
|
||||
"allocation", G_TYPE_STRING, allocation_str,
|
||||
"bitpool", G_TYPE_INT, sbc->bitpool, NULL);
|
||||
|
||||
return caps;
|
||||
}
|
||||
|
||||
GstCaps *
|
||||
gst_sbc_caps_from_sbc (sbc_capabilities_t * sbc, gint channels)
|
||||
{
|
||||
|
|
|
@ -47,6 +47,7 @@ gint gst_sbc_get_mode_int(const gchar *mode);
|
|||
const gchar *gst_sbc_get_mode_string(int joint);
|
||||
|
||||
GstCaps* gst_sbc_caps_from_sbc(sbc_capabilities_t *sbc, gint channels);
|
||||
GstCaps* gst_sbc_parse_caps_from_sbc(sbc_t *sbc);
|
||||
|
||||
GstCaps* gst_sbc_util_caps_fixate(GstCaps *caps, gchar** error_message);
|
||||
|
||||
|
|
Loading…
Reference in a new issue