Градиентный цвет текста в пользовательском представлении

#android #textview #gradient #android-custom-view

#Android #textview #градиент #android-пользовательский вид

Вопрос:

У меня есть этот класс GradientTextView, который расширяет AppCompatTextView

 public class GradientTextView extends android.support.v7.widget.AppCompatTextView {

public GradientTextView(Context context) {
    super(context);
}

public GradientTextView(Context context, AttributeSet attrs) {
    super(context, attrs);
}

public GradientTextView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
}

@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
    super.onLayout(changed, left, top, right, bottom);

    //Setting the gradient if layout is changed
    if (changed) {
        getPaint().setShader(new LinearGradient(0, 0, getWidth(), getHeight(),
                ContextCompat.getColor(getContext(), R.color.colorStart),//Red Color
                ContextCompat.getColor(getContext(), R.color.colorEnd),// Blue Color
                Shader.TileMode.CLAMP));
    }
}
  

}

и вот XML-файл gradient textview

 <package.GradientTextView
        android:id="@ id/textLogin"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Login."
        android:textStyle="bold"
        android:padding="4dp"
        android:layout_marginStart="8dp"/>
  

Прямо сейчас у меня есть textview с красным и синим градиентом.
Я хотел бы изменить цвет градиента динамически.

Каков наилучший способ изменить цвет программно?

После ответа @ Nicola Gallazzi я обновляю свой вопрос, теперь новый файл GradientTextView

 public class GradientTextView extends android.support.v7.widget.AppCompatTextView {


int colorStart = ContextCompat.getColor(getContext(), R.color.colorStart);
int colorEnd = ContextCompat.getColor(getContext(), R.color.colorEnd);

public GradientTextView(Context context) {
    super(context);
}

public GradientTextView(Context context, AttributeSet attrs) {
    super(context, attrs);
}

public GradientTextView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
}

@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
    super.onLayout(changed, left, top, right, bottom);
    //Setting the gradient if layout is changed
    if (changed) {
        getPaint().setShader(new LinearGradient(0, 0, getWidth(), getHeight(), colorStart, colorEnd,
                Shader.TileMode.CLAMP));
    }
}

public void setGradientColors(int colorStart, int colorEnd) {
    this.colorStart = colorStart;
    this.colorEnd = colorEnd;
    // this forces view redrawing
    invalidate();
}
  

}

но вот новая проблема, которая заключается в том, что когда я использую это в деятельности, подобной @Nicola Gallazzi, отображается ошибка.

код

         textView.setGradientColors(ContextCompat.getColor(this,R.color.ncolorEnd, R.color.ncolorStart));
  

ОШИБКА

Здесь вы можете найти ошибку, которая

Ответ №1:

Вы должны определить свои colorStart и colorEnd как переменные экземпляра вашего GradientTextView класса. Затем определите общедоступный метод внутри класса, чтобы программно задать colorStart и colorEnd:

 public class GradientTextView extends android.support.v7.widget.AppCompatTextView {

    private int colorStart = ContextCompat.getColor(getContext(), R.color.colorPrimary);
    private int colorEnd = ContextCompat.getColor(getContext(), R.color.colorAccent);


    public GradientTextView(Context context) {
        super(context);
    }

    public GradientTextView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public GradientTextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
    }

    @Override
    protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
        super.onLayout(changed, left, top, right, bottom);
        //Setting the gradient if layout is changed
        if (changed) {
            getPaint().setShader(new LinearGradient(0, 0, getWidth(), getHeight(), colorStart, colorEnd,
                    Shader.TileMode.CLAMP));
        }
    }

    public void setGradientColors(int colorStart, int colorEnd) {
        this.colorStart = colorStart;
        this.colorEnd = colorEnd;
        // this forces view redrawing
        invalidate();
    }

}
  

Комментарии:

1. братан, у меня есть одно сомнение в экземпляре Paint. Что такое R.color.startColor?

2. Вы имеете в виду R.color.colorStart? Я скопировал и вставил его из вопроса

3. и еще одно сомнение. Как это использовать программно?

4. Хорошо, согласно моему вопросу R.color.colorStart — это ссылка на красный цвет, а R.color.colorEnd — это ссылка на синий цвет, который определен в color.xml файл

5. Теперь я обновил свой ответ. Вы можете это проверить.

Ответ №2:

Вы можете просто создать градиент, который можно нарисовать из кода Java, как показано ниже-

 GradientDrawable drawable = new GradientDrawable();
drawable.setStroke(width, Color.RED);
drawable.setCornerRadius(8);
drawable.setColor(ContextCompat.getColor(context,R.color.colorRed));
  

И установите для отрисовки значение imageview, как показано ниже

     imageView.setBackgroundDrawable(drawable);
  

Комментарии:

1. братан, я раскрашиваю текст градиентным цветом, а не устанавливаю фон в качестве градиента.?

2. Используйте метод setColors, чтобы задать разные цвета в градиенте. Проверьте эту ссылку для ссылки на GradientDrawable developer.android.com/reference/android/graphics/drawable /…

3. Я не хочу, чтобы его можно было рисовать