Rename AudioSinkPlayback::toggle to toggle_playback (#16837)
# Objective - #16813 added the ability to mute sinks and added a new method `toggle_mute()`. - Leaving `toggle()` as is creates inconsistency and a bit of confusion about what is being toggled. ## Solution - Rename `toggle()` to `toggle_playback()`. - The choice to use the `_playback` suffix was easy because the method comment was already telling us what is being toggled: `Toggles playback of the sink.` - [Raised in Discord] and got the OK from Alice. [Raised in Discord]: https://discord.com/channels/691052431525675048/749430447326625812/1318000355824504905 ## Testing - I ran the example and also updated the instruction text to make it clear `Space` is toggling the playback not just pausing. - I added a unit test for `toggle_playback()` because why not. --- ## Showcase Example instructions: <img width="292" alt="image" src="https://github.com/user-attachments/assets/585c36c6-c4d7-428b-acbe-a92f3a37b460" /> ## Migration Guide - `AudioSinkPlayback`'s `toggle` method has been renamed to `toggle_playback`. This was done to create consistency with the `toggle_mute` method added in https://github.com/bevyengine/bevy/pull/16813. Change instances of `toggle` to `toggle_playback`. E.g.: Before: ```rust fn pause(keyboard_input: Res<ButtonInput<KeyCode>>, sink: Single<&AudioSink>) { if keyboard_input.just_pressed(KeyCode::Space) { sink.toggle(); } } ``` After: ```rust fn pause(keyboard_input: Res<ButtonInput<KeyCode>>, sink: Single<&AudioSink>) { if keyboard_input.just_pressed(KeyCode::Space) { sink.toggle_playback(); } } ```
This commit is contained in:
		
							parent
							
								
									56688b387c
								
							
						
					
					
						commit
						90b2ba1859
					
				| @ -58,10 +58,11 @@ pub trait AudioSinkPlayback { | |||||||
|     /// A paused sink can be resumed with [`play`](Self::play).
 |     /// A paused sink can be resumed with [`play`](Self::play).
 | ||||||
|     fn pause(&self); |     fn pause(&self); | ||||||
| 
 | 
 | ||||||
|     /// Toggles the playback of this sink.
 |     /// Toggles playback of the sink.
 | ||||||
|     ///
 |     ///
 | ||||||
|     /// Will pause if playing, and will be resumed if paused.
 |     /// If the sink is paused, toggling playback resumes it. If the sink is
 | ||||||
|     fn toggle(&self) { |     /// playing, toggling playback pauses it.
 | ||||||
|  |     fn toggle_playback(&self) { | ||||||
|         if self.is_paused() { |         if self.is_paused() { | ||||||
|             self.play(); |             self.play(); | ||||||
|         } else { |         } else { | ||||||
| @ -69,7 +70,7 @@ pub trait AudioSinkPlayback { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// Is this sink paused?
 |     /// Returns true if the sink is paused.
 | ||||||
|     ///
 |     ///
 | ||||||
|     /// Sinks can be paused and resumed using [`pause`](Self::pause) and [`play`](Self::play).
 |     /// Sinks can be paused and resumed using [`pause`](Self::pause) and [`play`](Self::play).
 | ||||||
|     fn is_paused(&self) -> bool; |     fn is_paused(&self) -> bool; | ||||||
| @ -338,13 +339,20 @@ mod tests { | |||||||
|         audio_sink.set_speed(1.0); |         audio_sink.set_speed(1.0); | ||||||
|         assert_eq!(audio_sink.speed(), 1.0); |         assert_eq!(audio_sink.speed(), 1.0); | ||||||
| 
 | 
 | ||||||
|         // Test pause
 |         // Test playback
 | ||||||
|         assert!(!audio_sink.is_paused()); // default pause state
 |         assert!(!audio_sink.is_paused()); // default pause state
 | ||||||
|         audio_sink.pause(); |         audio_sink.pause(); | ||||||
|         assert!(audio_sink.is_paused()); |         assert!(audio_sink.is_paused()); | ||||||
|         audio_sink.play(); |         audio_sink.play(); | ||||||
|         assert!(!audio_sink.is_paused()); |         assert!(!audio_sink.is_paused()); | ||||||
| 
 | 
 | ||||||
|  |         // Test toggle playback
 | ||||||
|  |         audio_sink.pause(); // start paused
 | ||||||
|  |         audio_sink.toggle_playback(); | ||||||
|  |         assert!(!audio_sink.is_paused()); | ||||||
|  |         audio_sink.toggle_playback(); | ||||||
|  |         assert!(audio_sink.is_paused()); | ||||||
|  | 
 | ||||||
|         // Test mute
 |         // Test mute
 | ||||||
|         assert!(!audio_sink.is_muted()); // default mute state
 |         assert!(!audio_sink.is_muted()); // default mute state
 | ||||||
|         audio_sink.mute(); |         audio_sink.mute(); | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ fn setup(mut commands: Commands, asset_server: Res<AssetServer>) { | |||||||
| 
 | 
 | ||||||
|     // example instructions
 |     // example instructions
 | ||||||
|     commands.spawn(( |     commands.spawn(( | ||||||
|         Text::new("-/=: Volume Down/Up\nSpace: Pause Playback\nM: Toggle Mute"), |         Text::new("-/=: Volume Down/Up\nSpace: Toggle Playback\nM: Toggle Mute"), | ||||||
|         Node { |         Node { | ||||||
|             position_type: PositionType::Absolute, |             position_type: PositionType::Absolute, | ||||||
|             bottom: Val::Px(12.0), |             bottom: Val::Px(12.0), | ||||||
| @ -40,7 +40,7 @@ fn update_speed(sink: Single<&AudioSink, With<MyMusic>>, time: Res<Time>) { | |||||||
| 
 | 
 | ||||||
| fn pause(keyboard_input: Res<ButtonInput<KeyCode>>, sink: Single<&AudioSink, With<MyMusic>>) { | fn pause(keyboard_input: Res<ButtonInput<KeyCode>>, sink: Single<&AudioSink, With<MyMusic>>) { | ||||||
|     if keyboard_input.just_pressed(KeyCode::Space) { |     if keyboard_input.just_pressed(KeyCode::Space) { | ||||||
|         sink.toggle(); |         sink.toggle_playback(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 mgi388
						mgi388