mirror of
				https://github.com/johrpan/musicus.git
				synced 2025-10-26 19:57:25 +01:00 
			
		
		
		
	player bar: hook up controls
This commit is contained in:
		
							parent
							
								
									25dc8e2779
								
							
						
					
					
						commit
						9489aaf2ee
					
				
					 3 changed files with 81 additions and 19 deletions
				
			
		|  | @ -16,6 +16,12 @@ mod imp { | |||
|         pub playlist: OnceCell<gio::ListStore>, | ||||
|         #[property(get, set = Self::set_current_index)] | ||||
|         pub current_index: Cell<u32>, | ||||
|         #[property(get, set)] | ||||
|         pub current_time: Cell<u32>, | ||||
|         #[property(get, set)] | ||||
|         pub remaining_time: Cell<u32>, | ||||
|         #[property(get, set = Self::set_position)] | ||||
|         pub position: Cell<f64>, | ||||
|     } | ||||
| 
 | ||||
|     impl MusicusPlayer { | ||||
|  | @ -36,6 +42,10 @@ mod imp { | |||
|                     .set_is_playing(true); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         pub fn set_position(&self, position: f64) { | ||||
|             self.position.set(position); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     #[glib::object_subclass] | ||||
|  | @ -59,6 +69,9 @@ impl MusicusPlayer { | |||
|             .property("playing", false) | ||||
|             .property("playlist", gio::ListStore::new::<PlaylistItem>()) | ||||
|             .property("current-index", 0u32) | ||||
|             .property("current-time", 0u32) | ||||
|             .property("remaining-time", 10000u32) | ||||
|             .property("position", 0.0) | ||||
|             .build() | ||||
|     } | ||||
| 
 | ||||
|  | @ -88,6 +101,18 @@ impl MusicusPlayer { | |||
|             .item(imp.current_index.get()) | ||||
|             .and_downcast::<PlaylistItem>() | ||||
|     } | ||||
| 
 | ||||
|     pub fn next(&self) { | ||||
|         if self.current_index() < self.playlist().n_items() - 1 { | ||||
|             self.set_current_index(self.current_index() + 1); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     pub fn previous(&self) { | ||||
|         if self.current_index() > 0 { | ||||
|             self.set_current_index(self.current_index() - 1); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl Default for MusicusPlayer { | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| use crate::player::MusicusPlayer; | ||||
| use gtk::{ | ||||
|     glib::{self, subclass::Signal, Properties}, | ||||
|     glib::{self, clone, subclass::Signal, Properties}, | ||||
|     prelude::*, | ||||
|     subclass::prelude::*, | ||||
| }; | ||||
|  | @ -37,6 +37,28 @@ mod imp { | |||
|         pub remaining_time_label: TemplateChild<gtk::Label>, | ||||
|     } | ||||
| 
 | ||||
|     impl PlayerBar { | ||||
|         fn update(&self) { | ||||
|             if let Some(item) = self.player.borrow().current_item() { | ||||
|                 let mut title = item.title(); | ||||
| 
 | ||||
|                 if let Some(part_title) = item.part_title() { | ||||
|                     title.push_str(": "); | ||||
|                     title.push_str(&part_title); | ||||
|                 } | ||||
| 
 | ||||
|                 self.title_label.set_label(&title); | ||||
| 
 | ||||
|                 if let Some(performances) = item.performers() { | ||||
|                     self.subtitle_label.set_label(&performances); | ||||
|                     self.subtitle_label.set_visible(true); | ||||
|                 } else { | ||||
|                     self.subtitle_label.set_visible(false); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     #[glib::object_subclass] | ||||
|     impl ObjectSubclass for PlayerBar { | ||||
|         const NAME: &'static str = "MusicusPlayerBar"; | ||||
|  | @ -82,27 +104,30 @@ mod imp { | |||
|                 .sync_create() | ||||
|                 .build(); | ||||
| 
 | ||||
|             let title_label = self.title_label.get(); | ||||
|             let subtitle_label = self.subtitle_label.get(); | ||||
|             player.connect_current_index_notify(move |player| { | ||||
|                 if let Some(item) = player.current_item() { | ||||
|                     let mut title = item.title(); | ||||
|             let obj = self.obj().clone(); | ||||
| 
 | ||||
|                     if let Some(part_title) = item.part_title() { | ||||
|                         title.push_str(": "); | ||||
|                         title.push_str(&part_title); | ||||
|                     } | ||||
|             player.connect_current_index_notify(clone!(@weak obj => move |_| obj.imp().update())); | ||||
|             player | ||||
|                 .playlist() | ||||
|                 .connect_items_changed(clone!(@weak obj => move |_, _, _, _| obj.imp().update())); | ||||
| 
 | ||||
|                     title_label.set_label(&title); | ||||
|             player | ||||
|                 .bind_property("current-time", &self.current_time_label.get(), "label") | ||||
|                 .transform_to(|_, t: u32| Some(format!("{:0>2}:{:0>2}", t / 60, t % 60))) | ||||
|                 .sync_create() | ||||
|                 .build(); | ||||
| 
 | ||||
|                     if let Some(performances) = item.performers() { | ||||
|                         subtitle_label.set_label(&performances); | ||||
|                         subtitle_label.set_visible(true); | ||||
|                     } else { | ||||
|                         subtitle_label.set_visible(false); | ||||
|                     } | ||||
|                 } | ||||
|             }); | ||||
|             player | ||||
|                 .bind_property("remaining-time", &self.remaining_time_label.get(), "label") | ||||
|                 .transform_to(|_, t: u32| Some(format!("{:0>2}:{:0>2}", t / 60, t % 60))) | ||||
|                 .sync_create() | ||||
|                 .build(); | ||||
| 
 | ||||
|             player | ||||
|                 .bind_property("position", &self.slider.adjustment(), "value") | ||||
|                 .sync_create() | ||||
|                 .bidirectional() | ||||
|                 .build(); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -137,11 +162,21 @@ impl PlayerBar { | |||
|         self.imp().playlist_button.set_active(false); | ||||
|     } | ||||
| 
 | ||||
|     #[template_callback] | ||||
|     fn previous(&self, _: >k::Button) { | ||||
|         self.player().previous(); | ||||
|     } | ||||
| 
 | ||||
|     #[template_callback] | ||||
|     fn show_playlist(&self, button: >k::ToggleButton) { | ||||
|         self.emit_by_name::<()>("show-playlist", &[&button.is_active()]); | ||||
|     } | ||||
| 
 | ||||
|     #[template_callback] | ||||
|     fn next(&self, _: >k::Button) { | ||||
|         self.player().next(); | ||||
|     } | ||||
| 
 | ||||
|     #[template_callback] | ||||
|     fn play_pause(&self, _: >k::Button) { | ||||
|         let player = self.player(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue