// Diopser: a phase rotation plugin // Copyright (C) 2021-2022 Robbert van der Helm // // 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 3 of the License, or // (at your option) 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. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . 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>, } 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 { ViziaState::from_size(380, 305) } pub(crate) fn create( params: Pin>, editor_state: Arc, ) -> Option> { create_vizia_editor(editor_state, move |cx| { Data { params: params.clone(), } .build(cx); 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(12.0)); // See the Crisp generic UI for an example using a ScrollView GenericUI::new(cx, Data::params) .width(Percentage(100.0)) .child_top(Pixels(5.0)); }) .width(Percentage(100.0)) .row_between(Pixels(0.0)) .child_left(Stretch(1.0)) .child_right(Stretch(1.0)); }) }