![]() |
pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
|
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