Button点击效果及自定义控件

技术点:

1.实现Button的3种状态,无点击,按住没松开,点击过后(点击前后一般都应该是同一种状态)

2.做成自定义控件,一次制造,到处使用

步骤:

1.在layout文件夹创建一个mybutton.xml,作为自定义button的布局,

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    >
<Button
    android:background="@drawable/button_file"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
</LinearLayout>

2.在drawable文件夹创建button_file.xml文件,作为自定义button点击效果切换图

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

</selector>

3.创建一个MyButton.java继承 LinearLayout

import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.widget.LinearLayout;
public class MyButton extends LinearLayout {

    public MyButton(Context context, AttributeSet attrs) {
        super(context, attrs);
        LayoutInflater.from(context).inflate(R.layout.button_layout,this);
    }
}

4.准备工作已经做完,下面就可以在活动中直接使用这个MyButton了,先在xml中布置MyButton,然后就可以在活动中直接使用了

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.moumou.myapplication.MainActivity">

    <com.moumou.myapplication.MyButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"></com.moumou.myapplication.MyButton>

</LinearLayout>

 


 

posted @ 2017-03-23 23:29  马赛回旋  阅读(232)  评论(0编辑  收藏  举报