mirror of
https://codeberg.org/unspeaker/tek.git
synced 2025-12-07 04:06:45 +01:00
cmdsys: focus enter
This commit is contained in:
parent
c551f83d5c
commit
31c1db8a5c
3 changed files with 28 additions and 9 deletions
|
|
@ -6,6 +6,8 @@ pub struct Arranger<E: Engine> {
|
||||||
pub jack: Arc<RwLock<JackClient>>,
|
pub jack: Arc<RwLock<JackClient>>,
|
||||||
/// Which view is focused
|
/// Which view is focused
|
||||||
pub focus_cursor: (usize, usize),
|
pub focus_cursor: (usize, usize),
|
||||||
|
/// Whether the focused view is entered
|
||||||
|
pub entered: bool,
|
||||||
/// Controls the JACK transport.
|
/// Controls the JACK transport.
|
||||||
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
||||||
/// Global timebase
|
/// Global timebase
|
||||||
|
|
@ -132,6 +134,7 @@ impl<E: Engine> Arranger<E> {
|
||||||
let mut app = Self {
|
let mut app = Self {
|
||||||
jack: jack.clone(),
|
jack: jack.clone(),
|
||||||
focus_cursor: (0, 1),
|
focus_cursor: (0, 1),
|
||||||
|
entered: false,
|
||||||
phrases_split: 20,
|
phrases_split: 20,
|
||||||
arrangement_split: 15,
|
arrangement_split: 15,
|
||||||
editor: PhraseEditor::new(),
|
editor: PhraseEditor::new(),
|
||||||
|
|
@ -271,13 +274,21 @@ impl<E: Engine> FocusGrid for Arranger<E> {
|
||||||
type Item = ArrangerFocus;
|
type Item = ArrangerFocus;
|
||||||
fn cursor (&self) -> (usize, usize) { self.focus_cursor }
|
fn cursor (&self) -> (usize, usize) { self.focus_cursor }
|
||||||
fn cursor_mut (&mut self) -> &mut (usize, usize) { &mut self.focus_cursor }
|
fn cursor_mut (&mut self) -> &mut (usize, usize) { &mut self.focus_cursor }
|
||||||
fn layout (&self) -> &[&[ArrangerFocus]] { &[
|
fn focus_enter (&mut self) { self.entered = true }
|
||||||
&[ArrangerFocus::Transport],
|
fn focus_exit (&mut self) { self.entered = false }
|
||||||
&[ArrangerFocus::Arrangement, ArrangerFocus::Arrangement],
|
fn entered (&self) -> Option<ArrangerFocus> {
|
||||||
&[ArrangerFocus::PhrasePool, ArrangerFocus::PhraseEditor],
|
if self.entered { Some(self.focused()) } else { None }
|
||||||
] }
|
}
|
||||||
|
fn layout (&self) -> &[&[ArrangerFocus]] {
|
||||||
|
use ArrangerFocus::*;
|
||||||
|
&[
|
||||||
|
&[Transport, Transport],
|
||||||
|
&[Arrangement, Arrangement],
|
||||||
|
&[PhrasePool, PhraseEditor],
|
||||||
|
]
|
||||||
|
}
|
||||||
fn update_focus (&mut self) {
|
fn update_focus (&mut self) {
|
||||||
let focused = *self.focused();
|
let focused = self.focused();
|
||||||
if let Some(transport) = self.transport.as_ref() {
|
if let Some(transport) = self.transport.as_ref() {
|
||||||
transport.write().unwrap().focused =
|
transport.write().unwrap().focused =
|
||||||
focused == ArrangerFocus::Transport
|
focused == ArrangerFocus::Transport
|
||||||
|
|
|
||||||
|
|
@ -10,8 +10,6 @@ pub type PhraseChunk = [Vec<PhraseMessage>];
|
||||||
pub struct Sequencer<E: Engine> {
|
pub struct Sequencer<E: Engine> {
|
||||||
/// JACK client handle (needs to not be dropped for standalone mode to work).
|
/// JACK client handle (needs to not be dropped for standalone mode to work).
|
||||||
pub jack: Arc<RwLock<JackClient>>,
|
pub jack: Arc<RwLock<JackClient>>,
|
||||||
/// Which view is focused
|
|
||||||
pub focus_cursor: (usize, usize),
|
|
||||||
/// Controls the JACK transport.
|
/// Controls the JACK transport.
|
||||||
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
||||||
/// Global timebase
|
/// Global timebase
|
||||||
|
|
@ -22,6 +20,10 @@ pub struct Sequencer<E: Engine> {
|
||||||
pub editor: PhraseEditor<E>,
|
pub editor: PhraseEditor<E>,
|
||||||
/// Phrase player
|
/// Phrase player
|
||||||
pub player: PhrasePlayer,
|
pub player: PhrasePlayer,
|
||||||
|
/// Which view is focused
|
||||||
|
pub focus_cursor: (usize, usize),
|
||||||
|
/// Whether the currently focused item is entered
|
||||||
|
pub entered: bool,
|
||||||
}
|
}
|
||||||
/// Sections in the sequencer app that may be focused
|
/// Sections in the sequencer app that may be focused
|
||||||
#[derive(Copy, Clone, PartialEq, Eq)] pub enum SequencerFocus {
|
#[derive(Copy, Clone, PartialEq, Eq)] pub enum SequencerFocus {
|
||||||
|
|
@ -172,8 +174,13 @@ impl<E: Engine> FocusGrid for Sequencer<E> {
|
||||||
&[SequencerFocus::Transport],
|
&[SequencerFocus::Transport],
|
||||||
&[SequencerFocus::PhrasePool, SequencerFocus::PhraseEditor],
|
&[SequencerFocus::PhrasePool, SequencerFocus::PhraseEditor],
|
||||||
] }
|
] }
|
||||||
|
fn focus_enter (&mut self) { self.entered = true }
|
||||||
|
fn focus_exit (&mut self) { self.entered = false }
|
||||||
|
fn entered (&self) -> Option<Self::Item> {
|
||||||
|
if self.entered { Some(self.focused()) } else { None }
|
||||||
|
}
|
||||||
fn update_focus (&mut self) {
|
fn update_focus (&mut self) {
|
||||||
let focused = *self.focused();
|
let focused = self.focused();
|
||||||
if let Some(transport) = self.transport.as_ref() {
|
if let Some(transport) = self.transport.as_ref() {
|
||||||
transport.write().unwrap().focused = focused == SequencerFocus::Transport
|
transport.write().unwrap().focused = focused == SequencerFocus::Transport
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@ impl SequencerCli {
|
||||||
let sequencer = Sequencer {
|
let sequencer = Sequencer {
|
||||||
jack: jack.clone(),
|
jack: jack.clone(),
|
||||||
focus_cursor: (1, 1),
|
focus_cursor: (1, 1),
|
||||||
|
entered: false,
|
||||||
phrases: Arc::new(RwLock::new(PhrasePool::new())),
|
phrases: Arc::new(RwLock::new(PhrasePool::new())),
|
||||||
editor: PhraseEditor::new(),
|
editor: PhraseEditor::new(),
|
||||||
clock: transport.clock.clone(),
|
clock: transport.clock.clone(),
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue