# ringtonePlayer (Ringtone Player) The **ringtonePlayer** module provides APIs for playing, configuring, and obtaining system ringtones. This module must work with [@ohos.multimedia.systemSoundManager](js-apis-systemSoundManager.md) to manage system ringtones. > **NOTE** > > The initial APIs of this module are supported since API version 10. Newly added APIs will be marked with a superscript to indicate their earliest API version. > > The APIs provided by this module are system APIs. ## Modules to Import ```ts import systemSoundManager from '@ohos.multimedia.systemSoundManager'; ``` ## RingtoneOptions Enumerates the ringtone parameters. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core | Name | Type |Mandatory | Description | | --------- | -------------- | ---- | --------------------------------- | | volume | number | Yes | Relative volume. The value ranges from 0.00 to 1.00. The value **1.00** indicates the maximum volume (100%).| | loop | boolean | Yes | Whether to enable loop playback. The value **true** means to enable loop playback, and **false** means the opposite.| ## RingtonePlayer Provides APIs for setting and obtaining system ringtone parameters as well as playing and stopping system ringtones. Before calling any API in **RingtonePlayer**, you must use [getSystemRingtonePlayer](js-apis-systemSoundManager.md#getsystemringtoneplayer) to create a **RingtonePlayer** instance. ### Attributes **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core | Name | Type | Readable| Writable| Description | | ----- | -------------------------- | ---- | ---- | ------------------ | | state | [media.AVPlayerState](js-apis-media.md#avplayerstate9) | Yes | No | Audio renderer state.| **Example** ```ts import media from '@ohos.multimedia.media'; let state: media.AVPlayerState = systemRingtonePlayer.state; ``` ### getTitle getTitle(callback: AsyncCallback<string>): void Obtains the title of a system ringtone. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | callback | AsyncCallback<string> | Yes | Callback used to return the ringtone title obtained. | **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.getTitle((err: BusinessError, value: string) => { if (err) { console.error(`Failed to get system ringtone title. ${err}`); return; } console.info(`Callback invoked to indicate the value of the system ringtone title is obtained ${value}.`); }); ``` ### getTitle getTitle(): Promise<string> Obtains the title of a system ringtone. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Return value** | Type | Description | | --------------------- | -------------------------------- | | Promise<string> | Promise used to return the ringtone title obtained.| **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.getTitle().then((value: string) => { console.info(`Promise returned to indicate that the value of the system ringtone title is obtained ${value}.`); }).catch ((err: BusinessError) => { console.error(`Failed to get the system ringtone title ${err}`); }); ``` ### getAudioRendererInfo getAudioRendererInfo(callback: AsyncCallback<audio.AudioRendererInfo>): void Obtains the information about the audio renderer used by the ringtone. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | callback | AsyncCallback<[audio.AudioRendererInfo](js-apis-audio.md#audiorendererinfo8)> | Yes| Callback used to return the audio renderer information obtained.| **Example** ```ts import audio from '@ohos.multimedia.audio'; import { BusinessError } from '@ohos.base'; let audioRendererInfo: audio.AudioRendererInfo | undefined = undefined; systemRingtonePlayer.getAudioRendererInfo((err: BusinessError, value: audio.AudioRendererInfo) => { if (err) { console.error(`Failed to get ringtone AudioRendererInfo. ${err}`); return; } console.info(`Callback invoked to indicate the value of the ringtone AudioRendererInfo is obtained.`); audioRendererInfo = value; }); ``` ### getAudioRendererInfo getAudioRendererInfo(): Promise<audio.AudioRendererInfo> Obtains the information about the audio renderer used by the ringtone. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Return value** | Type | Description | | ------------------- | ------------------------------- | | Promise<[audio.AudioRendererInfo](js-apis-audio.md#audiorendererinfo8)> | Promise used to return the audio renderer information obtained.| **Example** ```ts import audio from '@ohos.multimedia.audio'; import { BusinessError } from '@ohos.base'; let audioRendererInfo: audio.AudioRendererInfo | undefined = undefined; systemRingtonePlayer.getAudioRendererInfo().then((value: audio.AudioRendererInfo) => { console.info(`Promise returned to indicate that the value of the ringtone AudioRendererInfo is obtained ${value}.`); audioRendererInfo = value; }).catch ((err: BusinessError) => { console.error(`Failed to get the ringtone AudioRendererInfo ${err}`); }); ``` ### configure configure(options: RingtoneOptions, callback: AsyncCallback<void>): void Sets ringtone parameters. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | options | [RingtoneOptions](#ringtoneoptions) | Yes | Ringtone parameters. | | callback | AsyncCallback<void> | Yes | Callback used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; class RingtoneOptions { volume: number = 0; loop: boolean = false; } let ringtoneOptions: RingtoneOptions = {volume: 0.5, loop: true}; systemRingtonePlayer.configure(ringtoneOptions, (err: BusinessError) => { if (err) { console.error(`Failed to configure ringtone options. ${err}`); return; } console.info(`Callback invoked to indicate a successful setting of ringtone options.`); }); ``` ### configure configure(options: RingtoneOptions): Promise<void> Sets ringtone parameters. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | options | [RingtoneOptions](#ringtoneoptions) | Yes | Ringtone parameters. | **Return value** | Type | Description | | ------------------- | ------------------------------- | | Promise<void> | Promise used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; class RingtoneOptions { volume: number = 0; loop: boolean = false; } let ringtoneOptions: RingtoneOptions = {volume: 0.5, loop: true}; systemRingtonePlayer.configure(ringtoneOptions).then(() => { console.info(`Promise returned to indicate a successful setting of ringtone options.`); }).catch ((err: BusinessError) => { console.error(`Failed to configure ringtone options. ${err}`); }); ``` ### start start(callback: AsyncCallback<void>): void Starts playing the ringtone. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | callback | AsyncCallback<void> | Yes | Callback used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.start((err: BusinessError) => { if (err) { console.error(`Failed to start playing ringtone. ${err}`); return; } console.info(`Callback invoked to indicate a successful starting of ringtone.`); }); ``` ### start start(): Promise<void> Starts playing the ringtone. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Return value** | Type | Description | | ------------------- | -------------------------------- | | Promise<void> | Promise used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.start().then(() => { console.info(`Promise returned to indicate a successful starting of ringtone.`); }).catch ((err: BusinessError) => { console.error(`Failed to start playing ringtone. ${err}`); }); ``` ### stop stop(callback: AsyncCallback<void>): void Stops playing the ringtone. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | callback | AsyncCallback<void> | Yes | Callback used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.stop((err: BusinessError) => { if (err) { console.error(`Failed to stop playing ringtone. ${err}`); return; } console.info(`Callback invoked to indicate a successful stopping of ringtone.`); }); ``` ### stop stop(): Promise<void> Stops playing the ringtone. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Return value** | Type | Description | | ------------------- | -------------------------------- | | Promise<void> | Promise used to return the result.| **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.stop().then(() => { console.info(`Promise returned to indicate a successful stopping of ringtone.`); }).catch ((err: BusinessError) => { console.error(`Failed to stop playing ringtone. ${err}`); }); ``` ### release release(callback: AsyncCallback<void>): void Releases the ringtone player. This API uses an asynchronous callback to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | -----------------------------------------| ---- | ------------------------- | | callback | AsyncCallback<void> | Yes | Callback used to return the result. | **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.release((err: BusinessError) => { if (err) { console.error(`Failed to release ringtone player. ${err}`); return; } console.info(`Callback invoked to indicate a successful releasing of ringtone player.`); }); ``` ### release release(): Promise<void> Releases the ringtone player. This API uses a promise to return the result. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Return value** | Type | Description | | ------------------- | ------------------------------- | | Promise<void> | Promise used to return the result. | **Example** ```ts import { BusinessError } from '@ohos.base'; systemRingtonePlayer.release().then(() => { console.info(`Promise returned to indicate a successful releasing of ringtone player.`); }).catch ((err: BusinessError) => { console.error(`Failed to release ringtone player. ${err}`); }); ``` ### on('audioInterrupt') on(type: 'audioInterrupt', callback: Callback<audio.InterruptEvent>): void Subscribes to audio interruption events. This API uses a callback to obtain interrupt events. **System API**: This is a system API. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name | Type | Mandatory| Description | | -------- | ----------------------- | ---- | -------------------------------------------------------------------------- | | type | string | Yes | Event type. The value **'audioInterrupt'** means the audio interruption event, which is triggered when audio rendering is interrupted.| | callback | Callback<[audio.InterruptEvent](js-apis-audio.md#interruptevent9)> | Yes | Callback used to return the audio interruption event. | **Error codes** For details about the error codes, see [Audio Error Codes](../errorcodes/errorcode-audio.md). | ID| Error Message| | ------- | --------------------------------------------| | 401 | if input parameter type or number mismatch | | 6800101 | if input parameter value error | **Example** ```ts import audio from '@ohos.multimedia.audio'; let isPlaying: boolean; // An identifier specifying whether rendering is in progress. let isDucked: boolean; // An identifier specifying whether the audio volume is reduced. systemRingtonePlayer.on('audioInterrupt', async(interruptEvent: audio.InterruptEvent) => { if (interruptEvent.forceType == audio.InterruptForceType.INTERRUPT_FORCE) { // The system forcibly interrupts audio rendering. The application must update the status and displayed content accordingly. switch (interruptEvent.hintType) { case audio.InterruptHint.INTERRUPT_HINT_PAUSE: // The audio stream has been paused and temporarily loses the focus. It will receive the interruptEvent corresponding to resume when it is able to regain the focus. console.info('Force paused. Update playing status and stop writing'); isPlaying = false; // A simplified processing indicating several operations for switching the application to the paused state. break; case audio.InterruptHint.INTERRUPT_HINT_STOP: // The audio stream has been stopped and permanently loses the focus. The user must manually trigger the operation to resume rendering. console.info('Force stopped. Update playing status and stop writing'); isPlaying = false; // A simplified processing indicating several operations for switching the application to the paused state. break; case audio.InterruptHint.INTERRUPT_HINT_DUCK: // The audio stream is rendered at a reduced volume. console.info('Force ducked. Update volume status'); isDucked = true; // A simplified processing indicating several operations for updating the volume status. break; case audio.InterruptHint.INTERRUPT_HINT_UNDUCK: // The audio stream is rendered at the normal volume. console.info('Force ducked. Update volume status'); isDucked = false; // A simplified processing indicating several operations for updating the volume status. break; default: break; } } else if (interruptEvent.forceType == audio.InterruptForceType.INTERRUPT_SHARE) { // The application can choose to take action or ignore. switch (interruptEvent.hintType) { case audio.InterruptHint.INTERRUPT_HINT_RESUME: // It is recommended that the application continue rendering. (The audio stream has been forcibly paused and temporarily lost the focus. It can resume rendering now.) console.info('Resume force paused renderer or ignore'); // To continue rendering, the application must perform the required operations. break; default: break; } } }); ``` ### off('audioInterrupt') 10+ off(type: 'audioInterrupt'): void Unsubscribes from audio interruption events. **System capability**: SystemCapability.Multimedia.SystemSound.Core **Parameters** | Name| Type | Mandatory| Description | | :----- | :----- | :--- | :------------------------------------------------ | | type | string | Yes | Event type. The value is fixed at **'audioInterrupt'**.| **Error codes** For details about the error codes, see [Audio Error Codes](../errorcodes/errorcode-audio.md). | ID| Error Message| | ------- | --------------------------------------------| | 401 | if input parameter type or number mismatch | | 6800101 | if input parameter value error | **Example** ```ts systemRingtonePlayer.off('audioInterrupt'); ```