Latex, default text color if not specified explicitly
This commit is contained in:
parent
86d34cef6f
commit
c90675d67b
@ -12,13 +12,14 @@
|
|||||||
.build();
|
.build();
|
||||||
```
|
```
|
||||||
* `JLatexMathPlugin`: add `theme` (to customize both inlines and blocks)
|
* `JLatexMathPlugin`: add `theme` (to customize both inlines and blocks)
|
||||||
* `JLatexMathPlugin`: add `renderMode` to use previous (pre `4.3.0`) LaTeX rendering
|
* `JLatexMathPlugin`: add `renderMode` to use previous (pre `4.3.0`) LaTeX rendering (`LEGACY` & `BLOCKS_AND_INLINES`)
|
||||||
* add `JLatexMathPlugin.ErrorHandler` to catch latex rendering errors and (optionally) display error drawable ([#204])
|
* add `JLatexMathPlugin.ErrorHandler` to catch latex rendering errors and (optionally) display error drawable ([#204])
|
||||||
|
* `JLatexMathPlugin` add text color customization ([#207])
|
||||||
|
* `JLatexMathPlugin` will use text color of widget in which it is displayed **if color is not set explicitly**
|
||||||
* add `SoftBreakAddsNewLinePlugin` plugin (`core` module)
|
* add `SoftBreakAddsNewLinePlugin` plugin (`core` module)
|
||||||
* `LinkResolverDef` defaults to `https` when a link does not have scheme information ([#75])
|
* `LinkResolverDef` defaults to `https` when a link does not have scheme information ([#75])
|
||||||
* add `option` abstraction for `sample` module allowing switching of multiple cases in runtime via menu
|
* add `option` abstraction for `sample` module allowing switching of multiple cases in runtime via menu
|
||||||
* non-empty bounds for `AsyncDrawable` when no dimensions are not yet available ([#189])
|
* non-empty bounds for `AsyncDrawable` when no dimensions are not yet available ([#189])
|
||||||
* `JLatexMathPlugin` add text color customization ([#207])
|
|
||||||
* `linkify` - option to use `LinkifyCompat` in `LinkifyPlugin` ([#201])
|
* `linkify` - option to use `LinkifyCompat` in `LinkifyPlugin` ([#201])
|
||||||
<br>Thanks to [@drakeet]
|
<br>Thanks to [@drakeet]
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ allprojects {
|
|||||||
}
|
}
|
||||||
google()
|
google()
|
||||||
jcenter()
|
jcenter()
|
||||||
|
// maven { url 'https://oss.sonatype.org/content/repositories/snapshots/' }
|
||||||
}
|
}
|
||||||
version = VERSION_NAME
|
version = VERSION_NAME
|
||||||
group = GROUP
|
group = GROUP
|
||||||
@ -69,7 +70,7 @@ ext {
|
|||||||
'commonmark-table' : "com.atlassian.commonmark:commonmark-ext-gfm-tables:$commonMarkVersion",
|
'commonmark-table' : "com.atlassian.commonmark:commonmark-ext-gfm-tables:$commonMarkVersion",
|
||||||
'android-svg' : 'com.caverock:androidsvg:1.4',
|
'android-svg' : 'com.caverock:androidsvg:1.4',
|
||||||
'android-gif' : 'pl.droidsonroids.gif:android-gif-drawable:1.2.15',
|
'android-gif' : 'pl.droidsonroids.gif:android-gif-drawable:1.2.15',
|
||||||
'jlatexmath-android' : 'ru.noties:jlatexmath-android:0.1.0',
|
'jlatexmath-android' : 'ru.noties:jlatexmath-android:0.1.1',
|
||||||
'okhttp' : 'com.squareup.okhttp3:okhttp:3.9.0',
|
'okhttp' : 'com.squareup.okhttp3:okhttp:3.9.0',
|
||||||
'prism4j' : 'io.noties:prism4j:2.0.0',
|
'prism4j' : 'io.noties:prism4j:2.0.0',
|
||||||
'debug' : 'io.noties:debug:5.0.0@jar',
|
'debug' : 'io.noties:debug:5.0.0@jar',
|
||||||
|
@ -48,5 +48,14 @@ final Markwon markwon = Markwon.builder(context)
|
|||||||
|
|
||||||
|
|
||||||
:::tip
|
:::tip
|
||||||
Since <Badge text="4.0.0" /> `JLatexMathPlugin` operates independently of `ImagesPlugin`
|
Sometimes it is enough to use rendered to an image LaTeX formula and
|
||||||
|
inline it directly in your markdown document. For this markdown references can be useful. For example:
|
||||||
|
```markdown
|
||||||
|
<!-- your mardown -->
|
||||||
|
![markdown-reference] of a solution...
|
||||||
|
|
||||||
|
<!-- then reference prerendered and converted to base64 SVG/PNG/GIF/etc -->
|
||||||
|
[markdown-reference]: 
|
||||||
|
```
|
||||||
|
For this to work an image loader that supports data uri and base64 must be used. Default `Markwon` [image-loader](../image/) supports it out of box (including SVG support)
|
||||||
:::
|
:::
|
@ -0,0 +1,62 @@
|
|||||||
|
package io.noties.markwon.ext.latex;
|
||||||
|
|
||||||
|
import android.graphics.Canvas;
|
||||||
|
import android.graphics.Paint;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
|
||||||
|
import androidx.annotation.ColorInt;
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
|
import org.scilab.forge.jlatexmath.TeXIcon;
|
||||||
|
|
||||||
|
import io.noties.markwon.core.MarkwonTheme;
|
||||||
|
import io.noties.markwon.image.AsyncDrawableSpan;
|
||||||
|
import ru.noties.jlatexmath.JLatexMathDrawable;
|
||||||
|
import ru.noties.jlatexmath.awt.Color;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 4.3.0-SNAPSHOT
|
||||||
|
*/
|
||||||
|
public class JLatexAsyncDrawableSpan extends AsyncDrawableSpan {
|
||||||
|
|
||||||
|
private final JLatextAsyncDrawable drawable;
|
||||||
|
private final int color;
|
||||||
|
private boolean appliedTextColor;
|
||||||
|
|
||||||
|
public JLatexAsyncDrawableSpan(
|
||||||
|
@NonNull MarkwonTheme theme,
|
||||||
|
@NonNull JLatextAsyncDrawable drawable,
|
||||||
|
@ColorInt int color) {
|
||||||
|
super(theme, drawable, ALIGN_CENTER, false);
|
||||||
|
this.drawable = drawable;
|
||||||
|
this.color = color;
|
||||||
|
// if color is not 0 -> then no need to apply text color
|
||||||
|
this.appliedTextColor = color != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void draw(@NonNull Canvas canvas, CharSequence text, int start, int end, float x, int top, int y, int bottom, @NonNull Paint paint) {
|
||||||
|
if (!appliedTextColor && drawable.hasResult()) {
|
||||||
|
// it is important to check for type (in case of an error, or custom placeholder or whatever
|
||||||
|
// this result can be of other type)
|
||||||
|
final Drawable drawableResult = drawable.getResult();
|
||||||
|
if (drawableResult instanceof JLatexMathDrawable) {
|
||||||
|
final JLatexMathDrawable result = (JLatexMathDrawable) drawableResult;
|
||||||
|
final TeXIcon icon = result.icon();
|
||||||
|
icon.setForeground(new Color(paint.getColor()));
|
||||||
|
appliedTextColor = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
super.draw(canvas, text, start, end, x, top, y, bottom, paint);
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
public JLatextAsyncDrawable drawable() {
|
||||||
|
return drawable;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ColorInt
|
||||||
|
public int color() {
|
||||||
|
return color;
|
||||||
|
}
|
||||||
|
}
|
@ -3,23 +3,23 @@ package io.noties.markwon.ext.latex;
|
|||||||
import android.graphics.Paint;
|
import android.graphics.Paint;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
|
|
||||||
|
import androidx.annotation.ColorInt;
|
||||||
import androidx.annotation.IntRange;
|
import androidx.annotation.IntRange;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import io.noties.markwon.core.MarkwonTheme;
|
import io.noties.markwon.core.MarkwonTheme;
|
||||||
import io.noties.markwon.image.AsyncDrawable;
|
import io.noties.markwon.image.AsyncDrawable;
|
||||||
import io.noties.markwon.image.AsyncDrawableSpan;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @since 4.3.0-SNAPSHOT
|
* @since 4.3.0-SNAPSHOT
|
||||||
*/
|
*/
|
||||||
class JLatexInlineAsyncDrawableSpan extends AsyncDrawableSpan {
|
class JLatexInlineAsyncDrawableSpan extends JLatexAsyncDrawableSpan {
|
||||||
|
|
||||||
private final AsyncDrawable drawable;
|
private final AsyncDrawable drawable;
|
||||||
|
|
||||||
JLatexInlineAsyncDrawableSpan(@NonNull MarkwonTheme theme, @NonNull AsyncDrawable drawable, int alignment, boolean replacementTextIsLink) {
|
JLatexInlineAsyncDrawableSpan(@NonNull MarkwonTheme theme, @NonNull JLatextAsyncDrawable drawable, @ColorInt int color) {
|
||||||
super(theme, drawable, alignment, replacementTextIsLink);
|
super(theme, drawable, color);
|
||||||
this.drawable = drawable;
|
this.drawable = drawable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -228,7 +228,7 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
|
|
||||||
final MarkwonConfiguration configuration = visitor.configuration();
|
final MarkwonConfiguration configuration = visitor.configuration();
|
||||||
|
|
||||||
final AsyncDrawableSpan span = new AsyncDrawableSpan(
|
final AsyncDrawableSpan span = new JLatexAsyncDrawableSpan(
|
||||||
configuration.theme(),
|
configuration.theme(),
|
||||||
new JLatextAsyncDrawable(
|
new JLatextAsyncDrawable(
|
||||||
latex,
|
latex,
|
||||||
@ -236,8 +236,8 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
jLatexBlockImageSizeResolver,
|
jLatexBlockImageSizeResolver,
|
||||||
null,
|
null,
|
||||||
true),
|
true),
|
||||||
AsyncDrawableSpan.ALIGN_CENTER,
|
config.theme.blockTextColor()
|
||||||
false);
|
);
|
||||||
|
|
||||||
visitor.setSpans(length, span);
|
visitor.setSpans(length, span);
|
||||||
|
|
||||||
@ -273,8 +273,8 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
inlineImageSizeResolver,
|
inlineImageSizeResolver,
|
||||||
null,
|
null,
|
||||||
false),
|
false),
|
||||||
AsyncDrawableSpan.ALIGN_CENTER,
|
config.theme.inlineTextColor()
|
||||||
false);
|
);
|
||||||
|
|
||||||
visitor.setSpans(length, span);
|
visitor.setSpans(length, span);
|
||||||
}
|
}
|
||||||
@ -415,9 +415,9 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
final JLatextAsyncDrawable jLatextAsyncDrawable = (JLatextAsyncDrawable) drawable;
|
final JLatextAsyncDrawable jLatextAsyncDrawable = (JLatextAsyncDrawable) drawable;
|
||||||
|
|
||||||
if (jLatextAsyncDrawable.isBlock()) {
|
if (jLatextAsyncDrawable.isBlock()) {
|
||||||
jLatexMathDrawable = createBlockDrawable(jLatextAsyncDrawable.getDestination());
|
jLatexMathDrawable = createBlockDrawable(jLatextAsyncDrawable);
|
||||||
} else {
|
} else {
|
||||||
jLatexMathDrawable = createInlineDrawable(jLatextAsyncDrawable.getDestination());
|
jLatexMathDrawable = createInlineDrawable(jLatextAsyncDrawable);
|
||||||
}
|
}
|
||||||
|
|
||||||
setResult(drawable, jLatexMathDrawable);
|
setResult(drawable, jLatexMathDrawable);
|
||||||
@ -448,7 +448,9 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
|
|
||||||
// @since 4.3.0-SNAPSHOT
|
// @since 4.3.0-SNAPSHOT
|
||||||
@NonNull
|
@NonNull
|
||||||
private JLatexMathDrawable createBlockDrawable(@NonNull String latex) {
|
private JLatexMathDrawable createBlockDrawable(@NonNull JLatextAsyncDrawable drawable) {
|
||||||
|
|
||||||
|
final String latex = drawable.getDestination();
|
||||||
|
|
||||||
final JLatexMathTheme theme = config.theme;
|
final JLatexMathTheme theme = config.theme;
|
||||||
|
|
||||||
@ -478,7 +480,9 @@ public class JLatexMathPlugin extends AbstractMarkwonPlugin {
|
|||||||
|
|
||||||
// @since 4.3.0-SNAPSHOT
|
// @since 4.3.0-SNAPSHOT
|
||||||
@NonNull
|
@NonNull
|
||||||
private JLatexMathDrawable createInlineDrawable(@NonNull String latex) {
|
private JLatexMathDrawable createInlineDrawable(@NonNull JLatextAsyncDrawable drawable) {
|
||||||
|
|
||||||
|
final String latex = drawable.getDestination();
|
||||||
|
|
||||||
final JLatexMathTheme theme = config.theme;
|
final JLatexMathTheme theme = config.theme;
|
||||||
|
|
||||||
|
@ -47,6 +47,7 @@ public abstract class JLatexMathTheme {
|
|||||||
/**
|
/**
|
||||||
* Special immutable class to hold padding information
|
* Special immutable class to hold padding information
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("WeakerAccess")
|
||||||
public static class Padding {
|
public static class Padding {
|
||||||
public final int left;
|
public final int left;
|
||||||
public final int top;
|
public final int top;
|
||||||
@ -60,6 +61,7 @@ public abstract class JLatexMathTheme {
|
|||||||
this.bottom = bottom;
|
this.bottom = bottom;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Padding{" +
|
return "Padding{" +
|
||||||
@ -125,6 +127,7 @@ public abstract class JLatexMathTheme {
|
|||||||
@ColorInt
|
@ColorInt
|
||||||
public abstract int blockTextColor();
|
public abstract int blockTextColor();
|
||||||
|
|
||||||
|
@SuppressWarnings({"unused", "UnusedReturnValue"})
|
||||||
public static class Builder {
|
public static class Builder {
|
||||||
private final float textSize;
|
private final float textSize;
|
||||||
private final float inlineTextSize;
|
private final float inlineTextSize;
|
||||||
@ -142,7 +145,7 @@ public abstract class JLatexMathTheme {
|
|||||||
private Padding inlinePadding;
|
private Padding inlinePadding;
|
||||||
private Padding blockPadding;
|
private Padding blockPadding;
|
||||||
|
|
||||||
private int textColor = 0xFF000000;
|
private int textColor;
|
||||||
private int inlineTextColor;
|
private int inlineTextColor;
|
||||||
private int blockTextColor;
|
private int blockTextColor;
|
||||||
|
|
||||||
|
@ -63,7 +63,16 @@ public class LatexActivity extends ActivityWithMenuOptions {
|
|||||||
.add("insideBlockQuote", this::insideBlockQuote)
|
.add("insideBlockQuote", this::insideBlockQuote)
|
||||||
.add("error", this::error)
|
.add("error", this::error)
|
||||||
.add("legacy", this::legacy)
|
.add("legacy", this::legacy)
|
||||||
.add("textColor", this::textColor);
|
.add("textColor", this::textColor)
|
||||||
|
.add("defaultTextColor", this::defaultTextColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void beforeOptionSelected(@NonNull String option) {
|
||||||
|
super.beforeOptionSelected(option);
|
||||||
|
|
||||||
|
// reset text color
|
||||||
|
textView.setTextColor(0xFF000000);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -151,6 +160,18 @@ public class LatexActivity extends ActivityWithMenuOptions {
|
|||||||
markwon.setMarkdown(textView, md);
|
markwon.setMarkdown(textView, md);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void defaultTextColor() {
|
||||||
|
// @since 4.3.0-SNAPSHOT text color is automatically taken from textView
|
||||||
|
textView.setTextColor(0xFFff0000);
|
||||||
|
|
||||||
|
final String md = wrapLatexInSampleMarkdown(LATEX_LONG_DIVISION);
|
||||||
|
final Markwon markwon = Markwon.builder(this)
|
||||||
|
.usePlugin(MarkwonInlineParserPlugin.create())
|
||||||
|
.usePlugin(JLatexMathPlugin.create(textView.getTextSize()))
|
||||||
|
.build();
|
||||||
|
markwon.setMarkdown(textView, md);
|
||||||
|
}
|
||||||
|
|
||||||
@NonNull
|
@NonNull
|
||||||
private static String wrapLatexInSampleMarkdown(@NonNull String latex) {
|
private static String wrapLatexInSampleMarkdown(@NonNull String latex) {
|
||||||
return "" +
|
return "" +
|
||||||
|
Loading…
x
Reference in New Issue
Block a user