Merge pull request #3160 from saghul/mobile-sounds-loop

Mobile looping sounds
This commit is contained in:
Zoltan Bettenbuk 2018-06-22 17:48:13 +02:00 committed by GitHub
commit b5e9c71865
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 36 additions and 16 deletions

View File

@ -15,6 +15,7 @@ import {
participantConnectionStatusChanged,
participantJoined,
participantLeft,
participantPresenceChanged,
participantRoleChanged,
participantUpdated
} from '../participants';
@ -146,6 +147,7 @@ function _addConferenceListeners(conference, dispatch) {
conference,
id,
name: user.getDisplayName(),
presence: user.getStatus(),
role: user.getRole()
})));
conference.on(
@ -155,6 +157,9 @@ function _addConferenceListeners(conference, dispatch) {
conference.on(
JitsiConferenceEvents.USER_ROLE_CHANGED,
(...args) => dispatch(participantRoleChanged(...args)));
conference.on(
JitsiConferenceEvents.USER_STATUS_CHANGED,
(...args) => dispatch(participantPresenceChanged(...args)));
conference.addCommandListener(
AVATAR_ID_COMMAND,

View File

@ -10,7 +10,8 @@ export type AudioElement = {
currentTime?: number,
pause: () => void,
play: () => void,
setSinkId?: string => void
setSinkId?: string => void,
stop: () => void
};
/**
@ -61,8 +62,6 @@ export default class AbstractAudio extends Component<Props> {
this.setAudioElementImpl = this.setAudioElementImpl.bind(this);
}
pause: () => void;
/**
* Attempts to pause the playback of the media.
*
@ -73,10 +72,8 @@ export default class AbstractAudio extends Component<Props> {
this._audioElementImpl && this._audioElementImpl.pause();
}
play: () => void;
/**
* Attempts to being the playback of the media.
* Attempts to begin the playback of the media.
*
* @public
* @returns {void}
@ -106,8 +103,6 @@ export default class AbstractAudio extends Component<Props> {
typeof setRef === 'function' && setRef(element ? this : null);
}
setSinkId: string => void;
/**
* Sets the sink ID (output device ID) on the underlying audio element.
* NOTE: Currently, implemented only on Web.
@ -120,4 +115,14 @@ export default class AbstractAudio extends Component<Props> {
&& typeof this._audioElementImpl.setSinkId === 'function'
&& this._audioElementImpl.setSinkId(sinkId);
}
/**
* Attempts to stop the playback of the media.
*
* @public
* @returns {void}
*/
stop(): void {
this._audioElementImpl && this._audioElementImpl.stop();
}
}

View File

@ -12,11 +12,10 @@ const logger = require('jitsi-meet-logger').getLogger(__filename);
* {@link RTCView}.
*/
export default class Audio extends AbstractAudio {
/**
* Reference to 'react-native-sound} {@link Sound} instance.
*/
_sound: Sound
_sound: ?Sound;
/**
* A callback passed to the 'react-native-sound''s {@link Sound} instance,
@ -56,9 +55,22 @@ export default class Audio extends AbstractAudio {
*/
componentWillUnmount() {
if (this._sound) {
this.setAudioElementImpl(null);
this._sound.release();
this._sound = null;
this.setAudioElementImpl(null);
}
}
/**
* Attempts to begin the playback of the media.
*
* @inheritdoc
* @override
*/
play() {
if (this._sound) {
this._sound.setNumberOfLoops(this.props.loop ? -1 : 0);
super.play();
}
}
@ -81,10 +93,8 @@ export default class Audio extends AbstractAudio {
* @returns {void}
*/
stop() {
// Currently not implemented for mobile. If needed, a possible
// implementation is:
// if (this._sound) {
// this._sound.stop();
// }
if (this._sound) {
this._sound.stop();
}
}
}