Collection of DPF-based plugins for packaging
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

128 lines
4.2KB

  1. /*
  2. * DISTRHO CycleShifter, a DPF'ied CycleShifter.
  3. * Copyright (C) 2004 Niall Moody
  4. * Copyright (C) 2015 Filipe Coelho <falktx@falktx.com>
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining a
  7. * copy of this software and associated documentation files (the "Software"),
  8. * to deal in the Software without restriction, including without limitation
  9. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  10. * and/or sell copies of the Software, and to permit persons to whom the
  11. * Software is furnished to do so, subject to the following conditions:
  12. *
  13. * The above copyright notice and this permission notice shall be included in
  14. * all copies or substantial portions of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  19. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  21. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  22. * DEALINGS IN THE SOFTWARE.
  23. */
  24. #ifndef DISTRHO_PLUGIN_CYCLE_SHIFTER_HPP_INCLUDED
  25. #define DISTRHO_PLUGIN_CYCLE_SHIFTER_HPP_INCLUDED
  26. #include "DistrhoPlugin.hpp"
  27. #define BUFFER_SIZE 11025
  28. START_NAMESPACE_DISTRHO
  29. // -----------------------------------------------------------------------
  30. class DistrhoPluginCycleShifter : public Plugin
  31. {
  32. public:
  33. enum Parameters {
  34. kParameterNewCycleVolume,
  35. kParameterInputVolume,
  36. kParameterCount
  37. };
  38. DistrhoPluginCycleShifter();
  39. protected:
  40. // -------------------------------------------------------------------
  41. // Information
  42. const char* getLabel() const noexcept override
  43. {
  44. return "CycleShifter";
  45. }
  46. const char* getDescription() const override
  47. {
  48. return "Reads in a cycle's-worth of the input signal, then (once the whole cycle's been read in) outputs it again, on top of the current output.\n\
  49. Works best with long/sustained sounds (e.g. strings, pads etc.), sounds like a weird kind of gentle distortion.";
  50. }
  51. const char* getMaker() const noexcept override
  52. {
  53. return "ndc Plugs";
  54. }
  55. const char* getHomePage() const override
  56. {
  57. return "https://github.com/DISTRHO/ndc-Plugs";
  58. }
  59. const char* getLicense() const noexcept override
  60. {
  61. return "MIT";
  62. }
  63. uint32_t getVersion() const noexcept override
  64. {
  65. return d_version(0, 1, 0);
  66. }
  67. int64_t getUniqueId() const noexcept override
  68. {
  69. return d_cconst('C', 'S', 'f', 't');
  70. }
  71. // -------------------------------------------------------------------
  72. // Init
  73. void initParameter(uint32_t index, Parameter& parameter) override;
  74. void initProgramName(uint32_t index, String& programName) override;
  75. // -------------------------------------------------------------------
  76. // Internal data
  77. float getParameterValue(uint32_t index) const override;
  78. void setParameterValue(uint32_t index, float value) override;
  79. void loadProgram(uint32_t index) override;
  80. // -------------------------------------------------------------------
  81. // Process
  82. void activate() override;
  83. void run(const float** inputs, float** outputs, uint32_t frames) override;
  84. // -------------------------------------------------------------------
  85. private:
  86. float fNewCycleVolume;
  87. float fInputVolume;
  88. float CycleBuffer[BUFFER_SIZE]; // buffer to store the cycle in
  89. int OutIndex; // index for playing the buffer
  90. int InCount; // counts how many samples we've recorded
  91. bool ReadWrite; // 0=read, 1=write
  92. float EnvOld; // last (input) sample - used to determine zero-crossings
  93. float DoProcess(float a);
  94. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(DistrhoPluginCycleShifter)
  95. };
  96. // -----------------------------------------------------------------------
  97. END_NAMESPACE_DISTRHO
  98. #endif // DISTRHO_PLUGIN_CYCLE_SHIFTER_HPP_INCLUDED