Android学习之自定义控件

本文介绍了在Android中创建自定义控件的三种方法:继承现有控件并改进、组合多个控件形成新组件及直接继承View类进行重绘。通过具体示例展示了自定义控件的具体实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用的自定义控件的方式大致有三种:

        1.继承自现有控件,加以改进,如继承TextView;

        2.将几种控件进行组合,构成新的组件;

        3.继承View类,重绘一个组件。

自定义控件的方法:

首先定义一个自定义控件类(MyView.java):

</pre><pre name="code" class="html">package com.jtext.chessdisplay;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Toast;

public class MyView extends View{

	Context context1;
		// TODO Auto-generated constructor stub
	public MyView(Context context, AttributeSet attrs) {
		super(context, attrs);
		context1=context;
		// TODO Auto-generated constructor stub
	}
	
	@Override
	protected void onDraw(Canvas canvas){
		super.onDraw(canvas);
		Paint paint=new Paint();
		paint.setColor(Color.RED);
		paint.setShadowLayer(2, 3, 4, Color.GRAY);
		Rect r=new Rect(40,40,200,100);
		canvas.drawRect(r,paint);
		paint.setColor(Color.BLUE);
	    canvas.drawText("自定义控件测试", 40, 40, paint);
	}

	@Override
	public boolean onTouchEvent(MotionEvent event) {
		// TODO Auto-generated method stub
		switch (event.getAction()){
		case MotionEvent.ACTION_DOWN:
			Toast.makeText(context1, "自定义组件测试",0).show();
			break;
		case MotionEvent.ACTION_MOVE:
			Toast.makeText(context1, "HUAHUA",0).show();
			break;
		}
		return super.onTouchEvent(event);
				
	}
 
}

接着,就可以像普通控件一样,在布局里声明使用(myview.xml):

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" 
    >
  <com.jtext.chessdisplay.MyView
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
      android:id="@+id/myView"  
      />  
</LinearLayout>
最后,在MainActivity里显示:

package com.jtext.chessdisplay;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends Activity {
    MyView2 mv;
    MyView2 mv1;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.myview);}
}


二、组合控件

以继承布局类来自定义控件为例.

布局myview2

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
  <ImageView 
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/iv"
      android:layout_gravity="center_vertical"/>
  <TextView 
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/tv"
      android:layout_gravity="center_vertical"
      android:gravity="center_horizontal"/>
</LinearLayout>
控件定义MyView2.java

package com.jtext.chessdisplay;

import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;

public class MyView2 extends LinearLayout{
 private ImageView iv;
 private TextView tv;
 int i=0;
 Context context1;
	public MyView2(Context context, AttributeSet attrs) {
		super(context, attrs);
		// TODO Auto-generated constructor stub
		LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
	    inflater.inflate(R.layout.myview2, this); 
	    iv=(ImageView) findViewById(R.id.iv);  
	    tv=(TextView)findViewById(R.id.tv);  
	    context1=context;
	    iv.setOnTouchListener(new myTouchListener());
	}
	public void setImageResource(int resid){
		iv.setImageResource(resid);
	}
	public void setTextView(String str,int color){
		tv.setText(str);
		tv.setTextColor(color);
	}
	class myTouchListener implements  OnTouchListener {

		@Override
		public boolean onTouch(View v, MotionEvent event) {
			// TODO Auto-generated method stub
			switch (v.getId()){
			case R.id.iv:
				i++;
				Toast.makeText(context1, "数量更改成功", 0).show();
			    tv.setText(i+"");;
				break;
			}
			return false;
		}
		
	}
}
MainActivity里进行显示:

package com.jtext.chessdisplay;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends Activity {
    MyView2 mv;
    MyView2 mv1;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.myview3);
		mv=(MyView2)findViewById(R.id.mv);
		mv1=(MyView2)findViewById(R.id.mv1);
		mv.setImageResource(R.drawable.cart);
		mv.setTextView("测试", Color.RED);
		mv1.setImageResource(R.drawable.cart);
		mv1.setTextView("测试", Color.BLUE);
	}
}
             






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值