Break bullet spans

pull/184/head
M66B 5 years ago
parent a0f86be19a
commit c65d99a56d

@ -62,8 +62,10 @@ import android.text.Spanned;
import android.text.TextUtils; import android.text.TextUtils;
import android.text.TextWatcher; import android.text.TextWatcher;
import android.text.method.LinkMovementMethod; import android.text.method.LinkMovementMethod;
import android.text.style.BulletSpan;
import android.text.style.CharacterStyle; import android.text.style.CharacterStyle;
import android.text.style.ImageSpan; import android.text.style.ImageSpan;
import android.text.style.LeadingMarginSpan;
import android.text.style.QuoteSpan; import android.text.style.QuoteSpan;
import android.text.style.URLSpan; import android.text.style.URLSpan;
import android.util.TypedValue; import android.util.TypedValue;
@ -499,19 +501,11 @@ public class FragmentCompose extends FragmentBase {
ssb.charAt(start) == '\n' && ssb.charAt(e - 1) == '\n') { ssb.charAt(start) == '\n' && ssb.charAt(e - 1) == '\n') {
broken = true; broken = true;
QuoteSpan q1; QuoteSpan q1 = clone(span, QuoteSpan.class, etBody.getContext());
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.P)
q1 = new QuoteSpan(span.getColor());
else
q1 = new QuoteSpan(span.getColor(), span.getStripeWidth(), span.getGapWidth());
ssb.setSpan(q1, s, start, f); ssb.setSpan(q1, s, start, f);
Log.i("Span " + s + "..." + start); Log.i("Span " + s + "..." + start);
QuoteSpan q2; QuoteSpan q2 = clone(span, QuoteSpan.class, etBody.getContext());
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.P)
q2 = new QuoteSpan(span.getColor());
else
q2 = new QuoteSpan(span.getColor(), span.getStripeWidth(), span.getGapWidth());
ssb.setSpan(q2, start + 1, e, f); ssb.setSpan(q2, start + 1, e, f);
Log.i("Span " + (start + 1) + "..." + e); Log.i("Span " + (start + 1) + "..." + e);
@ -519,6 +513,30 @@ public class FragmentCompose extends FragmentBase {
} }
} }
BulletSpan[] bullets = ssb.getSpans(start + 1, start + 1, BulletSpan.class);
for (BulletSpan span : bullets) {
int s = ssb.getSpanStart(span);
int e = ssb.getSpanEnd(span);
int f = ssb.getSpanFlags(span);
Log.i("Span " + s + "..." + e + " start=" + start);
broken = true;
if (start + 1 > s) {
BulletSpan b1 = clone(span, span.getClass(), etBody.getContext());
ssb.setSpan(b1, s, start + 1, f);
Log.i("Span " + s + "..." + (start + 1));
}
if (e > start + 1) {
BulletSpan b2 = clone(span, span.getClass(), etBody.getContext());
ssb.setSpan(b2, start + 1, e, f);
Log.i("Span " + (start + 1) + "..." + e);
}
start++; // next bullet
ssb.removeSpan(span);
}
if (broken) { if (broken) {
CharacterStyle[] sspan = ssb.getSpans(start + 1, start + 1, CharacterStyle.class); CharacterStyle[] sspan = ssb.getSpans(start + 1, start + 1, CharacterStyle.class);
for (CharacterStyle span : sspan) { for (CharacterStyle span : sspan) {
@ -542,10 +560,6 @@ public class FragmentCompose extends FragmentBase {
ssb.removeSpan(span); ssb.removeSpan(span);
} }
//int color = Helper.resolveColor(getContext(), android.R.attr.textColorPrimary);
//int flags = (Spanned.SPAN_INCLUSIVE_INCLUSIVE | Spanned.SPAN_COMPOSING);
//ssb.setSpan(new ForegroundColorSpan(color), start, start, flags);
etBody.setText(ssb); etBody.setText(ssb);
etBody.setSelection(start); etBody.setSelection(start);
} }
@ -556,6 +570,31 @@ public class FragmentCompose extends FragmentBase {
public void afterTextChanged(Editable s) { public void afterTextChanged(Editable s) {
// Do nothing // Do nothing
} }
public <T extends LeadingMarginSpan> T clone(Object span, Class<T> type, Context context) {
if (QuoteSpan.class.isAssignableFrom(type)) {
QuoteSpan q = (QuoteSpan) span;
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.P)
return (T) new QuoteSpan(q.getColor());
else
return (T) new QuoteSpan(q.getColor(), q.getStripeWidth(), q.getGapWidth());
} else if (NumberSpan.class.isAssignableFrom(type)) {
NumberSpan n = (NumberSpan) span;
int dp6 = Helper.dp2pixels(context, 6);
int colorAccent = Helper.resolveColor(context, R.attr.colorAccent);
return (T) new NumberSpan(dp6, colorAccent, n.getTextSize(), n.getIndex() + 1);
} else if (BulletSpan.class.isAssignableFrom(type)) {
BulletSpan b = (BulletSpan) span;
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.P) {
int dp6 = Helper.dp2pixels(context, 6);
int colorAccent = Helper.resolveColor(context, R.attr.colorAccent);
return (T) new BulletSpan(dp6, colorAccent);
} else
return (T) new BulletSpan(b.getGapWidth(), b.getColor(), b.getBulletRadius());
} else
throw new IllegalArgumentException(type.getName());
}
}); });
cbSignature.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { cbSignature.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

@ -28,6 +28,8 @@ import android.text.TextPaint;
import android.text.style.BulletSpan; import android.text.style.BulletSpan;
public class NumberSpan extends BulletSpan { public class NumberSpan extends BulletSpan {
private int index;
private TextPaint tp; private TextPaint tp;
private String number; private String number;
private int margin; private int margin;
@ -39,10 +41,20 @@ public class NumberSpan extends BulletSpan {
tp.setTypeface(Typeface.MONOSPACE); tp.setTypeface(Typeface.MONOSPACE);
tp.setTextSize(textSize); tp.setTextSize(textSize);
this.index = index;
number = index + "."; number = index + ".";
margin = Math.round(tp.measureText(number) + gapWidth); margin = Math.round(tp.measureText(number) + gapWidth);
} }
float getTextSize() {
return tp.getTextSize();
}
int getIndex() {
return index;
}
@Override @Override
public int getLeadingMargin(boolean first) { public int getLeadingMargin(boolean first) {
// https://issuetracker.google.com/issues/36956124 // https://issuetracker.google.com/issues/36956124

Loading…
Cancel
Save