Android: Ustaw margines na lewą stronę przycisku radiobutton do rysowania

Jan 10 2021

Chcę ustawić margines / dopełnienie między moim rysowanym radiobuttonem a jego lewą stroną, np .: Ustawienie marginesu 8dp między moim rysowanym radiobuttonem a lewą stroną ekranu. Wiem, jak ustawić margines między samym radiobuttonem, ale nie wiem, jak to zrobić z rysowanym radiobuttonem. Wiem również, jak ustawić prawy margines do rysowania przycisku radiobutton za pomocą paddngStart = "YOUR_PADDING".

czy to możliwe?

Oto zdjęcie tego, co mam na myśli:

Obecnie

Czego chcę

EDYTOWAĆ

Powyższa pisemna odpowiedź działa. Dla tych, którzy chcą ustawić wartość wewnątrz układu, a nie programowo, napisałem wiążący adapter:

@BindingAdapter("setDrawableLeftPadding")
fun setDrawableLeftPadding(view: CustomRadioButton, padding: Float) {
    view.setStartPaddingDp(padding)
}

Możesz go następnie użyć w układzie CustomRadioButton z app:setDrawableLeftPadding="@{8f}"

Odpowiedzi

1 mhdwajeeh.95 Jan 10 2021 at 23:20

Jeśli chcesz osiągnąć dokładnie to samo, co pokazuje twoje drugie zdjęcie, możesz napisać niestandardowy, RadioButtonktóry obsługuje to wypełnienie, niestandardowy kod widoku może wyglądać tak (w Kotlinie) :

import android.content.Context
import android.graphics.Canvas
import android.util.AttributeSet
import androidx.appcompat.widget.AppCompatRadioButton

class CustomRadioButton : AppCompatRadioButton {

    // the value of your padding (in pixels) from the start of the radio button
    var startPadding: Int = 0
        get
        set(value) {
            field = value
            requestLayout()
        }

    constructor(context: Context?) : super(context)
    constructor(context: Context?, attrs: AttributeSet?) : super(context, attrs)
    constructor(context: Context?, attrs: AttributeSet?, defStyleAttr: Int) : super(
        context,
        attrs,
        defStyleAttr
    )


    fun setStartPaddingDp(paddingDp: Float) {
        startPaddingPx = (paddingDp * context.resources.displayMetrics.density).toInt()
    }


    override fun onDraw(canvas: Canvas?) {
        // todo: handle Right-To-Left layouts
        canvas?.translate(startPadding.toFloat(), 0f)

        super.onDraw(canvas)
    }

    override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec)

        setMeasuredDimension(measuredWidth + startPadding, measuredHeight)
    }
}

Możesz ustawić wartość dopełnienia, ustawiając wartość pola startPadding, na przykład:

yourCustomRadioButton.startPadding = 100 // this value is in pixels

// or

yourCustomRadioButton.setStartPaddingDp(100) // this value is in DP