
The styles that are denoted with an asterisk (*), when defined, completely override the default spans. The others, when defined, add spans before the default spans (if any) so that when reversed, take precedence. Example: ``` <ru.noties.markwon.view.MarkwonViewCompat android:layout_width="wrap_content" android:layout_height="wrap_content" app:mv_H2Style="?android:textAppearanceLarge" app:mv_markdown="## Opening hours" /> ``` In the above case, as ?android:textAppearanceLarge most likely is resolved into an actual style, the spans that are added by the Markwon- library (including heading line break) will no be added. ``` <ru.noties.markwon.view.MarkwonViewCompat android:layout_width="wrap_content" android:layout_height="wrap_content" app:mv_CodeSpanStyle="?textAppearanceSmall" app:mv_markdown="`private int count = 5`" /> ``` Conversely, defining a style for mv_CodeSpanStyle will still result in that background is added to the code text and it will by styled according to the resolved style of `android:textAppearanceSmall`. Supported style attributes: *mv_H1Style *mv_H2Style *mv_H3Style *mv_H4Style *mv_H5Style *mv_H6Style *mv_EmphasisStyle *mv_StrongEmphasisStyle mv_BlockQuoteStyle mv_CodeSpanStyle mv_MultilineCodeSpanStyle mv_OrderedListItemStyle mv_BulletListItemStyle mv_TaskListItemStyle mv_TableRowStyle mv_LinkStyle
Markwon View
This is simple library containing 2 views that are able to display markdown:
- MarkwonView - extends
android.view.TextView
- MarkwonViewCompat - extends
android.support.v7.widget.AppCompatTextView
Both of them implement common IMarkwonView
interface:
public interface IMarkwonView {
interface ConfigurationProvider {
@NonNull
SpannableConfiguration provide(@NonNull Context context);
}
void setConfigurationProvider(@NonNull ConfigurationProvider provider);
void setMarkdown(@Nullable String markdown);
void setMarkdown(@Nullable SpannableConfiguration configuration, @Nullable String markdown);
@Nullable
String getMarkdown();
}
Both views support layout-preview in Android Studio (with some exceptions, for example, bold span is not rendered due to some limitations of layout preview). These are XML attributes:
app:mv_markdown="string"
app:mv_configurationProvider="string"
mv_markdown
accepts a string and represents raw markdown
mv_configurationProvider
accepts a string and represents a full class name of a class of type ConfigurationProvider
,
for example: com.example.my.package.MyConfigurationProvider
(this class must have an empty constructor
in order to be instantiated via reflection).
Please note that those views parse markdown in main thread, so their usage must be for relatively small markdown portions only