android实现按钮圆角点击背景、字体颜色都改变

实现圆角按钮,点击的时候背景和字体的颜色都改变,这里的实现效果如下:原状态背景为白色,字体为蓝色,当点击的时候背景为蓝色,字体为白色。介绍两种实现方式。1、使用button。2、实现自定义TextView。

1.使用Button首先在drawable下建一个Button背景的btn_bg_round_click.xml文件。在这里面设置Button原状态和按下的时候,背景的颜色、圆角半径、边框宽度和颜色。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="false">
        <shape android:shape="rectangle" >
            <solid android:color="@color/color_white" />
            <corners android:radius="5dp" />
            <stroke android:width="1dp" android:color="#acacac" />
        </shape>
    </item>

    <item android:state_pressed="true" >
        <shape android:shape="rectangle">
            <solid android:color="@color/color_blue" />
            <corners android:radius="5dp" />
            <stroke android:width="1dp" android:color="#acacac" />
        </shape>
    </item>
</selector>

 

 再建一个改变字体颜色的btn_click_text_color.xml文件。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="false" android:color="@color/color_blue"/>
    <item android:state_pressed="true" android:color="@color/color_white"/>
</selector>

最后在Button的background和textColor属性中引用。

<Button
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="@drawable/btn_bg_round_click"
        android:textColor="@drawable/selector_btn_click_text_color"
        android:text="登录"
        android:textSize="23sp"
        android:gravity="center" />

2. 实现自定义TextView

 

首先在values文件夹下建一个attrs.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <declare-styleable name="ButtonTextView">
        <attr name="pressTxtColor" format="color"></attr>
        <attr name="pressBgc" format="color"></attr>
        <attr name="stroke" format="dimension"></attr>
        <attr name="corner" format="dimension|fraction"></attr>
    </declare-styleable>
</resources>

再建一个ButtonTextView类,让它继承AppCompatTextView类

public class ButtonTextView extends AppCompatTextView {

    private final String NAME_SPACE = "http://schemas.android.com/apk/res/android";
    private final String ATTR_BGC = "background";
    private final String ATTR_TXTC = "textColor";

    private final int DEFAULT_TEXT_COLOR = 0x8a000000;
    //文字演策
    private int txtC = DEFAULT_TEXT_COLOR;
    private int pressTxtC = DEFAULT_TEXT_COLOR;
    //背景色
    private int bgc;
    private int pressBgc;
    //圆角
    private float corner;
    private float cornerPercent;
    //边框
    private int stroke;

    /* 通过代码创建对象时,不检索自定义属性*/
    public ButtonTextView(Context context) {
        super(context);
        /*默认颜色*/
        setTextColor(DEFAULT_TEXT_COLOR);
    }

    public ButtonTextView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public ButtonTextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();

        if (attrs != null) {
            String bc = attrs.getAttributeValue(NAME_SPACE, ATTR_BGC);
            if (TextUtils.isEmpty(bc)) {
                bgc = Color.WHITE;
            } else if (bc.startsWith("#")) {
                bgc = Color.parseColor(bc);
            } else if (bc.startsWith("@")) {
                bgc = ContextCompat.getColor(context, Integer.valueOf(bc.substring(1)));
            }

            String tc = attrs.getAttributeValue(NAME_SPACE, ATTR_TXTC);
            if (TextUtils.isEmpty(tc)) {
                txtC = DEFAULT_TEXT_COLOR;
            } else if (tc.startsWith("#")) {
                txtC = Color.parseColor(tc);
            } else if (tc.startsWith("@")) {
                txtC = ContextCompat.getColor(context, Integer.valueOf(tc.substring(1)));
            }

        }

        TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.ButtonTextView);

        pressTxtC = ta.getColor(R.styleable.ButtonTextView_pressTxtColor, txtC);
        pressBgc = ta.getColor(R.styleable.ButtonTextView_pressBgc, bgc);

        //处理圆角度
        final String cornerValue = ta.getString(R.styleable.ButtonTextView_corner);
        if (!TextUtils.isEmpty(cornerValue)) {
            if (cornerValue.contains("%")) {
                corner = -1;
                cornerPercent = ta.getFraction(R.styleable.ButtonTextView_corner, 1, 1, 0f);
            } else {
                corner = ta.getDimensionPixelSize(R.styleable.ButtonTextView_corner, 0);
            }
        }

        //处理边框
        stroke = ta.getDimensionPixelSize(R.styleable.ButtonTextView_stroke, 0);

        ta.recycle();
    }

    private void init() {
        setClickable(true);
    }


    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
        if (corner < 0) {
            corner = cornerPercent * h;
        }
        setBgcDrawable(bgc, pressBgc, corner, stroke);
        setTxtColor(txtC, pressTxtC);
    }

    /**
     * @param txtC      正常情况下的字体颜色
     * @param pressTxtC 按下时的字体颜色
     */
    private void setTxtColor(@NonNull int txtC, @NonNull int pressTxtC) {

        if (txtC == pressTxtC) {
            setTextColor(txtC);
            return;
        }

        int[] colors = new int[]{pressTxtC, txtC};

        int[][] states = new int[2][];
        states[0] = new int[]{android.R.attr.state_pressed};
        states[1] = new int[]{};

        ColorStateList colorStateList = new ColorStateList(states, colors);

        setTextColor(colorStateList);
    }


    /**
     * @param bgc      正常背景色
     * @param pressBgc 按下背景色
     * @param corner   圆角
     * @param stroke   边框
     */
    private void setBgcDrawable(@NonNull int bgc, @NonNull int pressBgc, float corner, int stroke) {

        GradientDrawable bgcDrawable = new GradientDrawable();
        GradientDrawable pBgcDrawable = new GradientDrawable();

        bgcDrawable.setCornerRadius(corner);
        bgcDrawable.setStroke(stroke, txtC == 0 ? DEFAULT_TEXT_COLOR : txtC);
        bgcDrawable.setColor(bgc);


        if (bgc == pressBgc) {
            setBackgroundDrawable(bgcDrawable);
            return;
        }

        pBgcDrawable.setCornerRadius(corner);
        pBgcDrawable.setStroke(stroke, pressBgc);
        pBgcDrawable.setColor(pressBgc);

        StateListDrawable stateListDrawable = new StateListDrawable();
        stateListDrawable.addState(new int[]{android.R.attr.state_pressed}, pBgcDrawable);
        stateListDrawable.addState(new int[]{}, bgcDrawable);

        setBackgroundDrawable(stateListDrawable);
    }

    /**
     * 设置背景色
     *
     * @param bgc
     * @param pressBgc
     */
    public void setBgcDrawable(@NonNull int bgc, @NonNull int pressBgc) {
        this.bgc = bgc;
        this.pressBgc = pressBgc;
    }

    /**
     * 设置文字颜色
     *
     * @param txtC
     * @param pressTxtC
     */
    public void setTextColor(@NonNull int txtC, @NonNull int pressTxtC) {
        this.txtC = txtC;
        this.pressTxtC = pressTxtC;
    }

    public void setCorner(float corner) {
        this.corner = corner;
    }

    public void setStroke(int stroke) {
        this.stroke = stroke;
    }

    public void setTxtC(int txtC, int pressTxtC) {
        this.txtC = txtC;
        this.pressTxtC = pressTxtC;
    }

}

最后在xml中使用,使用和普通的Button差不多。只不过在这里面定义了一些按下时的效果属性。pressBgc按下时背景的颜色。

pressTxtColor按下时字体颜色,stroke边框宽度。

<com.geocompass.collect.view.ButtonTextView
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_margin="20dp"
        android:background="@color/color_white"
        android:gravity="center"
        android:text="登录"
        android:textSize="23sp"
        android:textColor="@color/color_blue"
        android:translationZ="3dp"
        app:corner="5dp"
        app:pressBgc="@color/color_blue"
        app:pressTxtColor="@color/color_white"
        app:stroke="1px" />

 

  • 1
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在 Android 上创建图形按钮,可以使用以下步骤: 1. 在 res/drawable 文件夹中创建一个 XML 文件,来定义你想要的按钮形状。例如,你可以创建一个名为 "button_shape.xml" 的文件,并在其中添加以下代码: ``` <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <corners android:radius="10dp" /> <solid android:color="@color/button_color" /> </shape> ``` 这将创建一个圆角矩形按钮,颜色为 "@color/button_color"。 2. 在布局文件中,使用 Button 元素来创建一个按钮,并为其设置样式为你刚才定义的按钮形状: ``` <Button android:id="@+id/my_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/button_shape" android:text="My Button" /> ``` 3. 在代码中,可以像处理普通按钮一样处理这个图形按钮: ``` Button myButton = findViewById(R.id.my_button); myButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理按钮点击事件 } }); ``` 这样,一个简单的图形按钮就完成了。你可以根据需要自定义按钮形状和颜色,以适应你的应用程序风格。 ### 回答2: Android 图形按钮是一种在Android应用程序中常见的UI元素。它是一种用于用户交互的控件,通常用于触发某个操作或跳转到其他界面。 Android图形按钮通常包含一个图标或者是一个图标和文本组合而成。这个图标可以是一张图片或者是由字体图标库提供的矢量图标。图形按钮的外观可以通过设置按钮背景色、边框样式、文字颜色等属性进行自定义。 在Android开发中,我们通常使用Button控件来创建图形按钮。在XML布局文件中,我们可以使用`Button`标签来定义一个图形按钮,并通过设置`android:background`属性来指定按钮背景样式。同时,我们还可以使用`android:drawableLeft`、`android:drawableRight`等属性来设置按钮中图标的位置。在Java代码中,我们可以通过`setOnClickListener`方法来为按钮绑定点击事件的处理逻辑。 使用图形按钮可以为用户提供直观的操作体验,通过不同的图标或颜色搭配,可以增加按钮的辨识度,并且可以提高用户对界面的可理解性和使用便捷性。在设计图形按钮时,需要考虑按钮的大小、样式和布局,以及按钮与其他UI元素的协调性,从而实现更好的用户交互体验。 综上所述,Android图形按钮是一种常见的用户交互控件,通过图标和文字组合形成,通过设置属性和绑定点击事件的方式实现功能。它可以提供直观的操作体验,增加界面可理解性和使用便捷性,是Android应用程序中不可或缺的一部分。 ### 回答3: Android 图形按钮是一种用于用户界面的交互元素,它可以呈现各种形状和样式的图形。Android 提供了多种方式来创建图形按钮,其中最常用的方式是使用Button控件和ImageView控件。 Button控件是Android中最基本的按钮控件之一,它可以显示文本、图标或二者的组合。可以通过设置Button背景、文本、文本颜色和点击事件来自定义按钮的外观和行为。 ImageView控件是一种显示图像的控件,它可以加载本地或网络上的图像资源。将图像设置为按钮背景,可以实现图形按钮效果。可以使用setImageResource()方法或setImageBitmap()方法来设置ImageView的图像资源。 通过设置图形按钮点击事件,可以为按钮添加事件监听器。当用户点击按钮时,可以执行相应的操作,例如跳转到另一个界面、提交表单或执行其他逻辑。 除了使用基本的Button和ImageView控件,还可以使用自定义控件或第三方库来创建更复杂的图形按钮自定义控件可以继承Button或ImageView来实现特定的按钮效果,例如圆形按钮、带有动画效果按钮等。第三方库提供了丰富的图形按钮样式和动画效果,可以通过导入库并设置相应的属性来使用。 总结来说,Android 图形按钮是一种用于用户界面的交互元素,可以通过Button和ImageView控件、自定义控件或第三方库来创建。通过设置背景、文本、文本颜色和点击事件等属性,可以自定义图形按钮的外观和行为。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值