Come allineare TextView attorno a un ImageView?

inserisci la descrizione dell'immagine qui

Sto cercando di allineare il TextView attorno a ImageView. Sto usando il seguente codice:

private void createSpannableText(){ TextView myTextView = (TextView) findViewById(R.id.textView); SpannableStringBuilder builder = new SpannableStringBuilder(); builder.append(this.getText(R.string.loren__ipsum__max)); int lengthOfPart1 = builder.length(); builder.append(" "); builder.append(this.getText(R.string.lorem__ipsum)); Drawable d = getResources().getDrawable(R.drawable.myImage); d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight()); // <---- Very important otherwise your image won't appear ImageSpan myImage = new ImageSpan(d); builder.setSpan(myImage, 0, lengthOfPart1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); myTextView.setText(builder); } 

Ma non è stato ansible ottenere il risultato esatto. Cosa dovrei fare? Devo usare SpannableStringBuilder in questo caso o c’è un altro modo. Per favore aiuto. Ho usato questo post- http://majaxandroidtips.blogspot.in/2009/06/how-to-have-few-layout-elements-wrap_17.html per avere la soluzione.

PS: voglio anche il margine di 6 dpi attorno a ImageView

È ansible ottenere ciò utilizzando l’interfaccia android.text.style.LeadingMarginSpan.LeadingMarginSpan2 che è disponibile in API 8. Ecco l’ articolo , non in inglese però, traducilo usando il tuo browser. Inoltre puoi scaricare il codice sorgente dell’esempio direttamente da qui .

Il tuo layout:

 < ?xml version="1.0" encoding="UTF-8"?>     

LeadingMarginSpan.LeadingMarginSpan2 class helper LeadingMarginSpan.LeadingMarginSpan2

 class MyLeadingMarginSpan2 implements LeadingMarginSpan.LeadingMarginSpan2 { private int margin; private int lines; MyLeadingMarginSpan2(int lines, int margin) { this.margin = margin; this.lines = lines; } /* Возвращает значение, на которе должен быть добавлен отступ */ @Override public int getLeadingMargin(boolean first) { if (first) { /* * Данный отступ будет применен к количеству строк * возвращаемых getLeadingMarginLineCount() */ return margin; } else { // Отступ для всех остальных строк return 0; } } @Override public void drawLeadingMargin(Canvas c, Paint p, int x, int dir, int top, int baseline, int bottom, CharSequence text, int start, int end, boolean first, Layout layout) {} /* * Возвращает количество строк, к которым должен быть * применен отступ возвращаемый методом getLeadingMargin(true) * Замечание: * Отступ применяется только к N строкам первого параграфа. */ @Override public int getLeadingMarginLineCount() { return lines; } }; 

Il tuo codice attività:

  @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); String text = getString(R.string.text); // Получаем иконку и ее ширину Drawable dIcon = getResources().getDrawable(R.drawable.icon); int leftMargin = dIcon.getIntrinsicWidth() + 10; // Устанавливаем иконку в R.id.icon ImageView icon = (ImageView) findViewById(R.id.icon); icon.setBackgroundDrawable(dIcon); SpannableString ss = new SpannableString(text); // Выставляем отступ для первых трех строк абазца ss.setSpan(new MyLeadingMarginSpan2(3, leftMargin), 0, ss.length(), 0); TextView messageView = (TextView) findViewById(R.id.message_view); messageView.setText(ss); } 

E finalmente ecco un risultato demo:

inserisci la descrizione dell'immagine qui