Mercurial > hg > opencollidoscope
view CollidoscopeApp/include/Config.h @ 5:75b744078d66
added license
author | Fiore Martin <f.martin@qmul.ac.uk> |
---|---|
date | Wed, 13 Jul 2016 16:06:46 +0200 |
parents | dd889fff8423 |
children | 4dad0b810f18 |
line wrap: on
line source
/* Copyright (C) 2016 Queen Mary University of London Author: Fiore Martin This file is part of Collidoscope. Collidoscope is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #pragma once #include <string> #include <array> #include "cinder/Color.h" #include "cinder/Xml.h" /** * Configuration class gathers in one place all the values recided at runtime * * Reading the configuration from an XML file is partially implemented but not used at the moment * */ class Config { public: Config(); // no copies Config( const Config © ) = delete; Config & operator=(const Config ©) = delete; /* load values for internal field from configuration file. Throws ci::Exception */ void loadFromFile( std::string&& path ); std::string getInputDeviceKey() const { return mAudioInputDeviceKey; } /** * Returns number of chunks in a wave */ std::size_t getNumChunks() const { return mNumChunks; } /** returns wave lenght in seconds */ double getWaveLen() const { return mWaveLen; } /** * Returns wave's selection color */ ci::Color getWaveSelectionColor(size_t waveIdx) const { if (waveIdx == 0){ return cinder::Color(243.0f / 255.0f, 6.0f / 255.0f, 62.0f / 255.0f); } else{ return cinder::Color(255.0f / 255.0f, 204.0f / 255.0f, 0.0f / 255.0f); } } /** * The size of the ring buffer used to trigger a visual cursor from the audio thread when a new grain is created */ std::size_t getCursorTriggerMessageBufSize() const { return 512; } /** returns the index of the wave associated to the MIDI channel passed as argument */ size_t getWaveForMIDIChannel( unsigned char channelIdx ) { return channelIdx; } double getMaxGrainDurationCoeff() const { return 8.0; } double getMaxFilterCutoffFreq() const { return 22050.; } double getMinFilterCutoffFreq() const { return 200.; } size_t getMaxKeyboardVoices() const { return 6; } /** * Returns the maximum size of a wave selection in number of chunks. */ size_t getMaxSelectionNumChunks() const { return 37; } /** * The value returned is used when creating the oscilloscope. * The oscilloscope represents the audio output buffer graphically. However it doesn't need to be as refined as the * audio wave and it's downsampled using the following formula : number of oscilloscope points = size o audio output buffer / getOscilloscopeNumPointsDivider() */ size_t getOscilloscopeNumPointsDivider() const { return 4; } private: void parseWave( const ci::XmlTree &wave, int id ); std::string mAudioInputDeviceKey; std::size_t mNumChunks; double mWaveLen; std::array< size_t, NUM_WAVES > mMidiChannels; };