sequencer: stack, borders

This commit is contained in:
🪞👃🪞 2024-08-22 07:35:45 +03:00
parent 654aa0f041
commit 5ed5054e05

View file

@ -5,11 +5,17 @@ impl Sequencer {
const H_KEYS_OFFSET: usize = 5; const H_KEYS_OFFSET: usize = 5;
pub(crate) fn horizontal_draw (&self, buf: &mut Buffer, mut area: Rect) -> Usually<()> { pub(crate) fn horizontal_draw (&self, buf: &mut Buffer, mut area: Rect) -> Usually<()> {
SequenceStartEnd.render(buf, area)?; Split::down()
SequenceLoop.render(buf, area)?; .add(SequenceStartEnd)
SequenceRange.render(buf, area)?; .add(SequenceLoop)
.add(SequenceRange)
.render(buf, Rect { x: area.x, y: area.y, width: 15, height: area.height })?;
//SequenceRange.render(buf, area)?;
area.x = area.x + 15; area.x = area.x + 15;
area.width = area.width.saturating_sub(12); area.width = area.width.saturating_sub(15);
Lozenge(Style::default().fg(Nord::BG2)).draw(buf, area)?;
area.x = area.x + 1;
area.width = area.width.saturating_sub(1);
SequenceKeys(&self).render(buf, area)?; SequenceKeys(&self).render(buf, area)?;
if let Some(ref phrase) = self.phrase { if let Some(ref phrase) = self.phrase {
SequenceTimer(&self, phrase).render(buf, area)?; SequenceTimer(&self, phrase).render(buf, area)?;
@ -38,11 +44,11 @@ struct SequenceLoop;
impl Render for SequenceLoop { impl Render for SequenceLoop {
fn render (&self, buf: &mut Buffer, area: Rect) -> Usually<Rect> { fn render (&self, buf: &mut Buffer, area: Rect) -> Usually<Rect> {
let range = Rect { x: area.x, y: area.y + 4, width: 15, height: 5 }; let range = Rect { x: area.x, y: area.y, width: 15, height: 5 };
Lozenge(Style::default().fg(Nord::BG2)).draw(buf, range)?; Lozenge(Style::default().fg(Nord::BG2)).draw(buf, range)?;
"[ Loop off ] ".blit(buf, area.x + 1, area.y + 5, None)?; "[ Loop off ] ".blit(buf, area.x + 1, area.y + 1, None)?;
"Loop 1.1.1".blit(buf, area.x + 1, area.y + 6, None)?; "Loop 1.1.1".blit(buf, area.x + 1, area.y + 2, None)?;
"Length 1.0.0".blit(buf, area.x + 1, area.y + 7, None)?; "Length 1.0.0".blit(buf, area.x + 1, area.y + 3, None)?;
Ok(range) Ok(range)
} }
} }
@ -51,13 +57,13 @@ struct SequenceRange;
impl Render for SequenceRange { impl Render for SequenceRange {
fn render (&self, buf: &mut Buffer, area: Rect) -> Usually<Rect> { fn render (&self, buf: &mut Buffer, area: Rect) -> Usually<Rect> {
let range = Rect { x: area.x, y: area.y + 9, width: 15, height: 7 }; let range = Rect { x: area.x, y: area.y, width: 15, height: 7 };
Lozenge(Style::default().fg(Nord::BG2)).draw(buf, range)?; Lozenge(Style::default().fg(Nord::BG2)).draw(buf, range)?;
"Notes -------".blit(buf, area.x + 1, area.y + 10, None)?; "Notes -------".blit(buf, area.x + 1, area.y + 1, None)?;
"[ /2 ] [ x2 ]".blit(buf, area.x + 1, area.y + 11, None)?; "[ /2 ] [ x2 ]".blit(buf, area.x + 1, area.y + 2, None)?;
"[ Reverse ]".blit(buf, area.x + 1, area.y + 12, None)?; "[ Reverse ]".blit(buf, area.x + 1, area.y + 3, None)?;
"[ Invert ]".blit(buf, area.x + 1, area.y + 13, None)?; "[ Invert ]".blit(buf, area.x + 1, area.y + 4, None)?;
"[ Duplicate ]".blit(buf, area.x + 1, area.y + 14, None)?; "[ Duplicate ]".blit(buf, area.x + 1, area.y + 5, None)?;
Ok(area) Ok(area)
} }
} }