Condividi tramite


Personalizzare i pulsanti

Per implementare le azioni personalizzate o modificare il layout dei pulsanti correnti, è possibile interagire con l'API della libreria dell'interfaccia utente nativa. Questa API comporta la definizione di configurazioni dei pulsanti personalizzate, specificando le azioni e gestendo le azioni correnti della barra dei pulsanti. L'API offre metodi per aggiungere azioni personalizzate e rimuovere pulsanti esistenti, tutti accessibili tramite semplici chiamate di funzioni.

Questa funzionalità offre un livello elevato di personalizzazione e garantisce che l'interfaccia utente rimanga coesa e coerente rispetto al design complessivo dell'applicazione.

Prerequisiti

Configurare la funzionalità

Rimuovere pulsanti

CallCompositeCallScreenControlBarOptions, consente la flessibilità di personalizzare i pulsanti rimuovendo pulsanti specifici, ad esempio fotocamera, microfono e controlli audio. Questa API consente di personalizzare l'interfaccia utente in base ai requisiti specifici dell'applicazione e alla progettazione dell'esperienza utente. Basta impostare visible o enabled su false per CallCompositeButtonViewData per nascondere o disabilitare il pulsante.

Screenshot che mostra l'esperienza di rimozione dei pulsanti nella libreria dell'interfaccia utente.

val controlBarOptions = CallCompositeCallScreenControlBarOptions()

val cameraButton = CallCompositeButtonViewData()
    .setVisible(false)

controlBarOptions.setCameraButton(cameraButton)

val callScreenOptions = CallCompositeCallScreenOptions()
    .setControlBarOptions(controlBarOptions)

val localOptions = CallCompositeLocalOptions()
    .setCallScreenOptions(callScreenOptions)

val callComposite = CallCompositeBuilder()
    .build()

callComposite.launch(context, locator, localOptions)

Il pulsante può essere aggiornato dopo l'avvio della chiamata composita.

cameraButton.setVisible(true)

Aggiungere azioni personalizzate

Call composite usa icone dell'interfaccia utente di Fluent. È possibile scaricare le icone direttamente dal repository GitHub dell'interfaccia utente di Fluent e incorporarle direttamente nel progetto, secondo necessità. Questo approccio garantisce una coerenza visiva tra tutti gli elementi dell'interfaccia utente, migliorando l'esperienza utente complessiva.

Screenshot che mostra l'esperienza quando si aggiunge un nuovo pulsante alla libreria dell'interfaccia utente.


// Custom header button
val headerCustomButton =
    CallCompositeCustomButtonViewData(
        "headerCustomButton",
        R.drawable.my_header_button_icon,
        "My header button",
        fun(it: CallCompositeCustomButtonClickEvent) {
            // process my button onClick
        }
    )

val headerOptions = CallCompositeCallScreenHeaderViewData()
    .setCustomButtons(listOf(headerCustomButton))

// Custom control bar button
val controlBarOptions = CallCompositeCallScreenControlBarOptions()

controlBarOptions.setCustomButtons(
    listOf(
        CallCompositeCustomButtonViewData(
            "customButtonId",
            R.drawable.my_button_image,
            "My button",
            fun(it: CallCompositeCustomButtonClickEvent) {
                // Process my button onClick
            },
        )
    )
)

val callScreenOptions = CallCompositeCallScreenOptions()
    .setHeaderViewData(headerOptions)
    .setControlBarOptions(controlBarOptions)

val localOptions = CallCompositeLocalOptions()
    .setCallScreenOptions(callScreenOptions)

val callComposite = CallCompositeBuilder()
    .build()

callComposite.launch(context, locator, localOptions)

Analogamente ai pulsanti forniti Call composite, i pulsanti personalizzati sono aggiornabili dopo l'avvio.

customButton.setVisible(true)

Rimuovere o disabilitare i pulsanti

CallScreenControlBarOptions, consente la flessibilità di personalizzare i pulsanti rimuovendo pulsanti specifici, ad esempio fotocamera, microfono e controlli audio. Questa API consente di personalizzare l'interfaccia utente in base ai requisiti specifici dell'applicazione e alla progettazione dell'esperienza utente. Basta impostare visible o enabled su false per ButtonViewData per nascondere o disabilitare il pulsante.

Screenshot che mostra l'esperienza di rimozione dei pulsanti nella libreria dell'interfaccia utente.

let cameraButton = ButtonViewData(visible: false)

let callScreenControlBarOptions = CallScreenControlBarOptions(
    cameraButton: cameraButton
)

let callScreenOptions = CallScreenOptions(controlBarOptions: callScreenControlBarOptions)
let localOptions = LocalOptions(callScreenOptions: callScreenOptions)

let callComposite = CallComposite(credential: credential)
callComposite.launch(locator: .roomCall(roomId: "..."), localOptions: localOptions)

Il pulsante può essere aggiornato dopo l'avvio della chiamata composita.

cameraButton.visible = true

Aggiungere azioni personalizzate

Call composite usa icone dell'interfaccia utente di Fluent. È possibile scaricare le icone direttamente dal repository GitHub dell'interfaccia utente di Fluent e incorporarle direttamente nel progetto, secondo necessità. Questo approccio garantisce una coerenza visiva tra tutti gli elementi dell'interfaccia utente, migliorando l'esperienza utente complessiva.

Screenshot che mostra l'esperienza quando si aggiunge un nuovo pulsante alla libreria dell'interfaccia utente.

// Custom header button
let headerCustomButton = CustomButtonViewData(image: UIImage(named: "...")!,
                                              title: "My header button") {_ in
    // Process my button onClick
}
let callScreenHeaderViewData = CallScreenHeaderViewData(
    customButtons: [headerCustomButton]
)

// Custom control bar button
let customButton = CustomButtonViewData(image: UIImage(named: "...")!,
                                        title: "My button") {_ in
    // Process my button onClick
}

let callScreenControlBarOptions = CallScreenControlBarOptions(
    customButtons: [customButton]
)

let callScreenOptions = CallScreenOptions(
    controlBarOptions: callScreenControlBarOptions, headerViewData: callScreenHeaderViewData)

let localOptions = LocalOptions(callScreenOptions: callScreenOptions)

let callComposite = CallComposite(credential: credential)
callComposite.launch(locator: .roomCall(roomId: "..."), localOptions: localOptions)

Analogamente ai pulsanti forniti Call composite, i pulsanti personalizzati sono aggiornabili dopo l'avvio.

customButton.enabled = true

Passaggi successivi