Definir programaticamente o desenho à esquerda em um TextView


285

Eu tenho um textView em xml aqui.

<TextView
        android:id="@+id/bookTitle"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:drawableLeft="@drawable/checkmark"
        android:gravity="center_vertical"
        android:textStyle="bold"
        android:textSize="24dip"
        android:maxLines="1"
        android:ellipsize="end"/>

Como você pode ver, defino o DrawableLeft em xml.

Eu gostaria de mudar o drawable no código.

Existe alguma maneira de fazer isso? Ou definindo o drawableLeft no código para a exibição de texto?

Respostas:


781

Você pode usar setCompoundDrawablesWithIntrinsicBounds (int left, int top, int right, int bottom)

defina 0 onde você não deseja imagens

Exemplo para Drawable à esquerda:

TextView textView = (TextView) findViewById(R.id.myTxtView);
textView.setCompoundDrawablesWithIntrinsicBounds(R.drawable.icon, 0, 0, 0);

Dica: sempre que você conhece algum atributo XML, mas não tem idéia de como usá-lo em tempo de execução. basta ir para a descrição dessa propriedade no documento do desenvolvedor. Lá você encontrará Métodos relacionados se for suportado em tempo de execução. ou seja, para DrawableLeft


Então, onde eu defino o drawable neste método?
Coder_For_Life22

1
+1 Está funcionando para definir o android: drawableLeft para TextView programaticamente. Thanx mate
Paresh Mayani

35
+1 para adicionar a dica. que deve ser a primeira coisa devs são informados ao usar os docs
gmjordan

@BrainCrash Você está certo, eu confundi com o método mais novo que tem o mesmo nome.
Deathemperor

2
Olá, eu estava usando esse método para definir os drawables, mas não consegui encontrar a parte contrária do getter. Eu tive que verificar se o TextView composto tem alguns drawable. Como faço isso? Tentei comparar textview.getCompoundDrawablesRelative()[0]commContext.getResources().getDrawable(R.drawable.my_drawable)
ravi


6

Você pode usar qualquer um dos seguintes métodos para definir o Drawable no TextView:

1- setCompoundDrawablesWithIntrinsicBounds (int, int, int, int)

2- setCompoundDrawables (Esquerda, Drawable, Top_Drawable, Right_Drawable, Bottom_Drawable)

E para obter recursos dos recursos, você pode usar:

getResources().getDrawable(R.drawable.your_drawable_id);

Não, setCompoundDrawablesWithIntrinsicBounds (int, int, int, int) é o API Levet 3 a partir do seu próprio link ...
BrainCrash

1

Usando o Kotlin:

Você pode criar uma função de extensão ou apenas usar setCompoundDrawablesWithIntrinsicBoundsdiretamente.

fun TextView.leftDrawable(@DrawableRes id: Int = 0) {
   this.setCompoundDrawablesWithIntrinsicBounds(id, 0, 0, 0)
}

Se você precisar redimensionar o drawable, poderá usar esta função de extensão.

textView.leftDrawable(R.drawable.my_icon, R.dimen.icon_size)

fun TextView.leftDrawable(@DrawableRes id: Int = 0, @DimenRes sizeRes: Int) {
    val drawable = ContextCompat.getDrawable(context, id)
    val size = resources.getDimensionPixelSize(sizeRes)
    drawable?.setBounds(0, 0, size, size)
    this.setCompoundDrawables(drawable, null, null, null)
}

Para ficar realmente elegante, crie um invólucro que permita modificações de tamanho e / ou cor.

textView.leftDrawable(R.drawable.my_icon, colorRes = R.color.white)

fun TextView.leftDrawable(@DrawableRes id: Int = 0, @DimenRes sizeRes: Int = 0, @ColorInt color: Int = 0, @ColorRes colorRes: Int = 0) {
    val drawable = drawable(id)
    if (sizeRes != 0) {
        val size = resources.getDimensionPixelSize(sizeRes)
        drawable?.setBounds(0, 0, size, size)
    }
    if (color != 0) {
        drawable?.setColorFilter(color, PorterDuff.Mode.SRC_ATOP)
    } else if (colorRes != 0) {
        val colorInt = ContextCompat.getColor(context, colorRes)
        drawable?.setColorFilter(colorInt, PorterDuff.Mode.SRC_ATOP)
    }
    this.setCompoundDrawables(drawable, null, null, null)
}

0

Uma extensão Kotlin + algum preenchimento ao redor do drawable

fun TextView.addDrawable(drawable: Int) {
val imgDrawable = ContextCompat.getDrawable(context, drawable)
compoundDrawablePadding = 32
setCompoundDrawablesWithIntrinsicBounds(imgDrawable, null, null, null)
}

0

existem duas maneiras de fazer isso: você pode usar XML ou Java para isso. Se for estático e não exigir alterações, você poderá inicializar em XML.

  android:drawableLeft="@drawable/cloud_up"
    android:drawablePadding="5sp"

Agora, se você precisar alterar os ícones dinamicamente, poderá fazê-lo chamando os ícones com base nos eventos

       textViewContext.setText("File Uploaded");
textViewContext.setCompoundDrawablesWithIntrinsicBounds(R.drawable.uploaded, 0, 0, 0);

-8
static private Drawable **scaleDrawable**(Drawable drawable, int width, int height) {

    int wi = drawable.getIntrinsicWidth();
    int hi = drawable.getIntrinsicHeight();
    int dimDiff = Math.abs(wi - width) - Math.abs(hi - height);
    float scale = (dimDiff > 0) ? width / (float)wi : height /
            (float)hi;
    Rect bounds = new Rect(0, 0, (int)(scale * wi), (int)(scale * hi));
    drawable.setBounds(bounds);
    return drawable;
}

Isso não responde à pergunta. A resposta relacionada ao TextView é esperada.
Rick
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.