Blender V2.61 - r43446
|
00001 /* 00002 * ***** BEGIN GPL LICENSE BLOCK ***** 00003 * 00004 * Copyright 2009-2011 Jörg Hermann Müller 00005 * 00006 * This file is part of AudaSpace. 00007 * 00008 * Audaspace is free software; you can redistribute it and/or modify 00009 * it under the terms of the GNU General Public License as published by 00010 * the Free Software Foundation; either version 2 of the License, or 00011 * (at your option) any later version. 00012 * 00013 * AudaSpace is distributed in the hope that it will be useful, 00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 * GNU General Public License for more details. 00017 * 00018 * You should have received a copy of the GNU General Public License 00019 * along with Audaspace; if not, write to the Free Software Foundation, 00020 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 00021 * 00022 * ***** END GPL LICENSE BLOCK ***** 00023 */ 00024 00030 #include "AUD_SquareFactory.h" 00031 #include "AUD_CallbackIIRFilterReader.h" 00032 00033 sample_t AUD_SquareFactory::squareFilter(AUD_CallbackIIRFilterReader* reader, float* threshold) 00034 { 00035 float in = reader->x(0); 00036 if(in >= *threshold) 00037 return 1; 00038 else if(in <= -*threshold) 00039 return -1; 00040 else 00041 return 0; 00042 } 00043 00044 void AUD_SquareFactory::endSquareFilter(float* threshold) 00045 { 00046 delete threshold; 00047 } 00048 00049 AUD_SquareFactory::AUD_SquareFactory(AUD_Reference<AUD_IFactory> factory, float threshold) : 00050 AUD_EffectFactory(factory), 00051 m_threshold(threshold) 00052 { 00053 } 00054 00055 float AUD_SquareFactory::getThreshold() const 00056 { 00057 return m_threshold; 00058 } 00059 00060 AUD_Reference<AUD_IReader> AUD_SquareFactory::createReader() 00061 { 00062 return new AUD_CallbackIIRFilterReader(getReader(), 1, 1, 00063 (doFilterIIR) squareFilter, 00064 (endFilterIIR) endSquareFilter, 00065 new float(m_threshold)); 00066 }