de.sciss.synth.ugen.Control.scala Maven / Gradle / Ivy
/*
* Control.scala
* (ScalaCollider)
*
* Copyright (c) 2008-2013 Hanns Holger Rutz. All rights reserved.
*
* This software 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 2, june 1991 of the License, or (at your option) any later version.
*
* This software 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 (gpl.txt) along with this software; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*
* For further information, please contact Hanns Holger Rutz at
* [email protected]
*/
package de.sciss.synth
package ugen
import collection.immutable.{ IndexedSeq => IIdxSeq }
// ---------- Control ----------
object Control {
/**
* Note: we are not providing further convenience methods,
* as that is the task of ControlProxyFactory...
*/
def ir( values: IIdxSeq[ Float ], name: Option[ String ] = None ) = apply( scalar, values, name )
def kr( values: IIdxSeq[ Float ], name: Option[ String ] = None ) = apply( control, values, name )
def ir( values: Float* ) : Control = ir( IIdxSeq( values: _* ))
def kr( values: Float* ) : Control = kr( IIdxSeq( values: _* ))
// side-effect: receiving messages from clients!
// and more importantly: control ugens created from proxies are not wired, so they would
// be eliminated if side-effect was false!!!
final class UGen private[ugen]( rate: Rate, numChannels: Int, override val specialIndex: Int )
extends UGen.MultiOut( "Control", rate, IIdxSeq.fill( numChannels )( rate ), IIdxSeq.empty, false, true )
}
final case class Control( rate: Rate, values: IIdxSeq[ Float ], ctrlName: Option[ String ])
extends UGenSource.MultiOut( "Control" /*, values.size */) /* with IsControl */ {
//def numOutputs = values.size
protected def makeUGens : UGenInLike = makeUGen( IIdxSeq.empty )
protected def makeUGen( args: IIdxSeq[ UGenIn ]) : UGenInLike = {
val specialIndex = UGenGraph.builder.addControl( values, ctrlName )
new Control.UGen( rate, values.size, specialIndex )
}
}
final case class ControlProxy( rate: Rate, values: IIdxSeq[ Float ], name: Option[ String ])( val factory: ControlFactory )
extends AbstractControlProxy[ ControlProxy ] // IIdxSeq.fill( values.size )( rate )
final class ControlFactory( rate: Rate ) extends AbstractControlFactory[ ControlProxy ] {
protected def makeUGen( numChannels: Int, specialIndex: Int ) : UGen = new Control.UGen( rate, numChannels, specialIndex )
}
// ---------- TrigControl ----------
object TrigControl {
def kr( values: IIdxSeq[ Float ], name: Option[ String ] = None ) = TrigControl( values, name )
def kr( values: Float* ) : TrigControl = kr( IIdxSeq( values: _* ))
final class UGen private[ugen]( numChannels: Int, override val specialIndex: Int )
extends UGen.MultiOut( "TrigControl", control, IIdxSeq.fill( numChannels )( control ), IIdxSeq.empty, false, true )
}
final case class TrigControl( values: IIdxSeq[ Float ], ctrlName: Option[ String ])
extends UGenSource.MultiOut( "TrigControl" /*, values.size */) with ControlRated /* with IsControl */ {
//def numOutputs = values.size
protected def makeUGens : UGenInLike = makeUGen( IIdxSeq.empty )
protected def makeUGen( args: IIdxSeq[ UGenIn ]) : UGenInLike = {
val specialIndex = UGenGraph.builder.addControl( values, ctrlName )
new TrigControl.UGen( values.size, specialIndex )
}
}
final case class TrigControlProxy( values: IIdxSeq[ Float ], name: Option[ String ])
extends AbstractControlProxy[ TrigControlProxy ] /* ( IIdxSeq.fill( values.size )( control )) */ with ControlRated {
def factory = TrigControlFactory
}
object TrigControlFactory extends AbstractControlFactory[ TrigControlProxy ] {
protected def makeUGen( numChannels: Int, specialIndex: Int ) : UGen = new TrigControl.UGen( numChannels, specialIndex )
}
// ---------- AudioControl ----------
object AudioControl {
def ar( values: IIdxSeq[ Float ], name: Option[ String ] = None ) = AudioControl( values, name )
def ar( values: Float* ) : AudioControl = ar( IIdxSeq( values: _* ))
final class UGen private[ugen]( numChannels: Int, override val specialIndex: Int )
extends UGen.MultiOut( "AudioControl", audio, IIdxSeq.fill( numChannels )( audio ), IIdxSeq.empty, false, true )
}
final case class AudioControl( values: IIdxSeq[ Float ], ctrlName: Option[ String ])
extends UGenSource.MultiOut( "AudioControl" /*, values.size */) with AudioRated /* with IsControl */ {
//def numOutputs = values.size
protected def makeUGens : UGenInLike = makeUGen( IIdxSeq.empty )
protected def makeUGen( args: IIdxSeq[ UGenIn ]) : UGenInLike = {
val specialIndex = UGenGraph.builder.addControl( values, ctrlName )
new AudioControl.UGen( values.size, specialIndex )
}
}
final case class AudioControlProxy( values: IIdxSeq[ Float ], name: Option[ String ])
extends AbstractControlProxy[ AudioControlProxy ] /* ( IIdxSeq.fill( values.size )( audio )) */ with AudioRated {
def factory = AudioControlFactory
}
object AudioControlFactory extends AbstractControlFactory[ AudioControlProxy ] {
protected def makeUGen( numChannels: Int, specialIndex: Int ) : UGen = new AudioControl.UGen( numChannels, specialIndex )
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy