Форум программистов, компьютерный форум, киберфорум
Наши страницы

Запись звука в Windows - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Массив, сделать вывод его на экран http://www.cyberforum.ru/cpp-beginners/thread851075.html
я хочу сделать функцию, которая выодит на экран все элементы массива, а там, где я ничего не вводила, чтобы писало "Пустота" моя структура struct Tichet{ int number; char station_otprav;...
C++ начал изучать C++ и MS Visual C++ 2012 выдает синтаксические ошибки начал изучать c++ и MS Visual C++ 2012, но столкнулся с проблемой. текст программы: // ConsoleApplication1.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h"... http://www.cyberforum.ru/cpp-beginners/thread851037.html
C++ Графика: вращательное движение относительно центра экрана
Здравствуйте! Нужна помощь в дописании программы. Вот само задание: Вариант 3. Для реализации вращательного движения относительно центра экрана удобно использовать полярную систему координат. Для...
рекурсия C++
#include <iostream> #include <windows.h> using namespace std; void someFunction ( int , int, int ); int main () { const int arraySize = 10;
C++ Поменять первый элемент строки с максимальным элементом этой строки http://www.cyberforum.ru/cpp-beginners/thread850992.html
Условие: поменять максимальный элемент строки с первым элемент строки матрицы... Вообщем ,как я понимаю,я нахожу максимальный элемент каждой строки,затем переменной присваиваю первый элемент...
C++ Отличие функции cin.get и cin.getline Добрый день! Изучаю функции get и getline, сказано, что они отличаются тем, что функция get считывает символ разрыва строк и оставляет его в буфере, а функция getline считывает, а затем удаляет его... подробнее

Показать сообщение отдельно
IPavel
9 / 9 / 0
Регистрация: 14.01.2013
Сообщений: 102

Запись звука в Windows - C++

28.04.2013, 17:16. Просмотров 969. Ответов 4
Метки (Все метки)

Всем привет!
Помогите разобраться с записью звука.
Есть такой примерчик, добросовестно спёртый с msdn.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
const IID IID_IAudioCaptureClient = __uuidof(IAudioCaptureClient);
 
HRESULT RecordAudioStream(MyAudioSink *pMySink)
{
    HRESULT hr;
    REFERENCE_TIME hnsRequestedDuration = REFTIMES_PER_SEC;
    REFERENCE_TIME hnsActualDuration;
    UINT32 bufferFrameCount;
    UINT32 numFramesAvailable;
    IMMDeviceEnumerator *pEnumerator = NULL;
    IMMDevice *pDevice = NULL;
    IAudioClient *pAudioClient = NULL;
    IAudioCaptureClient *pCaptureClient = NULL;
    WAVEFORMATEX *pwfx = NULL;
    UINT32 packetLength = 0;
    BOOL bDone = FALSE;
    BYTE *pData;
    DWORD flags;
 
    hr = CoCreateInstance(
           CLSID_MMDeviceEnumerator, NULL,
           CLSCTX_ALL, IID_IMMDeviceEnumerator,
           (void**)&pEnumerator);
    EXIT_ON_ERROR(hr)
 
    hr = pEnumerator->GetDefaultAudioEndpoint(
                        eCapture, eConsole, &pDevice);
    EXIT_ON_ERROR(hr)
 
    hr = pDevice->Activate(
                    IID_IAudioClient, CLSCTX_ALL,
                    NULL, (void**)&pAudioClient);
    EXIT_ON_ERROR(hr)
 
    hr = pAudioClient->GetMixFormat(&pwfx);
    EXIT_ON_ERROR(hr)
 
    hr = pAudioClient->Initialize(
                         AUDCLNT_SHAREMODE_SHARED,
                         0,
                         hnsRequestedDuration,
                         0,
                         pwfx,
                         NULL);
    EXIT_ON_ERROR(hr)
 
    // Get the size of the allocated buffer.
    hr = pAudioClient->GetBufferSize(&bufferFrameCount);
    EXIT_ON_ERROR(hr)
 
    hr = pAudioClient->GetService(
                         IID_IAudioCaptureClient,
                         (void**)&pCaptureClient);
    EXIT_ON_ERROR(hr)
 
    // Notify the audio sink which format to use.
    hr = pMySink->SetFormat(pwfx);
    EXIT_ON_ERROR(hr)
 
    // Calculate the actual duration of the allocated buffer.
    hnsActualDuration = (double)REFTIMES_PER_SEC *
                     bufferFrameCount / pwfx->nSamplesPerSec;
 
    hr = pAudioClient->Start();  // Start recording.
    EXIT_ON_ERROR(hr)
 
    // Each loop fills about half of the shared buffer.
    while (bDone == FALSE)
    {
        // Sleep for half the buffer duration.
        Sleep(hnsActualDuration/REFTIMES_PER_MILLISEC/2);
 
        hr = pCaptureClient->GetNextPacketSize(&packetLength);
        EXIT_ON_ERROR(hr)
 
        while (packetLength != 0)
        {
            // Get the available data in the shared buffer.
            hr = pCaptureClient->GetBuffer(
                                   &pData,
                                   &numFramesAvailable,
                                   &flags, NULL, NULL);
            EXIT_ON_ERROR(hr)
 
            if (flags & AUDCLNT_BUFFERFLAGS_SILENT)
            {
                pData = NULL;  // Tell CopyData to write silence.
            }
 
            // Copy the available capture data to the audio sink.
            hr = pMySink->CopyData(
                              pData, numFramesAvailable, &bDone);
            EXIT_ON_ERROR(hr)
 
            hr = pCaptureClient->ReleaseBuffer(numFramesAvailable);
            EXIT_ON_ERROR(hr)
 
            hr = pCaptureClient->GetNextPacketSize(&packetLength);
            EXIT_ON_ERROR(hr)
        }
    }
 
    hr = pAudioClient->Stop();  // Stop recording.
    EXIT_ON_ERROR(hr)
 
Exit:
    CoTaskMemFree(pwfx);
    SAFE_RELEASE(pEnumerator)
    SAFE_RELEASE(pDevice)
    SAFE_RELEASE(pAudioClient)
    SAFE_RELEASE(pCaptureClient)
 
    return hr;
}
И всё бы ничего разобраться я в нём разобрался...
Но возникла такая трудность...
В примере используеться две функции из пользовательского класса...
Т.е. класс этот надо написать самому чтобы пример заработал.
И вот тут я застрял.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
class MyAudioSink:
{
public:
CopyData( BYTE *pData, UINT32 numFramesAvailable, bool &bDone);
// эта функция должна копировать принятые значения для дальнейшего испльзования.
SetFormat( WAVEFORMATEX *pwfx);
// Эта функция принимает структуру с заполненым форматом и сохраняет себе.
...
//остальной код класса.
...
};
Ну собственно проблема с первой функцией.
Допустим я определю структуру.
struct DataBase: {
BYTE *pData;
UINT32 Frames;
};
И в функции буду писать принятые значения в структуру выделяя память.
DataBase *pDB = new DataBase;
Присваение значений...
И потом ложить это в вектор.
И вот тут сложность после оканчания записи
нужно будет извлечь по порядку все структуры и склеить BYTE в один буфер.
А вот как склеивать этот тип ума не преложу...
Он обьявлен в WinAPI как unside char .
strcat() не катит вылазеет ошибка...
Оно и понятно просто у обычного char может просто не хватить диапазона.
Подскажите как можно склеить этот BYTE???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru