Use a vizia generic UI for Diopser
This commit is contained in:
parent
ff000565e5
commit
101075795d
4 changed files with 44 additions and 71 deletions
2
Cargo.lock
generated
2
Cargo.lock
generated
|
@ -801,7 +801,7 @@ version = "0.1.0"
|
|||
dependencies = [
|
||||
"fftw",
|
||||
"nih_plug",
|
||||
"nih_plug_iced",
|
||||
"nih_plug_vizia",
|
||||
"triple_buffer",
|
||||
]
|
||||
|
||||
|
|
|
@ -16,7 +16,7 @@ simd = ["nih_plug/simd"]
|
|||
|
||||
[dependencies]
|
||||
nih_plug = { path = "../../", features = ["assert_process_allocs"] }
|
||||
nih_plug_iced = { path = "../../nih_plug_iced" }
|
||||
nih_plug_vizia = { path = "../../nih_plug_vizia" }
|
||||
|
||||
# For the GUI
|
||||
fftw = "0.7"
|
||||
|
|
|
@ -14,85 +14,58 @@
|
|||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
use nih_plug::prelude::{Editor, GuiContext};
|
||||
use nih_plug_iced::widgets as nih_widgets;
|
||||
use nih_plug_iced::widgets::generic_ui::GenericUi;
|
||||
use nih_plug_iced::*;
|
||||
use nih_plug::prelude::Editor;
|
||||
use nih_plug_vizia::vizia::*;
|
||||
use nih_plug_vizia::widgets::*;
|
||||
use nih_plug_vizia::{assets, create_vizia_editor, ViziaState};
|
||||
use std::pin::Pin;
|
||||
use std::sync::Arc;
|
||||
|
||||
use crate::DiopserParams;
|
||||
|
||||
/// VIZIA uses points instead of pixels for text
|
||||
const POINT_SCALE: f32 = 0.75;
|
||||
|
||||
#[derive(Lens)]
|
||||
// TODO: Lens requires everything to be marked as `pub`
|
||||
pub struct Data {
|
||||
params: Pin<Arc<DiopserParams>>,
|
||||
}
|
||||
|
||||
impl Model for Data {}
|
||||
|
||||
// Makes sense to also define this here, makes it a bit easier to keep track of
|
||||
pub(crate) fn default_state() -> Arc<IcedState> {
|
||||
IcedState::from_size(360, 300)
|
||||
pub(crate) fn default_state() -> Arc<ViziaState> {
|
||||
ViziaState::from_size(360, 300)
|
||||
}
|
||||
|
||||
pub(crate) fn create(
|
||||
params: Pin<Arc<DiopserParams>>,
|
||||
editor_state: Arc<IcedState>,
|
||||
editor_state: Arc<ViziaState>,
|
||||
) -> Option<Box<dyn Editor>> {
|
||||
create_iced_editor::<DiopserEditor>(editor_state, params)
|
||||
}
|
||||
|
||||
struct DiopserEditor {
|
||||
params: Pin<Arc<DiopserParams>>,
|
||||
context: Arc<dyn GuiContext>,
|
||||
|
||||
generic_ui_state: nih_widgets::generic_ui::State<nih_widgets::generic_ui::GenericSlider>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Copy)]
|
||||
enum Message {
|
||||
/// Update a parameter's value.
|
||||
ParamUpdate(nih_widgets::ParamMessage),
|
||||
}
|
||||
|
||||
impl IcedEditor for DiopserEditor {
|
||||
type Executor = executor::Default;
|
||||
type Message = Message;
|
||||
type InitializationFlags = Pin<Arc<DiopserParams>>;
|
||||
|
||||
fn new(
|
||||
params: Self::InitializationFlags,
|
||||
context: Arc<dyn GuiContext>,
|
||||
) -> (Self, Command<Self::Message>) {
|
||||
let editor = DiopserEditor {
|
||||
params,
|
||||
context,
|
||||
|
||||
generic_ui_state: Default::default(),
|
||||
};
|
||||
|
||||
(editor, Command::none())
|
||||
}
|
||||
|
||||
fn context(&self) -> &dyn GuiContext {
|
||||
self.context.as_ref()
|
||||
}
|
||||
|
||||
fn update(
|
||||
&mut self,
|
||||
_window: &mut WindowQueue,
|
||||
message: Self::Message,
|
||||
) -> Command<Self::Message> {
|
||||
match message {
|
||||
Message::ParamUpdate(message) => self.handle_param_message(message),
|
||||
create_vizia_editor(editor_state, move |cx| {
|
||||
Data {
|
||||
params: params.clone(),
|
||||
}
|
||||
.build(cx);
|
||||
|
||||
Command::none()
|
||||
}
|
||||
VStack::new(cx, |cx| {
|
||||
Label::new(cx, "Diopser")
|
||||
.font(assets::NOTO_SANS_THIN)
|
||||
.font_size(40.0 * POINT_SCALE)
|
||||
.height(Pixels(50.0))
|
||||
.child_top(Stretch(1.0))
|
||||
.child_bottom(Pixels(0.0))
|
||||
// Make this more or less align with the parameters column
|
||||
.right(Percentage(14.0));
|
||||
|
||||
fn view(&mut self) -> Element<'_, Self::Message> {
|
||||
GenericUi::new(&mut self.generic_ui_state, self.params.as_ref()).map(Message::ParamUpdate)
|
||||
}
|
||||
|
||||
fn background_color(&self) -> nih_plug_iced::Color {
|
||||
nih_plug_iced::Color {
|
||||
r: 0.98,
|
||||
g: 0.98,
|
||||
b: 0.98,
|
||||
a: 1.0,
|
||||
}
|
||||
}
|
||||
ScrollView::new(cx, 0.0, 0.0, false, true, |cx| {
|
||||
GenericUI::new(cx, Data::params);
|
||||
})
|
||||
.width(Percentage(100.0));
|
||||
})
|
||||
.row_between(Pixels(0.0))
|
||||
.child_left(Stretch(1.0))
|
||||
.child_right(Stretch(1.0));
|
||||
})
|
||||
}
|
||||
|
|
|
@ -23,7 +23,7 @@ compile_error!("Compiling without SIMD support is currently not supported");
|
|||
extern crate nih_plug;
|
||||
|
||||
use nih_plug::prelude::*;
|
||||
use nih_plug_iced::IcedState;
|
||||
use nih_plug_vizia::ViziaState;
|
||||
use std::pin::Pin;
|
||||
use std::simd::f32x2;
|
||||
use std::sync::atomic::{AtomicBool, Ordering};
|
||||
|
@ -50,7 +50,7 @@ const MAX_AUTOMATION_STEP_SIZE: u32 = 512;
|
|||
// - A proper GUI
|
||||
struct Diopser {
|
||||
params: Pin<Arc<DiopserParams>>,
|
||||
editor_state: Arc<IcedState>,
|
||||
editor_state: Arc<ViziaState>,
|
||||
|
||||
/// Needed for computing the filter coefficients.
|
||||
sample_rate: f32,
|
||||
|
|
Loading…
Add table
Reference in a new issue