Last active
August 1, 2018 20:42
-
-
Save CarlaTeo/8743f3bee4adc8cc09fc3e9897f5fd89 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package com.example.gk.np; | |
import android.graphics.Bitmap; | |
import android.graphics.BitmapFactory; | |
import android.graphics.Canvas; | |
import android.graphics.Color; | |
import android.graphics.Paint; | |
import android.graphics.Rect; | |
import android.graphics.Typeface; | |
import android.graphics.drawable.BitmapDrawable; | |
import android.graphics.drawable.Drawable; | |
import android.os.Bundle; | |
import android.support.design.widget.FloatingActionButton; | |
import android.support.design.widget.Snackbar; | |
import android.support.v7.app.AppCompatActivity; | |
import android.support.v7.widget.Toolbar; | |
import android.text.Editable; | |
import android.text.Spannable; | |
import android.text.style.ImageSpan; | |
import android.util.Base64; | |
import android.util.Log; | |
import android.view.ActionMode; | |
import android.view.Menu; | |
import android.view.MenuInflater; | |
import android.view.MenuItem; | |
import android.view.View; | |
import android.widget.TextView; | |
import org.xml.sax.Attributes; | |
import org.xml.sax.XMLReader; | |
import java.util.HashMap; | |
import java.util.Map; | |
class VerticalImageSpan extends ImageSpan { | |
private int baseline; | |
public VerticalImageSpan(Drawable drawable, int baseline) { | |
super(drawable); | |
this.baseline = baseline; | |
} | |
/** | |
* update the text line height | |
*/ | |
@Override | |
public int getSize(Paint paint, CharSequence text, int start, int end, | |
Paint.FontMetricsInt fontMetricsInt) { | |
Drawable drawable = getDrawable(); | |
Rect rect = drawable.getBounds(); | |
if (fontMetricsInt != null) { | |
Paint.FontMetricsInt fmPaint = paint.getFontMetricsInt(); | |
int fontHeight = fmPaint.descent - fmPaint.ascent; | |
int drHeight = rect.bottom - rect.top; | |
int centerY = fmPaint.ascent + fontHeight / 2; | |
fontMetricsInt.ascent = centerY - drHeight / 2; | |
fontMetricsInt.top = fontMetricsInt.ascent; | |
fontMetricsInt.bottom = centerY + drHeight / 2; | |
fontMetricsInt.descent = fontMetricsInt.bottom; | |
} | |
return rect.right; | |
} | |
/** | |
* see detail message in android.text.TextLine | |
* | |
* @param canvas the canvas, can be null if not rendering | |
* @param text the text to be draw | |
* @param start the text start position | |
* @param end the text end position | |
* @param x the edge of the replacement closest to the leading margin | |
* @param top the top of the line | |
* @param y the baseline | |
* @param bottom the bottom of the line | |
* @param paint the work paint | |
*/ | |
@Override | |
public void draw(Canvas canvas, CharSequence text, int start, int end, | |
float x, int top, int y, int bottom, Paint paint) { | |
Drawable drawable = getDrawable(); | |
canvas.save(); | |
Paint.FontMetricsInt fmPaint = paint.getFontMetricsInt(); | |
int fontHeight = fmPaint.descent - fmPaint.ascent; | |
int centerY = y + fmPaint.descent - fontHeight / 2; | |
int transY = centerY - (drawable.getBounds().bottom - drawable.getBounds().top) / 2; | |
canvas.translate(x, transY); | |
drawable.draw(canvas); | |
canvas.restore(); | |
} | |
} | |
public class MainActivity extends AppCompatActivity { | |
String getHTML() { | |
return "<p>Este texto precisa estar espaçadinho também. Sejam<strong> a</strong> e <strong>b</strong> números reais para os quais a igualdade " + | |
"<img style=\"width: 118px; height: 33px; vertical-align: -15px; margin: 3px;\" src=\"\" data-math=\"XGZyYWN7YX17MSthfSArIFxmcmFje2J9ezErYn0gPSAx\" " + | |
"data-original-size=\"baseline: 24px; height: 66px; width: 237px;\" data-mathrm=\"true\" /> " + | |
"tenha solução. Determine o valor do produto " + | |
"<img style=\"width: 27px; height: 11px; vertical-align: -3px; margin: 3px;\" src=\"\" " + | |
"data-math=\"YSBcY2RvdCBi\" data-original-size=\"baseline: 0px; height: 23px; width: 55px;\" data-mathrm=\"true\" />.</p>"; | |
} | |
@Override | |
protected void onCreate(Bundle savedInstanceState) { | |
super.onCreate(savedInstanceState); | |
setContentView(R.layout.activity_main); | |
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); | |
setSupportActionBar(toolbar); | |
FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); | |
fab.setOnClickListener(new View.OnClickListener() { | |
@Override | |
public void onClick(View view) { | |
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) | |
.setAction("Action", null).show(); | |
} | |
}); | |
TextView textView = (TextView)findViewById(R.id.textView); | |
textView.setText(Html.fromHtml(this.getHTML(), 0, new Html.ImageGetter() { | |
@Override | |
public Drawable getDrawable(String source, Attributes attributes) { | |
if (source.startsWith("data:image/png;base64,")) { | |
Log.e("MyComponent", source); | |
float latexScale = getApplication().getResources().getDisplayMetrics().density; | |
Map<String, Integer> styleProperties = new HashMap<>(); | |
String style = attributes.getValue("", "style"); | |
Log.e("MyComponent", style); | |
for (String part: style.split(";")) { | |
String trimmedPart = part.replace("px", "").trim(); | |
String[] subParts = trimmedPart.split(":"); | |
styleProperties.put(subParts[0].trim(), Integer.valueOf(subParts[1].trim())); | |
} | |
byte[] data = Base64.decode(source.substring(22), Base64.DEFAULT); | |
Bitmap bitmap = BitmapFactory.decodeByteArray(data, 0, data.length); | |
BitmapDrawable bitmapDrawable = new BitmapDrawable(getApplication().getResources(), bitmap); | |
bitmapDrawable.setBounds(0, 0, (int)(latexScale * styleProperties.get("width")),(int)(latexScale * styleProperties.get("height"))); | |
return bitmapDrawable; | |
} | |
return null; | |
} | |
@Override | |
public ImageSpan getImageSpan(Drawable drawable, String source, Attributes attributes) { | |
if (source.startsWith("data:image/png;base64,")) { | |
float latexScale = getApplication().getResources().getDisplayMetrics().density; | |
Map<String, Integer> styleProperties = new HashMap<>(); | |
String style = attributes.getValue("", "style"); | |
for (String part: style.split(";")) { | |
String trimmedPart = part.replace("px", "").trim(); | |
String[] subParts = trimmedPart.split(":"); | |
styleProperties.put(subParts[0].trim(), Integer.valueOf(subParts[1].trim())); | |
} | |
return new VerticalImageSpan(drawable, (int)(latexScale * styleProperties.get("vertical-align"))); | |
} | |
return new ImageSpan(drawable, source); | |
} | |
}, new Html.TagHandler() { | |
@Override | |
public void handleTag(boolean opening, String tag, Editable output, XMLReader xmlReader) { } | |
})); | |
// textView.setLineSpacing( (float)50, 0); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment