自定义View之组合控件

来源:互联网 发布:js ajax获取json文件 编辑:程序博客网 时间:2024/05/18 00:35

Android基础之自定义View


博主感觉以前学习过和用过的东西好像很快又忘记了,为了向大神们看齐,最主要还是为了自己以后方便查看和回忆,打算用博客把它们记录下来,也希望自己的技术可以通过一点点的积累,慢慢向一名真正的程序员高手靠近,嘿嘿嘿......,毕竟希望还是有的嘛,像咱们这种咸鱼也有可能会翻身嘛!对不对!好的,我们开始吧!



在咱们Android里面,自定义View主要有三种实现方式:
1、组合控件
2、自绘控件
3、继承控件

今天咱们先来看看第一种,组合控件!
组合控件,顾名思义就是将一些小的控件组合起来形成一个新的控件,这些小的控件多是系统自带的控件。比如很多应用中普遍使用的标题栏控件,其实用的就是组合控件,那么下面将通过实现一个简单的标题栏自定义控件来说说组合控件的用法。


1、新建一个Android项目,创建自定义标题栏的布局文件group.xml:
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="80px"    android:layout_margin="20px"    android:background="#611eff00">    <Button        android:id="@+id/button"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_centerVertical="true"        android:layout_marginLeft="50px"        android:text="这是按钮"        android:textSize="20px" />    <TextView        android:id="@+id/textview"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_centerVertical="true"        android:textColor="#e41515"        android:gravity="center"        android:text="这是标题"        android:textSize="30px" /></RelativeLayout>

我们这里XML文件非常简单,里面就是一个Button和一个TextView




2、创建一个类GroupView,继承自RelativeLayout:
public class GroupView extends RelativeLayout {    //按钮和文本控件    private Button mButton;    private TextView mTextView;    //重写父类的构造方法    public GroupView(Context context) {        super(context);        initialize(context);//调用自定义的初始化方法    }    public GroupView(Context context, AttributeSet attrs) {        super(context, attrs);        initialize(context);    }    public GroupView(Context context, AttributeSet attrs, int defStyleAttr) {        super(context, attrs, defStyleAttr);        initialize(context);    }    //加载布局的方法    private void initialize(Context context) {        LayoutInflater.from(context).inflate(R.layout.group, this);        //获取控件        mButton = (Button) findViewById(R.id.button);        mTextView = (TextView) findViewById(R.id.textview);    }    // 为按钮添加自定义点击事件    public void setLeftButtonListener(OnClickListener listener) {        mButton.setOnClickListener(listener);    }    // 设置标题的方法    public void setTitleText(String title) {        mTextView.setText(title);    }}

GroupView中主要是为自定义的标题栏加载了布局,为返回按钮添加事件监听方法,并提供了设置标题文本的方法。



3、在activity_main.xml中引入自定义的标题栏:
<?xml version="1.0" encoding="utf-8"?><RelativeLayout 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"    tools:context="com.example.administrator.myapplication.MainActivity">    <com.example.administrator.myapplication.GroupView        android:id="@+id/groupview"        android:layout_width="match_parent"        android:layout_height="wrap_content"         /></RelativeLayout>


4、在MainActivity中获取自定义的标题栏,并且为返回按钮添加自定义点击事件:
public class MainActivity extends AppCompatActivity {    private GroupView mGroupView;    private int str;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        mGroupView= (GroupView) findViewById(R.id.groupview);        initview();    }    private void initview() {        //给自定义控件添加点击事件        mGroupView.setLeftButtonListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                str++;            Toast.makeText(MainActivity.this,"点击了按钮!",Toast.LENGTH_LONG).show();                mGroupView.setTitleText("标题被点击了"+str+"次");            }        });    }}
只是一个简单的测试,我就随便来了个Toast,顺便记录一下标题的点击次数并且显示出来!

下面是运行的效果!






怎么样,是不是很简单呢?大家也可以根据需求,制作出复杂的组合控件出来,只需要知道怎么回事,那么就没什么困难了,对吧!




1 0