Overriding hyperlink behavior in Android
This guide addresses a common query of how to override hyperlink behavior in Android, especially for long-press actions. It’ll outline how to customize both click and long-press interactions with hyperlinks.
Analysis
While overriding the click behavior of hyperlinks is straightforward, the long-press action presents an additional challenge:
-
The SDK provides a default long-press menu for hyperlinks, offering Copy and Open as options.
-
This menu appears independent of the
onPageClick
callback, which only handles single clicks. -
As a result, the Open action from this menu bypasses any custom click handling you may have implemented.
Solution
We offer a long-press listener, setOnDocumentLongPressListener
, and it should work the same as with the single click.
-
You can override click behavior with the following code:
requirePdfFragment().setOnDocumentLongPressListener { document, pageIndex, event, pagePosition, longPressedAnnotation -> longPressedAnnotation is LinkAnnotation }
Summary
By implementing both click and long-press listeners, you can create a consistent and customized experience for hyperlink interactions in your Nutrient-powered Android application. This approach gives you full control over how hyperlinks behave, whether they’re tapped or long-pressed.
Remember to test your implementation thoroughly to ensure it meets your specific requirements and provides a smooth user experience.
If you encounter any issues or have further questions about customizing hyperlink behavior, don’t hesitate to reach out to our Support team.