Small chip improvements

pull/194/merge
M66B 4 years ago
parent 9888b19b81
commit 74cb32ea3c

@ -32,6 +32,7 @@ import android.text.TextWatcher;
import android.text.style.DynamicDrawableSpan; import android.text.style.DynamicDrawableSpan;
import android.text.style.ImageSpan; import android.text.style.ImageSpan;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.view.ContextThemeWrapper; import android.view.ContextThemeWrapper;
import android.view.MotionEvent; import android.view.MotionEvent;
@ -74,6 +75,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
dark ? R.style.Base_Theme_Material3_Dark : R.style.Base_Theme_Material3_Light); dark ? R.style.Base_Theme_Material3_Dark : R.style.Base_Theme_Material3_Light);
ContentResolver resolver = context.getContentResolver(); ContentResolver resolver = context.getContentResolver();
int dp3 = Helper.dp2pixels(context, 3); int dp3 = Helper.dp2pixels(context, 3);
DisplayMetrics dm = getResources().getDisplayMetrics();
addTextChangedListener(new TextWatcher() { addTextChangedListener(new TextWatcher() {
@Override @Override
@ -89,8 +91,8 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
@Override @Override
public void afterTextChanged(Editable edit) { public void afterTextChanged(Editable edit) {
boolean added = false; boolean added = false;
List<ImageSpan> spans = new ArrayList<>(); List<ClipImageSpan> spans = new ArrayList<>();
spans.addAll(Arrays.asList(edit.getSpans(0, edit.length(), ImageSpan.class))); spans.addAll(Arrays.asList(edit.getSpans(0, edit.length(), ClipImageSpan.class)));
boolean quote = false; boolean quote = false;
int start = 0; int start = 0;
@ -100,7 +102,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
quote = !quote; quote = !quote;
else if (kar == ',' && !quote) { else if (kar == ',' && !quote) {
boolean found = false; boolean found = false;
for (ImageSpan span : new ArrayList<>(spans)) { for (ClipImageSpan span : new ArrayList<>(spans)) {
int s = edit.getSpanStart(span); int s = edit.getSpanStart(span);
int e = edit.getSpanEnd(span); int e = edit.getSpanEnd(span);
if (s == start && e == i + 1) { if (s == start && e == i + 1) {
@ -131,25 +133,19 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
avatar = Drawable.createFromStream(is, email); avatar = Drawable.createFromStream(is, email);
} }
ChipDrawable cd = ChipDrawable.createFromResource(ctx, R.xml.chip);
cd.setChipIcon(avatar);
cd.setCloseIcon(null);
cd.setTextStartPadding(dp3);
cd.setTextEndPadding(dp3);
String e = parsed[0].getAddress(); String e = parsed[0].getAddress();
String p = parsed[0].getPersonal(); String p = parsed[0].getPersonal();
if (TextUtils.isEmpty(p)) String text = (TextUtils.isEmpty(p) ? e : p);
if (TextUtils.isEmpty(e))
cd.setText(email);
else
cd.setText(e);
else
cd.setText(p);
// https://github.com/material-components/material-components-android/blob/master/docs/components/Chip.md
ChipDrawable cd = ChipDrawable.createFromResource(ctx, R.xml.chip);
cd.setChipIcon(avatar);
// cd.setLayoutDirection(View.LAYOUT_DIRECTION_LOCALE);
cd.setText(text);
cd.setMaxWidth(2 * dm.widthPixels / 3);
cd.setBounds(0, 0, cd.getIntrinsicWidth(), cd.getIntrinsicHeight()); cd.setBounds(0, 0, cd.getIntrinsicWidth(), cd.getIntrinsicHeight());
ImageSpan is = new ImageSpan(cd, DynamicDrawableSpan.ALIGN_BOTTOM); ClipImageSpan is = new ClipImageSpan(cd);
edit.setSpan(is, start, i + 1, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); edit.setSpan(is, start, i + 1, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
added = true; added = true;
} }
@ -162,7 +158,7 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
} }
} }
for (ImageSpan span : spans) for (ClipImageSpan span : spans)
edit.removeSpan(span); edit.removeSpan(span);
if (spans.size() > 0 || added) if (spans.size() > 0 || added)
@ -172,6 +168,12 @@ public class EditTextMultiAutoComplete extends AppCompatMultiAutoCompleteTextVie
} }
} }
private static class ClipImageSpan extends ImageSpan {
public ClipImageSpan(@NonNull Drawable drawable) {
super(drawable, DynamicDrawableSpan.ALIGN_BOTTOM);
}
}
@Override @Override
public boolean onPreDraw() { public boolean onPreDraw() {
try { try {

@ -1,5 +1,7 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<chip xmlns:android="http://schemas.android.com/apk/res/android" <chip xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:app="http://schemas.android.com/apk/res-auto"
android:text="Contact" android:textAppearance="@style/TextAppearance.AppCompat.Small"
app:chipIcon="@drawable/baseline_mail_24" /> app:closeIconVisible="false"
app:textEndPadding="3dp"
app:textStartPadding="3dp" />

Loading…
Cancel
Save