@@ -74,6 +74,7 @@ endif | |||||
# DISTRHO plugins (Juice) | # DISTRHO plugins (Juice) | ||||
OBJS += \ | OBJS += \ | ||||
$(OBJDIR)/distrho-vectorjuice.cpp.o \ | |||||
$(OBJDIR)/distrho-wobblejuice.cpp.o | $(OBJDIR)/distrho-wobblejuice.cpp.o | ||||
# ---------------------------------------------------------------------------------------------------------------------------- | # ---------------------------------------------------------------------------------------------------------------------------- | ||||
@@ -215,6 +216,11 @@ $(OBJDIR)/distrho-prom.cpp.o: distrho-prom.cpp | |||||
# ---------------------------------------------------------------------------------------------------------------------------- | # ---------------------------------------------------------------------------------------------------------------------------- | ||||
$(OBJDIR)/distrho-vectorjuice.cpp.o: distrho-vectorjuice.cpp | |||||
-@mkdir -p $(OBJDIR) | |||||
@echo "Compiling $<" | |||||
@$(CXX) $< $(BUILD_CXX_FLAGS) -DDISTRHO_NAMESPACE=DISTRHO_VectorJuice -Idistrho-vectorjuice -I$(CWD)/modules/dgl -Wno-effc++ -c -o $@ | |||||
$(OBJDIR)/distrho-wobblejuice.cpp.o: distrho-wobblejuice.cpp | $(OBJDIR)/distrho-wobblejuice.cpp.o: distrho-wobblejuice.cpp | ||||
-@mkdir -p $(OBJDIR) | -@mkdir -p $(OBJDIR) | ||||
@echo "Compiling $<" | @echo "Compiling $<" | ||||
@@ -48,6 +48,7 @@ extern void carla_register_native_plugin_distrho_pingpongpan(void); | |||||
extern void carla_register_native_plugin_distrho_prom(void); | extern void carla_register_native_plugin_distrho_prom(void); | ||||
// DISTRHO plugins (Juice) | // DISTRHO plugins (Juice) | ||||
extern void carla_register_native_plugin_distrho_vectorjuice(void); | |||||
extern void carla_register_native_plugin_distrho_wobblejuice(void); | extern void carla_register_native_plugin_distrho_wobblejuice(void); | ||||
// External-UI plugins | // External-UI plugins | ||||
@@ -103,6 +104,7 @@ void carla_register_all_native_plugins(void) | |||||
#endif | #endif | ||||
// DISTRHO plugins (Juice) | // DISTRHO plugins (Juice) | ||||
carla_register_native_plugin_distrho_vectorjuice(); | |||||
carla_register_native_plugin_distrho_wobblejuice(); | carla_register_native_plugin_distrho_wobblejuice(); | ||||
#ifndef CARLA_OS_WIN | #ifndef CARLA_OS_WIN | ||||
@@ -499,6 +499,31 @@ static const NativePluginDescriptor sNativePluginDescriptors[] = { | |||||
/* copyright */ "GPL v2+", | /* copyright */ "GPL v2+", | ||||
DESCFUNCS | DESCFUNCS | ||||
}, | }, | ||||
{ | |||||
/* category */ NATIVE_PLUGIN_CATEGORY_UTILITY, | |||||
#ifdef HAVE_DGL | |||||
/* hints */ static_cast<NativePluginHints>(NATIVE_PLUGIN_IS_RTSAFE | |||||
|NATIVE_PLUGIN_HAS_UI | |||||
|NATIVE_PLUGIN_NEEDS_UI_MAIN_THREAD | |||||
|NATIVE_PLUGIN_USES_PARENT_ID | |||||
|NATIVE_PLUGIN_USES_TIME), | |||||
#else | |||||
/* hints */ static_cast<NativePluginHints>(NATIVE_PLUGIN_IS_RTSAFE | |||||
|NATIVE_PLUGIN_USES_TIME), | |||||
#endif | |||||
/* supports */ static_cast<NativePluginSupports>(0x0), | |||||
/* audioIns */ 8, | |||||
/* audioOuts */ 2, | |||||
/* midiIns */ 0, | |||||
/* midiOuts */ 0, | |||||
/* paramIns */ 13, | |||||
/* paramOuts */ 4, | |||||
/* name */ "VectorJuice", | |||||
/* label */ "vectorjuice", | |||||
/* maker */ "Andre Sklenar", | |||||
/* copyright */ "GPL v2+", | |||||
DESCFUNCS | |||||
}, | |||||
// ----------------------------------------------------------------------- | // ----------------------------------------------------------------------- | ||||
// External-UI plugins | // External-UI plugins | ||||
@@ -0,0 +1,84 @@ | |||||
/* | |||||
* Carla Native Plugins | |||||
* Copyright (C) 2012-2015 Filipe Coelho <falktx@falktx.com> | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
// config fix | |||||
#include "distrho-vectorjuice/DistrhoPluginInfo.h" | |||||
#if DISTRHO_PLUGIN_HAS_UI && ! defined(HAVE_DGL) | |||||
# undef DISTRHO_PLUGIN_HAS_UI | |||||
# define DISTRHO_PLUGIN_HAS_UI 0 | |||||
#endif | |||||
// Plugin Code | |||||
#include "distrho-vectorjuice/VectorJuicePlugin.cpp" | |||||
#ifdef HAVE_DGL | |||||
#include "distrho-vectorjuice/VectorJuiceArtwork.cpp" | |||||
#include "distrho-vectorjuice/VectorJuiceUI.cpp" | |||||
#endif | |||||
// DISTRHO Code | |||||
#define DISTRHO_PLUGIN_TARGET_CARLA | |||||
#include "DistrhoPluginMain.cpp" | |||||
#ifdef HAVE_DGL | |||||
#include "DistrhoUIMain.cpp" | |||||
#endif | |||||
START_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
static const NativePluginDescriptor vectorjuiceDesc = { | |||||
/* category */ NATIVE_PLUGIN_CATEGORY_UTILITY, | |||||
#ifdef HAVE_DGL | |||||
/* hints */ static_cast<NativePluginHints>(NATIVE_PLUGIN_IS_RTSAFE | |||||
|NATIVE_PLUGIN_HAS_UI | |||||
|NATIVE_PLUGIN_NEEDS_UI_MAIN_THREAD | |||||
|NATIVE_PLUGIN_USES_PARENT_ID | |||||
|NATIVE_PLUGIN_USES_TIME), | |||||
#else | |||||
/* hints */ static_cast<NativePluginHints>(NATIVE_PLUGIN_IS_RTSAFE | |||||
|NATIVE_PLUGIN_USES_TIME), | |||||
#endif | |||||
/* supports */ static_cast<NativePluginSupports>(0x0), | |||||
/* audioIns */ DISTRHO_PLUGIN_NUM_INPUTS, | |||||
/* audioOuts */ DISTRHO_PLUGIN_NUM_OUTPUTS, | |||||
/* midiIns */ 0, | |||||
/* midiOuts */ 0, | |||||
/* paramIns */ 13, | |||||
/* paramOuts */ 4, | |||||
/* name */ DISTRHO_PLUGIN_NAME, | |||||
/* label */ "vectorjuice", | |||||
/* maker */ "Andre Sklenar", | |||||
/* copyright */ "GPL v2+", | |||||
PluginDescriptorFILL(PluginCarla) | |||||
}; | |||||
END_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
CARLA_EXPORT | |||||
void carla_register_native_plugin_distrho_vectorjuice(); | |||||
CARLA_EXPORT | |||||
void carla_register_native_plugin_distrho_vectorjuice() | |||||
{ | |||||
USE_NAMESPACE_DISTRHO | |||||
carla_register_native_plugin(&vectorjuiceDesc); | |||||
} | |||||
// ----------------------------------------------------------------------- |
@@ -0,0 +1,36 @@ | |||||
/* | |||||
* Vector Juice Plugin | |||||
* Copyright (C) 2014 Andre Sklenar <andre.sklenar@gmail.com>, www.juicelab.cz | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
#ifndef DISTRHO_PLUGIN_INFO_H_INCLUDED | |||||
#define DISTRHO_PLUGIN_INFO_H_INCLUDED | |||||
#define DISTRHO_PLUGIN_NAME "VectorJuice" | |||||
#define DISTRHO_PLUGIN_HAS_UI 1 | |||||
#define DISTRHO_PLUGIN_IS_SYNTH 0 | |||||
#define DISTRHO_PLUGIN_NUM_INPUTS 8 | |||||
#define DISTRHO_PLUGIN_NUM_OUTPUTS 2 | |||||
#define DISTRHO_PLUGIN_WANT_LATENCY 0 | |||||
#define DISTRHO_PLUGIN_WANT_PROGRAMS 1 | |||||
#define DISTRHO_PLUGIN_WANT_STATE 0 | |||||
#define DISTRHO_PLUGIN_WANT_TIMEPOS 1 | |||||
#define DISTRHO_PLUGIN_URI "urn:distrho:VectorJuice" | |||||
#endif // DISTRHO_PLUGIN_INFO_H_INCLUDED |
@@ -0,0 +1,55 @@ | |||||
/* (Auto-generated binary data file). */ | |||||
#ifndef BINARY_VECTORJUICEARTWORK_HPP | |||||
#define BINARY_VECTORJUICEARTWORK_HPP | |||||
namespace VectorJuiceArtwork | |||||
{ | |||||
extern const char* aboutData; | |||||
const unsigned int aboutDataSize = 180000; | |||||
const unsigned int aboutWidth = 300; | |||||
const unsigned int aboutHeight = 200; | |||||
extern const char* aboutButtonHoverData; | |||||
const unsigned int aboutButtonHoverDataSize = 5888; | |||||
const unsigned int aboutButtonHoverWidth = 92; | |||||
const unsigned int aboutButtonHoverHeight = 16; | |||||
extern const char* aboutButtonNormalData; | |||||
const unsigned int aboutButtonNormalDataSize = 5888; | |||||
const unsigned int aboutButtonNormalWidth = 92; | |||||
const unsigned int aboutButtonNormalHeight = 16; | |||||
extern const char* backgroundData; | |||||
const unsigned int backgroundDataSize = 933432; | |||||
const unsigned int backgroundWidth = 712; | |||||
const unsigned int backgroundHeight = 437; | |||||
extern const char* knobData; | |||||
const unsigned int knobDataSize = 10404; | |||||
const unsigned int knobWidth = 51; | |||||
const unsigned int knobHeight = 51; | |||||
extern const char* orbitData; | |||||
const unsigned int orbitDataSize = 4096; | |||||
const unsigned int orbitWidth = 32; | |||||
const unsigned int orbitHeight = 32; | |||||
extern const char* roundletData; | |||||
const unsigned int roundletDataSize = 2500; | |||||
const unsigned int roundletWidth = 25; | |||||
const unsigned int roundletHeight = 25; | |||||
extern const char* sliderData; | |||||
const unsigned int sliderDataSize = 2600; | |||||
const unsigned int sliderWidth = 26; | |||||
const unsigned int sliderHeight = 25; | |||||
extern const char* subOrbitData; | |||||
const unsigned int subOrbitDataSize = 3364; | |||||
const unsigned int subOrbitWidth = 29; | |||||
const unsigned int subOrbitHeight = 29; | |||||
} | |||||
#endif // BINARY_VECTORJUICEARTWORK_HPP | |||||
@@ -0,0 +1,391 @@ | |||||
/* | |||||
* Vector Juice Plugin | |||||
* Copyright (C) 2014 Andre Sklenar <andre.sklenar@gmail.com>, www.juicelab.cz | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
#include "VectorJuicePlugin.hpp" | |||||
START_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
VectorJuicePlugin::VectorJuicePlugin() | |||||
: Plugin(paramCount, 1, 0) // 1 program, 0 states | |||||
{ | |||||
// set default values | |||||
d_setProgram(0); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
// Init | |||||
void VectorJuicePlugin::d_initParameter(uint32_t index, Parameter& parameter) | |||||
{ | |||||
switch (index) | |||||
{ | |||||
case paramX: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "X"; | |||||
parameter.symbol = "x"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramY: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "Y"; | |||||
parameter.symbol = "y"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramOrbitSizeX: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "Orbit Size X"; | |||||
parameter.symbol = "sizex"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramOrbitSizeY: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "Orbit Size Y"; | |||||
parameter.symbol = "sizey"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramOrbitSpeedX: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Speed X"; | |||||
parameter.symbol = "speedx"; | |||||
parameter.ranges.def = 4.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 128.0f; | |||||
break; | |||||
case paramOrbitSpeedY: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Speed Y"; | |||||
parameter.symbol = "speedy"; | |||||
parameter.ranges.def = 4.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 128.0f; | |||||
break; | |||||
case paramSubOrbitSize: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "SubOrbit Size"; | |||||
parameter.symbol = "subsize"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramSubOrbitSpeed: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "SubOrbit Speed"; | |||||
parameter.symbol = "subspeed"; | |||||
parameter.ranges.def = 32.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 128.0f; | |||||
break; | |||||
case paramSubOrbitSmooth: | |||||
parameter.hints = kParameterIsAutomable; | |||||
parameter.name = "SubOrbit Wave"; | |||||
parameter.symbol = "subwave"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramOrbitWaveX: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Wave X"; | |||||
parameter.symbol = "wavex"; | |||||
parameter.ranges.def = 3.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 4.0f; | |||||
break; | |||||
case paramOrbitWaveY: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Wave Y"; | |||||
parameter.symbol = "wavey"; | |||||
parameter.ranges.def = 3.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 4.0f; | |||||
break; | |||||
case paramOrbitPhaseX: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Phase X"; | |||||
parameter.symbol = "phasex"; | |||||
parameter.ranges.def = 1.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 4.0f; | |||||
break; | |||||
case paramOrbitPhaseY: | |||||
parameter.hints = kParameterIsAutomable|kParameterIsInteger; | |||||
parameter.name = "Orbit Phase Y"; | |||||
parameter.symbol = "phasey"; | |||||
parameter.ranges.def = 1.0f; | |||||
parameter.ranges.min = 1.0f; | |||||
parameter.ranges.max = 4.0f; | |||||
break; | |||||
case paramOrbitOutX: | |||||
parameter.hints = kParameterIsOutput; | |||||
parameter.name = "Orbit X"; | |||||
parameter.symbol = "orx"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramOrbitOutY: | |||||
parameter.hints = kParameterIsOutput; | |||||
parameter.name = "Orbit Y"; | |||||
parameter.symbol = "ory"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramSubOrbitOutX: | |||||
parameter.hints = kParameterIsOutput; | |||||
parameter.name = "SubOrbit X"; | |||||
parameter.symbol = "sorx"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
case paramSubOrbitOutY: | |||||
parameter.hints = kParameterIsOutput; | |||||
parameter.name = "SubOrbit Y"; | |||||
parameter.symbol = "sory"; | |||||
parameter.ranges.def = 0.5f; | |||||
parameter.ranges.min = 0.0f; | |||||
parameter.ranges.max = 1.0f; | |||||
break; | |||||
} | |||||
} | |||||
void VectorJuicePlugin::d_initProgramName(uint32_t index, d_string& programName) | |||||
{ | |||||
if (index != 0) | |||||
return; | |||||
programName = "Default"; | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
// Internal data | |||||
float VectorJuicePlugin::d_getParameterValue(uint32_t index) const | |||||
{ | |||||
switch (index) | |||||
{ | |||||
case paramX: | |||||
return x; | |||||
case paramY: | |||||
return y; | |||||
case paramOrbitSizeX: | |||||
return orbitSizeX; | |||||
case paramOrbitSizeY: | |||||
return orbitSizeY; | |||||
case paramOrbitSpeedX: | |||||
return orbitSpeedX; | |||||
case paramOrbitSpeedY: | |||||
return orbitSpeedY; | |||||
case paramSubOrbitSize: | |||||
return subOrbitSize; | |||||
case paramSubOrbitSpeed: | |||||
return subOrbitSpeed; | |||||
case paramSubOrbitSmooth: | |||||
return subOrbitSmooth; | |||||
case paramOrbitWaveX: | |||||
return orbitWaveX; | |||||
case paramOrbitWaveY: | |||||
return orbitWaveY; | |||||
case paramOrbitPhaseX: | |||||
return orbitPhaseY; | |||||
case paramOrbitPhaseY: | |||||
return orbitPhaseY; | |||||
case paramOrbitOutX: | |||||
return orbitX; | |||||
case paramOrbitOutY: | |||||
return orbitY; | |||||
case paramSubOrbitOutX: | |||||
return subOrbitX; | |||||
case paramSubOrbitOutY: | |||||
return subOrbitY; | |||||
default: | |||||
return 0.0f; | |||||
} | |||||
} | |||||
void VectorJuicePlugin::d_setParameterValue(uint32_t index, float value) | |||||
{ | |||||
bool resetPhase = false; | |||||
switch (index) | |||||
{ | |||||
case paramX: | |||||
x = value; | |||||
break; | |||||
case paramY: | |||||
y = value; | |||||
break; | |||||
case paramOrbitSizeX: | |||||
orbitSizeX = value; | |||||
break; | |||||
case paramOrbitSizeY: | |||||
orbitSizeY = value; | |||||
break; | |||||
case paramOrbitSpeedX: | |||||
orbitSpeedX = value; | |||||
resetPhase = true; | |||||
break; | |||||
case paramOrbitSpeedY: | |||||
orbitSpeedY = value; | |||||
resetPhase = true; | |||||
break; | |||||
case paramSubOrbitSize: | |||||
subOrbitSize = value; | |||||
break; | |||||
case paramSubOrbitSpeed: | |||||
subOrbitSpeed = value; | |||||
resetPhase = true; | |||||
break; | |||||
case paramSubOrbitSmooth: | |||||
subOrbitSmooth = value; | |||||
break; | |||||
case paramOrbitWaveX: | |||||
orbitWaveX = value; | |||||
break; | |||||
case paramOrbitWaveY: | |||||
orbitWaveY = value; | |||||
break; | |||||
case paramOrbitPhaseX: | |||||
orbitPhaseX = value; | |||||
resetPhase = true; | |||||
break; | |||||
case paramOrbitPhaseY: | |||||
orbitPhaseY = value; | |||||
resetPhase = true; | |||||
break; | |||||
} | |||||
if (resetPhase) | |||||
{ | |||||
sinePosX = 0; | |||||
sinePosY = 0; | |||||
sinePos = 0; | |||||
} | |||||
} | |||||
void VectorJuicePlugin::d_setProgram(uint32_t index) | |||||
{ | |||||
if (index != 0) | |||||
return; | |||||
/* Default parameter values */ | |||||
x = 0.5f; | |||||
y = 0.5f; | |||||
orbitSizeX = 0.5f; | |||||
orbitSizeY = 0.5f; | |||||
orbitSpeedX = 4.0f; | |||||
orbitSpeedY = 4.0f; | |||||
subOrbitSize = 0.5f; | |||||
subOrbitSpeed = 32.0f; | |||||
subOrbitSmooth = 0.5f; | |||||
orbitWaveX = 3.0f; | |||||
orbitWaveY = 3.0f; | |||||
orbitPhaseX = 1.0f; | |||||
orbitPhaseY = 1.0f; | |||||
/* reset filter values */ | |||||
d_activate(); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
// Process | |||||
void VectorJuicePlugin::d_activate() | |||||
{ | |||||
/* Default variable values */ | |||||
orbitX=orbitY=orbitTX=orbitTY=0.5; | |||||
subOrbitX=subOrbitY=subOrbitTX=subOrbitTY=0; | |||||
interpolationDivider=200; | |||||
bar=tickX=tickY=percentageX=percentageY=tickOffsetX=0; | |||||
tickOffsetY=sinePosX=sinePosY=tick=percentage=tickOffset=sinePos=0; | |||||
waveBlend=0; | |||||
//parameter smoothing | |||||
for (int i=0; i<2; i++) { | |||||
sA[i] = 0.99f; | |||||
sB[i] = 1.f - sA[i]; | |||||
sZ[i] = 0; | |||||
} | |||||
} | |||||
void VectorJuicePlugin::d_run(const float** inputs, float** outputs, uint32_t frames) | |||||
{ | |||||
float out1, out2, tX, tY; | |||||
for (uint32_t i=0; i<frames; i++) { | |||||
//1.41421 -> 1 | |||||
//<0 = 0 | |||||
animate(); | |||||
tX = subOrbitX; | |||||
tY = subOrbitY; | |||||
out1 = inputs[0][i]*tN(1-std::sqrt((tX*tX)+(tY*tY))); | |||||
out2 = inputs[1][i]*tN(1-std::sqrt((tX*tX)+(tY*tY))); | |||||
out1 += inputs[2][i]*tN(1-std::sqrt(((1-tX)*(1-tX))+(tY*tY))); | |||||
out2 += inputs[3][i]*tN(1-std::sqrt(((1-tX)*(1-tX))+(tY*tY))); | |||||
out1 += inputs[4][i]*tN(1-std::sqrt(((1-tX)*(1-tX))+((1-tY)*(1-tY)))); | |||||
out2 += inputs[5][i]*tN(1-std::sqrt(((1-tX)*(1-tX))+((1-tY)*(1-tY)))); | |||||
out1 += inputs[6][i]*tN(1-std::sqrt((tX*tX)+((1-tY)*(1-tY)))); | |||||
out2 += inputs[7][i]*tN(1-std::sqrt((tX*tX)+((1-tY)*(1-tY)))); | |||||
outputs[0][i] = out1; | |||||
outputs[1][i] = out2; | |||||
} | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
Plugin* createPlugin() | |||||
{ | |||||
return new VectorJuicePlugin(); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
END_NAMESPACE_DISTRHO |
@@ -0,0 +1,236 @@ | |||||
/* | |||||
* Vector Juice Plugin | |||||
* Copyright (C) 2014 Andre Sklenar <andre.sklenar@gmail.com>, www.juicelab.cz | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
#ifndef VECTORJUICEPLUGIN_HPP_INCLUDED | |||||
#define VECTORJUICEPLUGIN_HPP_INCLUDED | |||||
#include "DistrhoPlugin.hpp" | |||||
START_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
class VectorJuicePlugin : public Plugin | |||||
{ | |||||
public: | |||||
enum Parameters | |||||
{ | |||||
paramX = 0, | |||||
paramY, | |||||
paramOrbitSizeX, | |||||
paramOrbitSizeY, | |||||
paramOrbitSpeedX, | |||||
paramOrbitSpeedY, | |||||
paramSubOrbitSize, | |||||
paramSubOrbitSpeed, | |||||
paramSubOrbitSmooth, | |||||
paramOrbitWaveX, | |||||
paramOrbitWaveY, | |||||
paramOrbitPhaseX, | |||||
paramOrbitPhaseY, | |||||
paramOrbitOutX, | |||||
paramOrbitOutY, | |||||
paramSubOrbitOutX, | |||||
paramSubOrbitOutY, | |||||
paramCount | |||||
}; | |||||
float smoothParameter(float in, int axis) { | |||||
sZ[axis] = (in * sB[axis]) + (sZ[axis] * sA[axis]); | |||||
return sZ[axis]; | |||||
} | |||||
float getSinePhase(float x) { | |||||
return (-std::sin(x)); | |||||
} | |||||
float getSawPhase(float x) { | |||||
return (-(2/M_PI *std::atan(1/std::tan(x/2)))); | |||||
} | |||||
float getRevSawPhase(float x) { | |||||
return ((2/M_PI *std::atan(1/std::tan(x/2)))); | |||||
} | |||||
float getSquarePhase(float x) { | |||||
return (std::round((std::sin(x)+1)/2)-0.5)*2; | |||||
} | |||||
//saw, sqr, sin, revSaw | |||||
float getBlendedPhase(float x, float wave) | |||||
{ | |||||
//wave = 2; | |||||
if (wave>=1 && wave<2) { | |||||
/* saw vs sqr */ | |||||
waveBlend = wave-1; | |||||
return (getSawPhase(x)*(1-waveBlend) + getSquarePhase(x)*waveBlend); | |||||
} else if (wave>=2 && wave<3) { | |||||
/* sqr vs sin */ | |||||
waveBlend = wave-2; | |||||
return (getSquarePhase(x)*(1-waveBlend) + getSinePhase(x)*waveBlend); | |||||
} else if (wave>=3 && wave<=4) { | |||||
/* sin vs revSaw */ | |||||
waveBlend = wave-3; | |||||
return (getSinePhase(x)*(1-waveBlend) + getRevSawPhase(x)*waveBlend); | |||||
} else { | |||||
return 0.0f; | |||||
} | |||||
} | |||||
float tN(float x) | |||||
{ | |||||
if (x>0) return x; | |||||
else return 0; | |||||
} | |||||
void animate() | |||||
{ | |||||
//sync orbit with frame, bpm | |||||
const TimePosition& time(d_getTimePosition()); | |||||
bar = ((120.0/(time.bbt.valid ? time.bbt.beatsPerMinute : 120.0))*(d_getSampleRate())); | |||||
int multiplier = 16;//2000*4; | |||||
tickX = bar/(std::round(orbitSpeedX))*multiplier; | |||||
tickY = bar/(std::round(orbitSpeedY))*multiplier; | |||||
tick = bar/(std::round(subOrbitSpeed))*multiplier; | |||||
if (time.playing) | |||||
{ | |||||
/* if rolling then sync to timepos */ | |||||
tickOffsetX = time.frame-std::floor(time.frame/tickX)*tickX; | |||||
tickOffsetY = time.frame-std::floor(time.frame/tickY)*tickY; | |||||
tickOffset = time.frame-std::floor(time.frame/tick)*tick; | |||||
percentageX = tickOffsetX/tickX; | |||||
percentageY = tickOffsetY/tickY; | |||||
percentage = tickOffset/tick; | |||||
sinePosX = (M_PI*2)*percentageX; | |||||
sinePosY = (M_PI*2)*percentageY; | |||||
sinePos = (M_PI*2)*percentage; | |||||
} else { | |||||
/* else just keep on wobblin' */ | |||||
sinePosX += (2*M_PI)/(tickX); | |||||
sinePosY += (2*M_PI)/(tickY); | |||||
sinePos += (M_PI)/(tick); | |||||
if (sinePosX>2*M_PI) { | |||||
sinePosX = 0; | |||||
} | |||||
if (sinePosY>2*M_PI) { | |||||
sinePosY = 0; | |||||
} | |||||
if (sinePos>2*M_PI) { | |||||
sinePos = 0; | |||||
} | |||||
} | |||||
//0..1 | |||||
//0..3 | |||||
//0, 1, 2, 3 | |||||
//* 0.25 | |||||
//0, 0.25, 0.5, 0.75 | |||||
float tempPhaseX = std::round(orbitPhaseX)*0.25-0.25; | |||||
float tempPhaseY = std::round(orbitPhaseY)*0.25-0.25; | |||||
orbitX = x+getBlendedPhase(sinePosX + tempPhaseX*(2*M_PI), std::round(orbitWaveX))*(orbitSizeX/2); | |||||
orbitY = y+getBlendedPhase(sinePosY+M_PI/2 + tempPhaseY*(2*M_PI), std::round(orbitWaveY))*(orbitSizeY/2); | |||||
subOrbitX = smoothParameter(orbitX+getBlendedPhase(sinePos, 3)*(subOrbitSize/3), 0); | |||||
subOrbitY = smoothParameter(orbitY+getBlendedPhase(sinePos+M_PI/2, 3)*(subOrbitSize/3), 1); | |||||
if (orbitX<0) orbitX=0; | |||||
if (orbitX>1) orbitX=1; | |||||
if (orbitY<0) orbitY=0; | |||||
if (orbitY>1) orbitY=1; | |||||
if (subOrbitX<0) subOrbitX=0; | |||||
if (subOrbitX>1) subOrbitX=1; | |||||
if (subOrbitY<0) subOrbitY=0; | |||||
if (subOrbitY>1) subOrbitY=1; | |||||
} | |||||
VectorJuicePlugin(); | |||||
protected: | |||||
// ------------------------------------------------------------------- | |||||
// Information | |||||
const char* d_getLabel() const noexcept override | |||||
{ | |||||
return "VectorJuice"; | |||||
} | |||||
const char* d_getMaker() const noexcept override | |||||
{ | |||||
return "Andre Sklenar"; | |||||
} | |||||
const char* d_getLicense() const noexcept override | |||||
{ | |||||
return "GPL v2+"; | |||||
} | |||||
uint32_t d_getVersion() const noexcept override | |||||
{ | |||||
return 0x1000; | |||||
} | |||||
long d_getUniqueId() const noexcept override | |||||
{ | |||||
return d_cconst('V', 'e', 'c', 'J'); | |||||
} | |||||
// ------------------------------------------------------------------- | |||||
// Init | |||||
void d_initParameter(uint32_t index, Parameter& parameter) override; | |||||
void d_initProgramName(uint32_t index, d_string& programName) override; | |||||
// ------------------------------------------------------------------- | |||||
// Internal data | |||||
float d_getParameterValue(uint32_t index) const override; | |||||
void d_setParameterValue(uint32_t index, float value) override; | |||||
void d_setProgram(uint32_t index) override; | |||||
// ------------------------------------------------------------------- | |||||
// Process | |||||
void d_activate() override; | |||||
void d_run(const float** inputs, float** outputs, uint32_t frames) override; | |||||
// ------------------------------------------------------------------- | |||||
private: | |||||
float x, y; | |||||
float orbitX, orbitY; | |||||
float orbitTX, orbitTY; //targetX and targetY for interpolation | |||||
float subOrbitX, subOrbitY; | |||||
float subOrbitTX, subOrbitTY; | |||||
float subOrbitSpeed, subOrbitSize, orbitSpeedX, orbitSpeedY; | |||||
float orbitSizeX, orbitSizeY; | |||||
float interpolationDivider; | |||||
float bar, tickX, tickY, percentageX, percentageY, tickOffsetX, tickOffsetY; | |||||
float sinePosX, sinePosY, tick, percentage, tickOffset, sinePos; | |||||
float orbitWaveX, orbitWaveY, subOrbitSmooth, waveBlend; | |||||
float orbitPhaseX, orbitPhaseY; | |||||
//parameter smoothing, for subOrbitX and subOrbitY | |||||
float sA[2], sB[2], sZ[2]; | |||||
}; | |||||
// ----------------------------------------------------------------------- | |||||
END_NAMESPACE_DISTRHO | |||||
#endif // VECTORJUICE_HPP_INCLUDED |
@@ -0,0 +1,461 @@ | |||||
/* | |||||
* Vector Juice Plugin | |||||
* Copyright (C) 2014 Andre Sklenar <andre.sklenar@gmail.com>, www.juicelab.cz | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
#include "VectorJuicePlugin.hpp" | |||||
#include "VectorJuiceUI.hpp" | |||||
using DGL::Point; | |||||
START_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
VectorJuiceUI::VectorJuiceUI() | |||||
: UI(), | |||||
fAboutWindow(this) | |||||
{ | |||||
setSize(VectorJuiceArtwork::backgroundWidth, VectorJuiceArtwork::backgroundHeight); | |||||
// xy params | |||||
paramX = paramY = 0.5f; | |||||
// orbit params | |||||
orbitX = orbitY = subOrbitX = subOrbitY = 0.5f; | |||||
// set the XY canvas area | |||||
fDragging = false; | |||||
fDragValid = false; | |||||
fLastX = fLastY = 0; | |||||
fCanvasArea.setPos(22+12, 49+12); | |||||
fCanvasArea.setSize(368-24, 368-24); | |||||
// background | |||||
fImgBackground = Image(VectorJuiceArtwork::backgroundData, VectorJuiceArtwork::backgroundWidth, VectorJuiceArtwork::backgroundHeight, GL_BGR); | |||||
//roundlet | |||||
fImgRoundlet = Image(VectorJuiceArtwork::roundletData, VectorJuiceArtwork::roundletWidth, VectorJuiceArtwork::roundletHeight); | |||||
//orbit | |||||
fImgOrbit = Image(VectorJuiceArtwork::orbitData, VectorJuiceArtwork::orbitWidth, VectorJuiceArtwork::orbitHeight); | |||||
//subOrbit | |||||
fImgSubOrbit = Image(VectorJuiceArtwork::subOrbitData, VectorJuiceArtwork::subOrbitWidth, VectorJuiceArtwork::subOrbitHeight); | |||||
// about | |||||
Image aboutImage(VectorJuiceArtwork::aboutData, VectorJuiceArtwork::aboutWidth, VectorJuiceArtwork::aboutHeight, GL_BGR); | |||||
fAboutWindow.setImage(aboutImage); | |||||
// about button | |||||
Image aboutImageNormal(VectorJuiceArtwork::aboutButtonNormalData, VectorJuiceArtwork::aboutButtonNormalWidth, VectorJuiceArtwork::aboutButtonNormalHeight); | |||||
Image aboutImageHover(VectorJuiceArtwork::aboutButtonHoverData, VectorJuiceArtwork::aboutButtonHoverWidth, VectorJuiceArtwork::aboutButtonHoverHeight); | |||||
fButtonAbout = new ImageButton(this, aboutImageNormal, aboutImageHover, aboutImageHover); | |||||
fButtonAbout->setAbsolutePos(599, 17); | |||||
fButtonAbout->setCallback(this); | |||||
// knobs | |||||
Image knobImage(VectorJuiceArtwork::knobData, VectorJuiceArtwork::knobWidth, VectorJuiceArtwork::knobHeight); | |||||
// knob KnobOrbitSizeX | |||||
fKnobOrbitSizeX = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobOrbitSizeX->setId(VectorJuicePlugin::paramOrbitSizeX); | |||||
fKnobOrbitSizeX->setAbsolutePos(423, 73); | |||||
fKnobOrbitSizeX->setRotationAngle(270); | |||||
fKnobOrbitSizeX->setRange(0.0f, 1.0f); | |||||
fKnobOrbitSizeX->setDefault(0.5f); | |||||
fKnobOrbitSizeX->setCallback(this); | |||||
// knob KnobOrbitSizeY | |||||
fKnobOrbitSizeY = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobOrbitSizeY->setId(VectorJuicePlugin::paramOrbitSizeY); | |||||
fKnobOrbitSizeY->setAbsolutePos(516, 73); | |||||
fKnobOrbitSizeY->setRotationAngle(270); | |||||
fKnobOrbitSizeY->setRange(0.0f, 1.0f); | |||||
fKnobOrbitSizeY->setDefault(0.5f); | |||||
fKnobOrbitSizeY->setCallback(this); | |||||
// knob KnobOrbitSpeedX | |||||
fKnobOrbitSpeedX = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobOrbitSpeedX->setId(VectorJuicePlugin::paramOrbitSpeedX); | |||||
fKnobOrbitSpeedX->setAbsolutePos(423, 185); | |||||
fKnobOrbitSpeedX->setRotationAngle(270); | |||||
fKnobOrbitSpeedX->setStep(1.0f); | |||||
fKnobOrbitSpeedX->setRange(1.0f, 128.0f); | |||||
fKnobOrbitSpeedX->setDefault(4.0f); | |||||
fKnobOrbitSpeedX->setCallback(this); | |||||
// knob KnobOrbitSpeedY | |||||
fKnobOrbitSpeedY = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobOrbitSpeedY->setId(VectorJuicePlugin::paramOrbitSpeedY); | |||||
fKnobOrbitSpeedY->setAbsolutePos(516, 185); | |||||
fKnobOrbitSpeedY->setRotationAngle(270); | |||||
fKnobOrbitSpeedY->setStep(1.0f); | |||||
fKnobOrbitSpeedY->setRange(1.0f, 128.0f); | |||||
fKnobOrbitSpeedY->setDefault(4.0f); | |||||
fKnobOrbitSpeedY->setCallback(this); | |||||
// knob KnobSubOrbitSize | |||||
fKnobSubOrbitSize = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobSubOrbitSize->setId(VectorJuicePlugin::paramSubOrbitSize); | |||||
fKnobSubOrbitSize->setAbsolutePos(620, 73); | |||||
fKnobSubOrbitSize->setRange(0.0f, 1.0f); | |||||
fKnobSubOrbitSize->setRotationAngle(270); | |||||
fKnobSubOrbitSize->setDefault(0.5f); | |||||
fKnobSubOrbitSize->setCallback(this); | |||||
// knob KnobSubOrbitSpeed | |||||
fKnobSubOrbitSpeed = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobSubOrbitSpeed->setId(VectorJuicePlugin::paramSubOrbitSpeed); | |||||
fKnobSubOrbitSpeed->setAbsolutePos(620, 185); | |||||
fKnobSubOrbitSpeed->setRotationAngle(270); | |||||
fKnobSubOrbitSpeed->setStep(1.0f); | |||||
fKnobSubOrbitSpeed->setRange(1.0f, 128.0f); | |||||
fKnobSubOrbitSpeed->setDefault(32.0f); | |||||
fKnobSubOrbitSpeed->setCallback(this); | |||||
// knob KnobSubOrbitSmooth | |||||
fKnobSubOrbitSmooth = new ImageKnob(this, knobImage, ImageKnob::Vertical); | |||||
fKnobSubOrbitSmooth->setId(VectorJuicePlugin::paramSubOrbitSmooth); | |||||
fKnobSubOrbitSmooth->setAbsolutePos(620, 297); | |||||
fKnobSubOrbitSmooth->setRotationAngle(270); | |||||
fKnobSubOrbitSmooth->setRange(0.0f, 1.0f); | |||||
fKnobSubOrbitSmooth->setDefault(0.5f); | |||||
fKnobSubOrbitSmooth->setCallback(this); | |||||
// sliders | |||||
Image sliderImage(VectorJuiceArtwork::sliderData, VectorJuiceArtwork::sliderWidth, VectorJuiceArtwork::sliderHeight); | |||||
Point<int> sliderPosStart(410, 284); | |||||
Point<int> sliderPosEnd(410+48, 284); | |||||
// slider OrbitWaveX | |||||
fSliderOrbitWaveX = new ImageSlider(this, sliderImage); | |||||
fSliderOrbitWaveX->setId(VectorJuicePlugin::paramOrbitWaveX); | |||||
fSliderOrbitWaveX->setStartPos(sliderPosStart); | |||||
fSliderOrbitWaveX->setEndPos(sliderPosEnd); | |||||
fSliderOrbitWaveX->setRange(1.0f, 4.0f); | |||||
fSliderOrbitWaveX->setStep(1.0f); | |||||
fSliderOrbitWaveX->setCallback(this); | |||||
// slider OrbitWaveY | |||||
sliderPosStart.setX(503); | |||||
sliderPosEnd.setX(503+48); | |||||
fSliderOrbitWaveY = new ImageSlider(this, sliderImage); | |||||
fSliderOrbitWaveY->setId(VectorJuicePlugin::paramOrbitWaveY); | |||||
fSliderOrbitWaveY->setStartPos(sliderPosStart); | |||||
fSliderOrbitWaveY->setEndPos(sliderPosEnd); | |||||
fSliderOrbitWaveY->setRange(1.0f, 4.0f); | |||||
fSliderOrbitWaveY->setStep(1.0f); | |||||
fSliderOrbitWaveY->setCallback(this); | |||||
// slider OrbitPhaseX | |||||
sliderPosStart.setX(410); | |||||
sliderPosStart.setY(345); | |||||
sliderPosEnd.setX(410+48); | |||||
sliderPosEnd.setY(345); | |||||
fSliderOrbitPhaseX = new ImageSlider(this, sliderImage); | |||||
fSliderOrbitPhaseX->setId(VectorJuicePlugin::paramOrbitPhaseX); | |||||
fSliderOrbitPhaseX->setStartPos(sliderPosStart); | |||||
fSliderOrbitPhaseX->setEndPos(sliderPosEnd); | |||||
fSliderOrbitPhaseX->setRange(1.0f, 4.0f); | |||||
fSliderOrbitPhaseX->setStep(1.0f); | |||||
fSliderOrbitPhaseX->setCallback(this); | |||||
// slider OrbitPhaseY | |||||
sliderPosStart.setX(503); | |||||
sliderPosEnd.setX(503+48); | |||||
fSliderOrbitPhaseY = new ImageSlider(this, sliderImage); | |||||
fSliderOrbitPhaseY->setId(VectorJuicePlugin::paramOrbitPhaseY); | |||||
fSliderOrbitPhaseY->setStartPos(sliderPosStart); | |||||
fSliderOrbitPhaseY->setEndPos(sliderPosEnd); | |||||
fSliderOrbitPhaseY->setRange(1.0f, 4.0f); | |||||
fSliderOrbitPhaseY->setStep(1.0f); | |||||
fSliderOrbitPhaseY->setCallback(this); | |||||
// set default values | |||||
d_programChanged(0); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
// DSP Callbacks | |||||
void VectorJuiceUI::d_parameterChanged(uint32_t index, float value) | |||||
{ | |||||
switch (index) | |||||
{ | |||||
case VectorJuicePlugin::paramX: | |||||
if (paramX != value) | |||||
{ | |||||
paramX = value; | |||||
fDragValid = false; | |||||
repaint(); | |||||
} | |||||
break; | |||||
case VectorJuicePlugin::paramY: | |||||
if (paramY != value) | |||||
{ | |||||
paramY = value; | |||||
fDragValid = false; | |||||
repaint(); | |||||
} | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitSizeX: | |||||
fKnobOrbitSizeX->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitSizeY: | |||||
fKnobOrbitSizeY->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitSpeedX: | |||||
fKnobOrbitSpeedX->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitSpeedY: | |||||
fKnobOrbitSpeedY->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramSubOrbitSize: | |||||
fKnobSubOrbitSize->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramSubOrbitSpeed: | |||||
fKnobSubOrbitSpeed->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramSubOrbitSmooth: | |||||
fKnobSubOrbitSmooth->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitWaveX: | |||||
fSliderOrbitWaveX->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitWaveY: | |||||
fSliderOrbitWaveY->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitPhaseX: | |||||
fSliderOrbitPhaseX->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitPhaseY: | |||||
fSliderOrbitPhaseY->setValue(value); | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitOutX: | |||||
if (orbitX != value) | |||||
{ | |||||
orbitX = value; | |||||
repaint(); | |||||
} | |||||
break; | |||||
case VectorJuicePlugin::paramOrbitOutY: | |||||
if (orbitY != value) | |||||
{ | |||||
orbitY = value; | |||||
repaint(); | |||||
} | |||||
break; | |||||
case VectorJuicePlugin::paramSubOrbitOutX: | |||||
if (subOrbitX != value) | |||||
{ | |||||
subOrbitX = value; | |||||
repaint(); | |||||
} | |||||
break; | |||||
case VectorJuicePlugin::paramSubOrbitOutY: | |||||
if (subOrbitY != value) | |||||
{ | |||||
subOrbitY = value; | |||||
repaint(); | |||||
} | |||||
break; | |||||
} | |||||
} | |||||
void VectorJuiceUI::d_programChanged(uint32_t index) | |||||
{ | |||||
if (index != 0) | |||||
return; | |||||
// Default values | |||||
paramX = paramY = 0.5f; | |||||
fKnobOrbitSizeX->setValue(0.5f); | |||||
fKnobOrbitSizeY->setValue(0.5f); | |||||
fKnobOrbitSpeedX->setValue(4.0f); | |||||
fKnobOrbitSpeedY->setValue(4.0f); | |||||
fKnobSubOrbitSize->setValue(0.5f); | |||||
fKnobSubOrbitSpeed->setValue(32.0f); | |||||
fKnobSubOrbitSmooth->setValue(0.5f); | |||||
fSliderOrbitWaveX->setValue(3.0f); | |||||
fSliderOrbitWaveY->setValue(3.0f); | |||||
fSliderOrbitPhaseX->setValue(1.0f); | |||||
fSliderOrbitPhaseY->setValue(1.0f); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
// Widget Callbacks | |||||
void VectorJuiceUI::imageButtonClicked(ImageButton* button, int) | |||||
{ | |||||
if (button != fButtonAbout) | |||||
return; | |||||
fAboutWindow.exec(); | |||||
} | |||||
void VectorJuiceUI::imageKnobDragStarted(ImageKnob* knob) | |||||
{ | |||||
d_editParameter(knob->getId(), true); | |||||
} | |||||
void VectorJuiceUI::imageKnobDragFinished(ImageKnob* knob) | |||||
{ | |||||
d_editParameter(knob->getId(), false); | |||||
} | |||||
void VectorJuiceUI::imageKnobValueChanged(ImageKnob* knob, float value) | |||||
{ | |||||
d_setParameterValue(knob->getId(), value); | |||||
} | |||||
void VectorJuiceUI::imageSliderDragStarted(ImageSlider* slider) | |||||
{ | |||||
d_editParameter(slider->getId(), true); | |||||
} | |||||
void VectorJuiceUI::imageSliderDragFinished(ImageSlider* slider) | |||||
{ | |||||
d_editParameter(slider->getId(), false); | |||||
} | |||||
void VectorJuiceUI::imageSliderValueChanged(ImageSlider* slider, float value) | |||||
{ | |||||
d_setParameterValue(slider->getId(), value); | |||||
} | |||||
void VectorJuiceUI::onDisplay() | |||||
{ | |||||
fImgBackground.draw(); | |||||
// get x, y mapped to XY area | |||||
int x = fCanvasArea.getX() + paramX*fCanvasArea.getWidth() - fImgRoundlet.getWidth()/2; | |||||
int y = fCanvasArea.getY() + paramY*fCanvasArea.getHeight() - fImgRoundlet.getHeight()/2; | |||||
int nOrbitX = fCanvasArea.getX()+((orbitX)*fCanvasArea.getWidth())-15; | |||||
int nOrbitY = fCanvasArea.getY()+((orbitY)*fCanvasArea.getWidth())-15; | |||||
int nSubOrbitX = fCanvasArea.getX()+(subOrbitX*fCanvasArea.getWidth())-15; | |||||
int nSubOrbitY = fCanvasArea.getY()+(subOrbitY*fCanvasArea.getWidth())-14; | |||||
//draw lines, just for fun | |||||
glEnable(GL_BLEND); | |||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | |||||
glColor4f(0.0f, 1.0f, 0.0f, 0.05f); | |||||
glLineWidth(4); | |||||
glBegin(GL_LINES); | |||||
glVertex2i(x+ fImgRoundlet.getWidth()/2, y+ fImgRoundlet.getHeight()/2); | |||||
glVertex2i(nOrbitX+15, nOrbitY+15); | |||||
glEnd(); | |||||
glBegin(GL_LINES); | |||||
glVertex2i(nOrbitX+15, nOrbitY+15); | |||||
glVertex2i(nSubOrbitX+15, nSubOrbitY+14); | |||||
glEnd(); | |||||
// reset color | |||||
glColor4f(1.0f, 1.0f, 1.0f, 1.0f); | |||||
// draw roundlet and orbits | |||||
fImgRoundlet.drawAt(x, y); | |||||
fImgOrbit.drawAt(nOrbitX, nOrbitY); | |||||
fImgSubOrbit.drawAt(nSubOrbitX, nSubOrbitY); | |||||
} | |||||
bool VectorJuiceUI::onMouse(const MouseEvent& ev) | |||||
{ | |||||
if (ev.button != 1) | |||||
return false; | |||||
if (ev.press) | |||||
{ | |||||
if (! fCanvasArea.contains(ev.pos)) | |||||
return false; | |||||
fDragging = true; | |||||
fDragValid = true; | |||||
fLastX = ev.pos.getX(); | |||||
fLastY = ev.pos.getY(); | |||||
return true; | |||||
} | |||||
else if (fDragging) | |||||
{ | |||||
fDragging = false; | |||||
return true; | |||||
} | |||||
return false; | |||||
} | |||||
bool VectorJuiceUI::onMotion(const MotionEvent& ev) | |||||
{ | |||||
if (! fDragging) | |||||
return false; | |||||
const int x = ev.pos.getX(); | |||||
const int y = ev.pos.getY(); | |||||
if (! fDragValid) | |||||
{ | |||||
fDragValid = true; | |||||
fLastX = x; | |||||
fLastY = y; | |||||
} | |||||
const int movedX = fLastX - x; | |||||
const int movedY = fLastY - y; | |||||
fLastX = x; | |||||
fLastY = y; | |||||
float newX = paramX; | |||||
float newY = paramY; | |||||
newX -= float(movedX)/fCanvasArea.getWidth(); | |||||
newY -= float(movedY)/fCanvasArea.getHeight(); | |||||
if (newX < 0.0f) | |||||
newX = 0.0f; | |||||
else if (newX > 1.0f) | |||||
newX = 1.0f; | |||||
if (newY < 0.0f) | |||||
newY = 0.0f; | |||||
else if (newY > 1.0f) | |||||
newY = 1.0f; | |||||
if (newX != paramX) | |||||
{ | |||||
paramX = newX; | |||||
d_setParameterValue(VectorJuicePlugin::paramX, paramX); | |||||
repaint(); | |||||
} | |||||
if (newY != paramY) | |||||
{ | |||||
paramY = newY; | |||||
d_setParameterValue(VectorJuicePlugin::paramY, paramY); | |||||
repaint(); | |||||
} | |||||
return true; | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
UI* createUI() | |||||
{ | |||||
return new VectorJuiceUI(); | |||||
} | |||||
// ----------------------------------------------------------------------- | |||||
END_NAMESPACE_DISTRHO |
@@ -0,0 +1,102 @@ | |||||
/* | |||||
* Vector Juice Plugin | |||||
* Copyright (C) 2014 Andre Sklenar <andre.sklenar@gmail.com>, www.juicelab.cz | |||||
* | |||||
* This program 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 of | |||||
* the License, or 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. | |||||
* | |||||
* For a full copy of the GNU General Public License see the doc/GPL.txt file. | |||||
*/ | |||||
#ifndef VECTORJUICEUI_HPP_INCLUDED | |||||
#define VECTORJUICEUI_HPP_INCLUDED | |||||
#include "DistrhoUI.hpp" | |||||
#include "ImageAboutWindow.hpp" | |||||
#include "ImageButton.hpp" | |||||
#include "ImageKnob.hpp" | |||||
#include "ImageSlider.hpp" | |||||
#include "VectorJuiceArtwork.hpp" | |||||
using DGL::Image; | |||||
using DGL::ImageAboutWindow; | |||||
using DGL::ImageButton; | |||||
using DGL::ImageKnob; | |||||
using DGL::ImageSlider; | |||||
START_NAMESPACE_DISTRHO | |||||
// ----------------------------------------------------------------------- | |||||
class VectorJuiceUI : public UI, | |||||
public ImageButton::Callback, | |||||
public ImageKnob::Callback, | |||||
public ImageSlider::Callback | |||||
{ | |||||
public: | |||||
VectorJuiceUI(); | |||||
protected: | |||||
// ------------------------------------------------------------------- | |||||
// DSP Callbacks | |||||
void d_parameterChanged(uint32_t index, float value) override; | |||||
void d_programChanged(uint32_t index) override; | |||||
// ------------------------------------------------------------------- | |||||
// Widget Callbacks | |||||
void imageButtonClicked(ImageButton* button, int) override; | |||||
void imageKnobDragStarted(ImageKnob* knob) override; | |||||
void imageKnobDragFinished(ImageKnob* knob) override; | |||||
void imageKnobValueChanged(ImageKnob* knob, float value) override; | |||||
void imageSliderDragStarted(ImageSlider* slider) override; | |||||
void imageSliderDragFinished(ImageSlider* slider) override; | |||||
void imageSliderValueChanged(ImageSlider* slider, float value) override; | |||||
void onDisplay() override; | |||||
bool onMouse(const MouseEvent&) override; | |||||
bool onMotion(const MotionEvent&) override; | |||||
private: | |||||
float paramX, paramY; | |||||
Image fImgBackground; | |||||
Image fImgRoundlet; | |||||
Image fImgOrbit; | |||||
Image fImgSubOrbit; | |||||
ImageAboutWindow fAboutWindow; | |||||
ScopedPointer<ImageButton> fButtonAbout; | |||||
//knobs | |||||
ScopedPointer<ImageKnob> fKnobOrbitSpeedX, fKnobOrbitSpeedY, fKnobOrbitSizeX, fKnobOrbitSizeY; | |||||
ScopedPointer<ImageKnob> fKnobSubOrbitSpeed, fKnobSubOrbitSize, fKnobSubOrbitSmooth; | |||||
//sliders | |||||
ScopedPointer<ImageSlider> fSliderOrbitWaveX, fSliderOrbitWaveY; | |||||
ScopedPointer<ImageSlider> fSliderOrbitPhaseX, fSliderOrbitPhaseY; | |||||
// needed for XY canvas handling | |||||
bool fDragging; | |||||
bool fDragValid; | |||||
int fLastX; | |||||
int fLastY; | |||||
DGL::Rectangle<int> fCanvasArea; | |||||
float orbitX, orbitY, subOrbitX, subOrbitY; | |||||
}; | |||||
// ----------------------------------------------------------------------- | |||||
END_NAMESPACE_DISTRHO | |||||
#endif // VECTORJUICEUI_HPP_INCLUDED |
@@ -72,7 +72,7 @@ struct PluginListManager { | |||||
std::strcmp(desc->label, "nekobi" ) == 0 || | std::strcmp(desc->label, "nekobi" ) == 0 || | ||||
std::strcmp(desc->label, "pingpongpan" ) == 0 || | std::strcmp(desc->label, "pingpongpan" ) == 0 || | ||||
std::strcmp(desc->label, "prom" ) == 0 || | std::strcmp(desc->label, "prom" ) == 0 || | ||||
std::strstr(desc->label, "Juice" ) != nullptr || | |||||
std::strstr(desc->label, "juice" ) != nullptr || | |||||
std::strstr(desc->label, "Zam" ) != nullptr) | std::strstr(desc->label, "Zam" ) != nullptr) | ||||
{ | { | ||||
continue; | continue; | ||||