Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stefanhaustein/nativehtml
Renders HTML to native Android components.
https://github.com/stefanhaustein/nativehtml
android html
Last synced: 2 months ago
JSON representation
Renders HTML to native Android components.
- Host: GitHub
- URL: https://github.com/stefanhaustein/nativehtml
- Owner: stefanhaustein
- License: apache-2.0
- Created: 2017-03-11T19:02:04.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-12-02T18:26:58.000Z (about 6 years ago)
- Last Synced: 2024-11-01T04:51:46.990Z (2 months ago)
- Topics: android, html
- Language: Java
- Homepage:
- Size: 293 KB
- Stars: 45
- Watchers: 7
- Forks: 6
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NativeHtml
Renders HTML to native Android components. Easily extensible with custom native elements.
The main use case for this library is rendering HTML-formatted text or (custom) components in cases where TextView HTML capabilities are too limited and WebView is too heavyweight or not suitable for other reasons.
## Use Cases
* Formatted help pages with links directly into the application
* Rendering server-provided content with custom native elements
* Multiple components with HTML content in a single view where multiple WebView instances would be prohibitive in terms of resource consumption## Limitations
* CSS is mostly limited to CSS 2
* Floating elements are not supported
* Formatted text is rendering using built-in TextViews with spans, which means that justified text is not supported.
## Extensibility* To implement custom elements, extend `AndroidPlatform` and override `createElement`. Native Android views can be wrapped in `AndroidWrapperElement`
* Platform-independent and platform-specific parts of the code base are clearly separated, so it should be straightforward to port the code to any platform that supports Java and provides a component for formatted text.
* Layout managers are separated from containers. So while flexbox is currently not supported, it should be relatively straightforward to implement in a way similar to the existing `BlockLayout` and `TableLayout` classes.
## UsageFor a simple example, please refer to the [demo](
https://github.com/stefanhaustein/nativehtml/blob/master/demo-android/src/main/java/org/kobjects/nativehtml/demo/android/MainActivity.java)## Gradle
Jitpack for the win!
Step 1: Add jitpack to your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}Step 2: Add the HtmlView2 dependency
dependencies {
compile 'com.github.stefanhaustein.nativehtml:android:v1.0.6'
}