Програмно встановлений лівий малюнок у TextView


285

У мене тут textView у xml.

<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"/>

Як ви бачите, я встановив DravableLeft в xml.

Я хотів би змінити код, який можна зрозуміти.

Чи варто все-таки робити це? Або встановити код DravableLeft для перегляду тексту?

Відповіді:


781

Ви можете використовувати setCompoundDrawablesWithIntrinsicBounds (int зліва, int зверху, int справа, int знизу)

встановіть 0 там, де не потрібно зображень

Приклад для малювання зліва:

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

Порада: Щоразу, коли ви знаєте будь-який атрибут XML, але не маєте поняття, як його використовувати під час виконання. просто перейдіть до опису цього властивості у розробнику doc. Там ви знайдете споріднені методи, якщо вони підтримуються під час виконання. тобто для DravableLeft


Тож де я можу встановити схему для цього?
coder_For_Life22

1
+1 Його робота для налаштування Android: dravableLeft для TextView програмно. Thanx мат
Paresh Mayani

35
+1 для додавання підказки. це має бути найперше, про що говорять розробники при використанні документів
gmjordan

@BrainCrash Ти маєш рацію, я неправильно сприйняв це за допомогою більш нового методу, який має ту саму назву.
зневірений

2
Здрастуйте, я використовував цей метод для встановлення чернетки, але не міг знайти його лічильника. Мені довелося перевірити, чи є в текстовому перегляді складених текстів. Як це зробити? Спробував порівняти textview.getCompoundDrawablesRelative()[0]зmContext.getResources().getDrawable(R.drawable.my_drawable)
ravi


6

Ви можете скористатися будь-яким із наведених нижче способів встановлення Dravable в TextView:

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

2- setCompoundDrawables (Left_Drawable, Top_Drawable, Right_Drawable, Bottom_Drawable)

А щоб отримати джерело ресурсів, ви можете використовувати:

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

Ні, setCompoundDrawablesWithIntrinsicBounds (int, int, int, int) - це API Levet 3 з вашого власного посилання ...
BrainCrash

1

Використання Котліна:

Ви можете створити функцію розширення або просто використовувати setCompoundDrawablesWithIntrinsicBoundsбезпосередньо.

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

Якщо вам потрібно змінити розмір рисунку, ви можете використовувати цю функцію розширення.

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)
}

Щоб отримати по-справжньому фантазії, створіть обгортку, яка дозволяє змінювати розмір та / або колір.

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

Розширення Котліна + кілька накладок навколо малюючого

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

0

Є два способи зробити це або ви можете використовувати для нього XML або Java. Якщо він статичний і не потребує змін, то ви можете ініціалізуватись у XML.

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

Тепер, якщо вам потрібно змінити піктограми динамічно, ви можете це зробити, зателефонувавши до значків на основі подій

       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;
}

Це не дає відповіді на запитання. Очікується відповідь, пов'язана з TextView.
Рік
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.