120 lines
3.6 KiB
C++
Raw Normal View History

/** @file
* @author Edouard DUPIN
* @copyright 2015, Edouard DUPIN, all right reserved
* @license MPL v2.0 (see license file)
*/
//! [audio_river_sample_write_all]
2016-10-02 22:19:26 +02:00
#include <audio/river/river.hpp>
#include <audio/river/Manager.hpp>
#include <audio/river/Interface.hpp>
#include <etk/etk.hpp>
2017-09-07 23:38:26 +02:00
#include <ethread/Thread.hpp>
2017-11-07 13:38:04 +01:00
#include <ethread/tools.hpp>
#include <test-debug/debug.hpp>
2016-10-13 21:29:18 +02:00
//! [audio_river_sample_write_config_file]
2017-08-28 00:08:50 +02:00
static const etk::String configurationRiver =
"{\n"
" speaker:{\n"
" io:'output',\n"
" map-on:{\n"
2016-04-20 21:19:11 +02:00
" interface:'alsa',\n"
2017-04-26 22:09:23 +00:00
" name:'hw:0,3',\n"
" },\n"
" frequency:48000,\n"
2016-04-20 21:19:11 +02:00
//" channel-map:['front-left', 'front-right', 'rear-left', 'rear-right'],\n"
" channel-map:['front-left', 'front-right'],\n"
" type:'int16',\n"
" nb-chunk:1024,\n"
" volume-name:'MASTER'\n"
" }\n"
"}\n";
//! [audio_river_sample_write_config_file]
2016-04-20 21:19:11 +02:00
static const int32_t nbChannelMax=8;
//! [audio_river_sample_callback_implement]
void onDataNeeded(void* _data,
2015-05-08 22:36:02 +02:00
const audio::Time& _time,
size_t _nbChunk,
enum audio::format _format,
uint32_t _sampleRate,
2017-08-28 00:08:50 +02:00
const etk::Vector<audio::channel>& _map) {
2016-04-20 21:19:11 +02:00
static double phase[8] = {0,0,0,0,0,0,0,0};
if (_format != audio::format_int16) {
2017-09-26 15:57:44 +02:00
TEST_ERROR("Call wrong type ... (need int16_t)");
}
2017-09-26 15:57:44 +02:00
//TEST_VERBOSE("Map " << _map);
int16_t* data = static_cast<int16_t*>(_data);
2016-04-20 21:19:11 +02:00
double baseCycle = 2.0*M_PI/double(48000) * double(440);
for (int32_t iii=0; iii<_nbChunk; iii++) {
for (int32_t jjj=0; jjj<_map.size(); jjj++) {
2016-04-20 21:19:11 +02:00
data[_map.size()*iii+jjj] = cos(phase[jjj]) * 30000;
phase[jjj] += baseCycle*jjj;
if (phase[jjj] >= 2*M_PI) {
phase[jjj] -= 2*M_PI;
}
}
}
}
//! [audio_river_sample_callback_implement]
2015-05-08 22:36:02 +02:00
int main(int _argc, const char **_argv) {
// the only one init for etk:
etk::init(_argc, _argv);
for (int32_t iii=0; iii<_argc ; ++iii) {
2017-08-28 00:08:50 +02:00
etk::String data = _argv[iii];
if ( data == "-h"
|| data == "--help") {
2017-09-26 15:57:44 +02:00
TEST_PRINT("Help:");
TEST_PRINT(" ./xxx ---");
exit(0);
}
}
// initialize river interface
2015-05-08 22:36:02 +02:00
audio::river::initString(configurationRiver);
// Create the River manager for tha application or part of the application.
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<audio::river::Manager> manager = audio::river::Manager::create("river_sample_read");
//! [audio_river_sample_create_write_interface]
// create interface:
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<audio::river::Interface> interface;
//Get the generic input:
interface = manager->createOutput(48000,
2017-08-28 00:08:50 +02:00
etk::Vector<audio::channel>(),
audio::format_int16,
"speaker");
if(interface == nullptr) {
2017-09-26 15:57:44 +02:00
TEST_ERROR("nullptr interface");
return -1;
}
//! [audio_river_sample_create_write_interface]
//! [audio_river_sample_set_callback]
// set callback mode ...
2017-11-07 13:38:04 +01:00
interface->setOutputCallback([=](void* _data,
2017-09-26 15:57:44 +02:00
const audio::Time& _time,
size_t _nbChunk,
enum audio::format _format,
uint32_t _frequency,
const etk::Vector<audio::channel>& _map) {
onDataNeeded(_data, _time, _nbChunk, _format, _frequency, _map);
});
//! [audio_river_sample_set_callback]
// start the stream
interface->start();
// wait 10 second ...
2017-09-26 15:57:44 +02:00
ethread::sleepMilliSeconds(1000*(10));
// stop the stream
interface->stop();
// remove interface and manager.
interface.reset();
manager.reset();
return 0;
}
//! [audio_river_sample_write_all]