You can support multiple links in a single string of text to perform different actions when clicking a subsection of text.
Version compatibility
This implementation requires that your project minSDK be set to API level 21 or higher.
Dependencies
Display multiple links in a single string
This snippet embeds multiple clickable links into a single string of text:
@Composable fun AnnotatedStringWithLinkSample() { // Display multiple links in the text Text( buildAnnotatedString { append("Go to the ") withLink( LinkAnnotation.Url( "https://developer.android.com/", TextLinkStyles(style = SpanStyle(color = Color.Blue)) ) ) { append("Android Developers ") } append("website, and check out the") withLink( LinkAnnotation.Url( "https://developer.android.com/jetpack/compose", TextLinkStyles(style = SpanStyle(color = Color.Green)) ) ) { append("Compose guidance") } append(".") } ) }
Key points about the code
- Uses the
buildAnnotatedString
function to create an annotated string of text. - Specifies the the link and text styling by passing them as arguments of the
LinkAnnotation.Url()
function (itself passed as an argument of thewithLink()
function). A click listener is built intoLinkAnnotation.Url()
. - Adds text using
append()
in the body of thewithLink
function. - Repeats this process to add another linked text segment.
Results
data:image/s3,"s3://crabby-images/d8d36/d8d360e5ef88f78610acb5e9572e37dc7c95d7b7" alt="One text string containing two different links"
Collections that contain this guide
This guide is part of these curated Quick Guide collections that cover broader Android development goals:
data:image/s3,"s3://crabby-images/f5af7/f5af76d18fcab5e5696f8d1eed7d8d6cd6c4fd03" alt=""
Display text
Text is a central piece of any UI. Find out different ways
you can present text in your app to provide a delightful user experience.
Have questions or feedback
Go to our frequently asked questions page and learn about quick guides or reach out and let us know your thoughts.