mirror of
https://codeberg.org/unspeaker/tek.git
synced 2025-12-06 19:56:42 +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>>,
|
||||
/// Which view is focused
|
||||
pub focus_cursor: (usize, usize),
|
||||
/// Whether the focused view is entered
|
||||
pub entered: bool,
|
||||
/// Controls the JACK transport.
|
||||
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
||||
/// Global timebase
|
||||
|
|
@ -132,6 +134,7 @@ impl<E: Engine> Arranger<E> {
|
|||
let mut app = Self {
|
||||
jack: jack.clone(),
|
||||
focus_cursor: (0, 1),
|
||||
entered: false,
|
||||
phrases_split: 20,
|
||||
arrangement_split: 15,
|
||||
editor: PhraseEditor::new(),
|
||||
|
|
@ -271,13 +274,21 @@ impl<E: Engine> FocusGrid for Arranger<E> {
|
|||
type Item = ArrangerFocus;
|
||||
fn cursor (&self) -> (usize, usize) { self.focus_cursor }
|
||||
fn cursor_mut (&mut self) -> &mut (usize, usize) { &mut self.focus_cursor }
|
||||
fn layout (&self) -> &[&[ArrangerFocus]] { &[
|
||||
&[ArrangerFocus::Transport],
|
||||
&[ArrangerFocus::Arrangement, ArrangerFocus::Arrangement],
|
||||
&[ArrangerFocus::PhrasePool, ArrangerFocus::PhraseEditor],
|
||||
] }
|
||||
fn focus_enter (&mut self) { self.entered = true }
|
||||
fn focus_exit (&mut self) { self.entered = false }
|
||||
fn entered (&self) -> Option<ArrangerFocus> {
|
||||
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) {
|
||||
let focused = *self.focused();
|
||||
let focused = self.focused();
|
||||
if let Some(transport) = self.transport.as_ref() {
|
||||
transport.write().unwrap().focused =
|
||||
focused == ArrangerFocus::Transport
|
||||
|
|
|
|||
|
|
@ -10,8 +10,6 @@ pub type PhraseChunk = [Vec<PhraseMessage>];
|
|||
pub struct Sequencer<E: Engine> {
|
||||
/// JACK client handle (needs to not be dropped for standalone mode to work).
|
||||
pub jack: Arc<RwLock<JackClient>>,
|
||||
/// Which view is focused
|
||||
pub focus_cursor: (usize, usize),
|
||||
/// Controls the JACK transport.
|
||||
pub transport: Option<Arc<RwLock<TransportToolbar<E>>>>,
|
||||
/// Global timebase
|
||||
|
|
@ -22,6 +20,10 @@ pub struct Sequencer<E: Engine> {
|
|||
pub editor: PhraseEditor<E>,
|
||||
/// Phrase player
|
||||
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
|
||||
#[derive(Copy, Clone, PartialEq, Eq)] pub enum SequencerFocus {
|
||||
|
|
@ -172,8 +174,13 @@ impl<E: Engine> FocusGrid for Sequencer<E> {
|
|||
&[SequencerFocus::Transport],
|
||||
&[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) {
|
||||
let focused = *self.focused();
|
||||
let focused = self.focused();
|
||||
if let Some(transport) = self.transport.as_ref() {
|
||||
transport.write().unwrap().focused = focused == SequencerFocus::Transport
|
||||
}
|
||||
|
|
|
|||
|
|
@ -23,6 +23,7 @@ impl SequencerCli {
|
|||
let sequencer = Sequencer {
|
||||
jack: jack.clone(),
|
||||
focus_cursor: (1, 1),
|
||||
entered: false,
|
||||
phrases: Arc::new(RwLock::new(PhrasePool::new())),
|
||||
editor: PhraseEditor::new(),
|
||||
clock: transport.clock.clone(),
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue