O Jetpack Compose oferece suporte ao recurso de arrastar e soltar usando dois modificadores:
dragAndDropSource
: especifica um elemento combinável como o ponto de partida do gesto de arrastar.dragAndDropTarget
: especifica um elemento combinável que aceita os dados soltados.
Por exemplo, para permitir que os usuários arrastem uma imagem no app, crie um elemento combinável
de imagem e adicione o modificador dragAndDropSource
. Para configurar um destino de soltar,
crie outro elemento combinável de imagem e adicione o modificador dragAndDropTarget
.
Os modificadores podem ser aplicados a várias origens de arrastar e vários destinos de soltar.
Os modificadores permitem que os apps compartilhem dados entre dois ou mais elementos combináveis usando
ClipData
, que é interoperável com implementações de View
.
Especificar uma origem da ação de arrastar
Para ativar eventos de arrastar dentro de um componente, adicione o modificador dragAndDropSource
.
Ele usa uma função como parâmetro. Dentro dessa função, use
DragAndDropTransferData
para representar os dados transferíveis. Os dados podem
ser um URI remoto, dados de rich text na área de transferência, um arquivo local ou muito mais, mas
todos precisam ser unidos em um objeto ClipData
. Forneça texto simples, por
exemplo, da seguinte maneira:
Modifier.dragAndDropSource { _ -> DragAndDropTransferData( ClipData.newPlainText( "image Url", url ) ) }
Para permitir que a ação de arrastar cruze as bordas do app, o
construtor DragAndDropTransferData
aceita um argumento flags
. No
exemplo abaixo, a constante DRAG_FLAG_GLOBAL
especifica que os dados podem
ser arrastados de um app para outro:
Modifier.dragAndDropSource { _ -> DragAndDropTransferData( ClipData.newPlainText( "image Url", url ), flags = View.DRAG_FLAG_GLOBAL ) }
DragAndDropTransferData
aceita flags com suporte ao sistema de visualização do Android.
Consulte a lista de constantes de View para ver uma lista completa de flags disponíveis.
Receber dados de soltar
Atribua o modificador dragAndDropTarget
a um elemento combinável para permitir que ele
receba eventos de arrastar e soltar. O modificador tem dois parâmetros: o primeiro atua
como um filtro e especifica o tipo de dados que ele pode aceitar, e o
segundo entrega os dados em um callback.
A instância do callback precisa ser lembrada. O snippet abaixo mostra como lembrar o callback:
val callback = remember { object : DragAndDropTarget { override fun onDrop(event: DragAndDropEvent): Boolean { // Parse received data return true } } }
O próximo snippet demonstra como lidar com texto simples solto:
Modifier.dragAndDropTarget( shouldStartDragAndDrop = { event -> event.mimeTypes().contains(ClipDescription.MIMETYPE_TEXT_PLAIN) }, target = callback )
A função de callback precisa retornar true
se o evento for consumido ou false
se o evento for recusado e não for propagado para o componente pai.
Processar eventos de arrastar e soltar
Modifique os callbacks na interface DragAndDropTarget
para observar quando um
evento de arrastar e soltar começa, termina ou entra ou sai de um componente para ter controle
preciso da interface e do comportamento do app:
object : DragAndDropTarget { override fun onStarted(event: DragAndDropEvent) { // When the drag event starts } override fun onEntered(event: DragAndDropEvent) { // When the dragged object enters the target surface } override fun onEnded(event: DragAndDropEvent) { // When the drag event stops } override fun onExited(event: DragAndDropEvent) { // When the dragged object exits the target surface } override fun onDrop(event: DragAndDropEvent): Boolean = true }
Outros recursos
Codelab: Arrastar e soltar no Compose