Nesploraw il-magna VoIP Mediastreamer2. Parti 5

Il-materjal tal-artiklu huwa meħud minn tiegħi kanal zen.

Detector tat-ton

Fl-aħħar artikolu Ħloqna arloġġ tal-livell tas-sinjal. F'dan wieħed se nitgħallmu kif niskopru sinjal tat-ton.

Nesploraw il-magna VoIP Mediastreamer2. Parti 5

Fl-antik, meta mhux kull familja kellha TV, u nofshom jaqilbu l-kanali bl-użu tat-tnalji, aħbarijiet intriganti dehru f'reviżjonijiet ta 'l-istampa teknika barranija li manifattur tat-TV wieħed arma t-tagħmir tagħhom b'kontroll remot mingħajr fili. Mid-dettalji kien magħruf li l-kontroll mill-bogħod operat mingħajr batteriji grazzi għall-użu ta 'approċċ mhux tas-soltu - il-kontroll mill-bogħod kien mekkaniku u kien ibridu ta' strument mużikali - metallophone u revolver. It-tanbur tar-revolver kien fih ċilindri tal-metall ta 'tulijiet differenti, u meta l-pern ta' l-isparar laqat wieħed minnhom, iċ-ċilindru beda jdoqq bil-frekwenza tiegħu stess. Preżumibbilment fuq ultrasound. L-elettronika fit-TV semgħet dan is-sinjal u, wara li ddeterminat il-frekwenza tagħha, wettqet l-azzjoni xierqa - aqleb il-kanal, ibiddel il-volum, itfi t-TV.

Illum se nippruvaw nibnu mill-ġdid din is-sistema ta 'trażmissjoni tal-kmand, billi nużaw l-għarfien tagħna tal-media streamer.

Biex tissimula kontroll mill-bogħod, se nużaw it-test tal-eżempju tal-ġeneratur tat-ton tagħna. Se nżidu magħha l-kontroll tal-frekwenza tal-ġeneratur minn keystrokes u riċevitur b'decoder li joħroġ kmandi riċevuti lill-console. Wara l-bidla, il-ġeneratur għandu jipproduċi tones ta '6 frekwenzi, li bihom se nikkodifikaw il-kmandi biex inżidu/nnaqqsu l-volum, ibiddlu l-kanal, ixgħel/itfi t-TV. Biex jiġi kkonfigurat id-ditekter, tintuża l-istruttura li ġejja:

struct _MSToneDetectorDef{  
     char tone_name[8];     
     int frequency; /**<Expected frequency of the tone*/ 
     int min_duration; /**<Min duration of the tone in milliseconds */ 
     float min_amplitude; /**<Minimum amplitude of the tone, 1.0 corresponding to the normalized 0dbm level */
};

typedef struct _MSToneDetectorDef MSToneDetectorDef;

Detector jista 'jingħata 10 minn dawn l-istrutturi, għalhekk detector wieħed jista' jiġi kkonfigurat biex jiskopri għaxar sinjali b'żewġ kuluri. Imma se nużaw biss sitt sinjali b'ton wieħed. Biex tittrasferixxi s-settings lid-ditekter, jintuża l-metodu MS_TONE_DETECTOR_ADD_SCAN.

Sabiex id-ditekter jinnotifikana li sinjal bil-komponenti tal-frekwenza mixtieqa wasal fl-input tiegħu, irridu nipprovdulu b'funzjoni ta 'callback li se tniedi f'dan il-każ. Dan isir bl-użu tal-funzjoni ms_filter_set_notify_callback (). Bħala argumenti, jirċievi pointer għall-filtru, pointer għall-funzjoni callback, u pointer għad-dejta li nixtiequ ngħaddu lill-funzjoni callback (data tal-utent).

Meta d-ditekter jiġi attivat, il-funzjoni ta' callback tirċievi dejta tal-utent, pointer għall-filtru tad-ditekter, identifikatur tal-avveniment, u struttura li tiddeskrivi l-avveniment:


/** * Structure carried as argument of the MS_TONE_DETECTOR_EVENT**/
struct _MSToneDetectorEvent{ 
      char tone_name[8];       /* Имя тона которое мы ему назначили при настройке детектора. */
      uint64_t tone_start_time;   /* Время в миллисекундах, когда тон был обнаружен. */
};

typedef struct _MSToneDetectorEvent MSToneDetectorEvent;

Id-dijagramma blokka tal-ipproċessar tas-sinjali tidher fl-istampa tat-titlu.

Ukoll, issa l-kodiċi tal-programm innifsu bil-kummenti.

/* Файл mstest4.c Имитатор пульта управления и приемника. */
#include <mediastreamer2/msfilter.h>
#include <mediastreamer2/msticker.h>
#include <mediastreamer2/dtmfgen.h>
#include <mediastreamer2/mssndcard.h>
#include <mediastreamer2/msvolume.h>
#include <mediastreamer2/mstonedetector.h>

/* Подключаем заголовочный файл с функциями управления событиями
 * медиастримера. */
#include <mediastreamer2/mseventqueue.h>

/* Функция обратного вызова, она будет вызвана фильтром, как только он
 * обнаружит совпадение характеристик входного сигнала с заданными. */
static void tone_detected_cb(void *data, MSFilter *f, unsigned int event_id,
        MSToneDetectorEvent *ev)
{
    printf("                      Принята команда: %sn", ev->tone_name);
}

int main()
{
    ms_init();

    /* Создаем экземпляры фильтров. */
    MSFilter  *voidsource = ms_filter_new(MS_VOID_SOURCE_ID);
    MSFilter  *dtmfgen = ms_filter_new(MS_DTMF_GEN_ID);
    MSFilter  *volume = ms_filter_new(MS_VOLUME_ID);
    MSSndCard *card_playback =
        ms_snd_card_manager_get_default_card(ms_snd_card_manager_get());
    MSFilter  *snd_card_write = ms_snd_card_create_writer(card_playback);
    MSFilter  *detector = ms_filter_new(MS_TONE_DETECTOR_ID);

    /* Очищаем массив находящийся внутри детектора тонов, он описывает
     * особые приметы разыскиваемых сигналов.*/
    ms_filter_call_method(detector, MS_TONE_DETECTOR_CLEAR_SCANS, 0);

    /* Создаем источник тактов - тикер. */
    MSTicker *ticker=ms_ticker_new();

    /* Соединяем фильтры в цепочку. */
    ms_filter_link(voidsource, 0, dtmfgen, 0);
    ms_filter_link(dtmfgen, 0, volume, 0);
    ms_filter_link(volume, 0, detector, 0);
    ms_filter_link(detector, 0, snd_card_write, 0);

    /* Подключаем к фильтру функцию обратного вызова. */
    ms_filter_set_notify_callback(detector,
            (MSFilterNotifyFunc)tone_detected_cb, NULL);

    /* Подключаем источник тактов. */
    ms_ticker_attach(ticker,voidsource);

    /* Создаем массив, каждый элемент которого описывает характеристику
     * одного из тонов, который требуется обнаруживать: Текстовое имя
     * данного элемента, частота в герцах, длительность в миллисекундах,
     * минимальный уровень относительно 0,775В. */  
    MSToneDetectorDef  scan[6]=
    {
        {"V+",  440, 100, 0.1}, /* Команда "Увеличить громкость". */
        {"V-",  540, 100, 0.1}, /* Команда "Уменьшить громкость". */
        {"C+",  640, 100, 0.1}, /* Команда "Увеличить номер канала". */
        {"C-",  740, 100, 0.1}, /* Команда "Уменьшить номер канала". */
        {"ON",  840, 100, 0.1}, /* Команда "Включить телевизор". */
        {"OFF", 940, 100, 0.1}  /* Команда "Выключить телевизор". */
    };

    /* Передаем в детектор тонов приметы сигналов. */
    int i;
    for (i = 0; i < 6; i++)
    {
        ms_filter_call_method(detector, MS_TONE_DETECTOR_ADD_SCAN,
                &scan[i]);
    }

    /* Настраиваем структуру, управляющую выходным сигналом генератора.*/
    MSDtmfGenCustomTone dtmf_cfg;
    dtmf_cfg.tone_name[0] = 0;
    dtmf_cfg.duration = 1000;
    dtmf_cfg.frequencies[0] = 440;
    /* Будем генерировать один тон, частоту второго тона установим в 0.*/
    dtmf_cfg.frequencies[1] = 0;
    dtmf_cfg.amplitude = 1.0;
    dtmf_cfg.interval = 0.;
    dtmf_cfg.repeat_count = 0.;

    /* Организуем цикл сканирования нажатых клавиш. Ввод нуля завершает
     * цикл и работу программы. */
    char key='9';
    printf("Нажмите клавишу команды, затем ввод.n"
        "Для завершения программы введите 0.n");
    while(key != '0')
    {
        key = getchar();
        if ((key >= 49) && (key <= 54))
        {
                printf("Отправлена команда: %cn", key);
            /* Устанавливаем частоту генератора в соответствии с
             * кодом нажатой клавиши.*/
            dtmf_cfg.frequencies[0] = 440 + 100*(key-49);

            /* Включаем звуковой генератор c обновленной частотой. */
            ms_filter_call_method(dtmfgen, MS_DTMF_GEN_PLAY_CUSTOM,
                    (void*)&dtmf_cfg);
        }
        ms_usleep(20000);
    }
}

Aħna niġbru u nħaddmu l-programm. Jekk kollox jaħdem sew, imbagħad wara t-tnedija għandna nġibu xi ħaġa bħal din l-imġieba tal-programm:

$ ./mstest4
ALSA lib conf.c:4738:(snd_config_expand) Unknown parameters 0
ALSA lib control.c:954:(snd_ctl_open_noupdate) Invalid CTL default:0
ortp-warning-Could not attach mixer to card: Invalid argument
ALSA lib conf.c:4738:(snd_config_expand) Unknown parameters 0
ALSA lib pcm.c:2266:(snd_pcm_open_noupdate) Unknown PCM default:0
ALSA lib conf.c:4738:(snd_config_expand) Unknown parameters 0
ALSA lib pcm.c:2266:(snd_pcm_open_noupdate) Unknown PCM default:0
ortp-warning-Strange, sound card Intel 82801AA-ICH does not seems to be capable of anything, retrying with plughw...
Нажмите клавишу команды, затем ввод.
Для завершения программы введите 0.
ortp-warning-alsa_set_params: periodsize:256 Using 256
ortp-warning-alsa_set_params: period:8 Using 8

Agħfas kwalunkwe tasti minn "1" sa "6", u tikkonferma bit-tasti "Enter", għandek tikseb xi ħaġa bħal din il-lista:


2
Отправлена команда: 2
                      Принята команда: V-
1
Отправлена команда: 1
                      Принята команда: V+
3
Отправлена команда: 3
                      Принята команда: C+
4
Отправлена команда: 4
                      Принята команда: C-
0
$

Naraw li t-tonijiet tal-kmand jintbagħtu b'suċċess u d-ditekter jiskoprihom.

Fl-artiklu li jmiss se ngħaddu għat-trażmissjoni ta 'sinjal awdjo fuq netwerk Ethernet bl-użu tal-protokoll RTP u immedjatament napplikawh fil-kontroll remot tagħna.

Sors: www.habr.com

Żid kumment