Я пытаюсь создать пузыри контактов MultiAutoCompleteTextView
аналогично тому, как это реализовано в приложении Google+. Ниже приведен снимок экрана:
.
Я попытался расширить DynamicDrawableSpan
класс, чтобы получить возможность рисования на фоне диапазона текста.
public class BubbleSpan extends DynamicDrawableSpan {
private Context c;
public BubbleSpan(Context context) {
super();
c = context;
}
@Override
public Drawable getDrawable() {
Resources res = c.getResources();
Drawable d = res.getDrawable(R.drawable.oval);
d.setBounds(0, 0, 100, 20);
return d;
}
}
Где мой объект oval.xml определяется так:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
<solid android:color="#352765"/>
<padding android:left="7dp" android:top="7dp"
android:right="7dp" android:bottom="7dp" />
<corners android:radius="6dp" />
</shape>
В моем классе Activity, который имеет MulitAutoCompleteTextView
, я устанавливаю диапазон пузырьков следующим образом:
final Editable e = tv.getEditableText();
final SpannableStringBuilder sb = new SpannableStringBuilder();
sb.append("some sample text");
sb.setSpan(new BubbleSpan(getApplicationContext()), 0, 6, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
e.append(sb);
Однако вместо овала, отображаемого за первыми 6 символами в строке, символы не видны, и на заднем плане нет овала, который можно рисовать.
Если я изменю метод getDrawable () BubbleSpan на использование .png вместо формы, которую можно рисовать:
public Drawable getDrawable() {
Resources res = c.getResources();
Drawable d = res.getDrawable(android.R.drawable.bottom_bar);
d.setBounds(0, 0, 100, 20);
return d;
}
Затем появится .png, но символы в строке, которые являются частью диапазона, не появятся. Как я могу сделать так, чтобы символы в диапазоне отображались на переднем плане, в то время как настраиваемая фигура, которую можно рисовать, отображалась в фоновом режиме?
Я попытался также использовать ImageSpan
вместо подкласса, DynamicDrawableSpan
но безуспешно.