pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
plonk_ShapeVariable.h
00001 /*
00002  -------------------------------------------------------------------------------
00003  This file is part of the Plink, Plonk, Plank libraries
00004   by Martin Robinson
00005  
00006  http://code.google.com/p/pl-nk/
00007  
00008  Copyright University of the West of England, Bristol 2011-14
00009  All rights reserved.
00010  
00011  Redistribution and use in source and binary forms, with or without
00012  modification, are permitted provided that the following conditions are met:
00013  
00014  * Redistributions of source code must retain the above copyright
00015    notice, this list of conditions and the following disclaimer.
00016  * Redistributions in binary form must reproduce the above copyright
00017    notice, this list of conditions and the following disclaimer in the
00018    documentation and/or other materials provided with the distribution.
00019  * Neither the name of University of the West of England, Bristol nor 
00020    the names of its contributors may be used to endorse or promote products
00021    derived from this software without specific prior written permission.
00022  
00023  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00024  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00025  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00026  DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF THE WEST OF ENGLAND, BRISTOL BE 
00027  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
00028  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 
00029  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 
00030  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
00031  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 
00032  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00033  
00034  This software makes use of third party libraries. For more information see:
00035  doc/license.txt included in the distribution.
00036  -------------------------------------------------------------------------------
00037  */
00038 
00039 #ifndef PLONK_SHAPEVARIABLE_H
00040 #define PLONK_SHAPEVARIABLE_H
00041 
00042 #include "plonk_VariableInternal.h"
00043 
00044 
00045 template<class Type>
00046 class ShapeVariableInternal : public VariableInternalBase<Type>
00047 {
00048 public:
00049     typedef Variable<Type>                 VariableType;
00050     typedef IntVariable                    StepsVariable;
00051     typedef Variable<Shape::ShapeType>     ShapeTypeVariable;
00052     typedef FloatVariable                  CurveVariable;
00053 
00054     ShapeVariableInternal (VariableType const& inputToUse,
00055                            StepsVariable const& numStepsToUse,
00056                            ShapeTypeVariable const& shapeToUse,
00057                            CurveVariable const& curveToUse) throw()
00058     :   input (inputToUse),
00059         numSteps (numStepsToUse),
00060         shape (shapeToUse),
00061         curve (curveToUse)
00062     {
00063         Memory::zero (shapeState);
00064         shapeState.stepsToTarget = TypeUtility<LongLong>::getTypePeak();
00065         shapeState.targetLevel = shapeState.currentLevel = input.getValue();
00066     }
00067     
00068     ~ShapeVariableInternal()
00069     {
00070     }
00071         
00072     const Type getValue() const throw()
00073     {
00074         return shapeState.currentLevel;
00075     }
00076     
00077     Type* getValuePtr() throw()
00078     {
00079         return &shapeState.currentLevel;
00080     }
00081     
00082     const Type nextValue() throw()
00083     {
00084         const Type nextValue = input.nextValue();
00085         
00086         if (nextValue != shapeState.targetLevel)
00087         {
00088             shapeState.targetLevel = nextValue;
00089             shapeState.shapeType = shape.nextValue();
00090             shapeState.curve = (shapeState.shapeType == Shape::Numerical) ? curve.nextValue() : 0.f;
00091             shapeState.stepsToTarget = plonk::max (1, numSteps.nextValue());
00092             Shape::initShape (shapeState);
00093         }
00094         
00095         const Type result = Shape::next (shapeState);
00096         
00097         if (shapeState.stepsToTarget == TypeUtility<LongLong>::getTypePeak())
00098             this->update (Text::getEmpty(), Dynamic::getNull());
00099             
00100         return result;
00101     }
00102     
00103     void setValue(Type const& newValue) throw()
00104     {
00105         plonk_assertfalse;
00106     }
00107     
00108 private:
00109     VariableType input;
00110     StepsVariable numSteps;
00111     ShapeTypeVariable shape;
00112     CurveVariable curve;
00113     ShapeState<Type> shapeState;
00114 };
00115 
00116 #endif // PLONK_SHAPEVARIABLE_H
 All Classes Functions Typedefs Enumerations Enumerator Properties