Связаться Bubble EditText

Я пытаюсь создать контактные пузыри вMultiAutoCompleteTextView похоже на то, как это реализовано в приложении Google+. Ниже скриншот:

Google+ Compose Post Screenshot .

Я пытался продлить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 drawable определяется так:

<?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>

В моем классе деятельности, который имеет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 но был неудачным.

Ответы на вопрос(3)

Ваш ответ на вопрос