自定义Layout的基本框架

本文介绍了一个使用XML布局实现的按钮点击事件处理机制,通过创建自定义视图类SimpleMenuView,并在其内部初始化按钮监听器,实现了对特定按钮的点击响应。通过调用inflate方法加载布局文件,实例化并初始化自定义视图,最终实现按钮的事件处理。

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

 

public class SimpleMenuView extends RelativeLayout implements OnClickListener {

	private Context mContext;

	public SimpleMenuView(Context context) {
		super(context);
		mContext = context;
	}

	public SimpleMenuView(Context context, AttributeSet attrs) {
		super(context, attrs);
		mContext = context;
	}

	public SimpleMenuView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		mContext = context;
	}

	public void init(final ItemAction action) {
		final Button btn01 = (Button) findViewById(R.id.btn_1);
		final Button btn02 = (Button) findViewById(R.id.btn_2);

		btn01.setOnClickListener(this);

		btn02.setOnClickListener(this);
	}

	@Override
	public void onClick(View v) {
		// TODO Auto-generated method stub
		switch (v.getId()) {
		case R.id.btn_1:
			break;

		default:
			break;
		}
		
	}
}

 

//加载类方法
private void layoutInflater() {
		LayoutInflater mInflater = getLayoutInflater();
		if (simpleMenuView == null || simpleMenuView.getParent() == null) {
			final SimpleMenuView menuView = (SimpleMenuView) mInflater.inflate(R.layout.menu_view, null);
			simpleMenuView = menuView;
		}

		if (simpleMenuView.getParent() == null) {
			RL.addView(simpleMenuView);
		} 
		if (simpleMenuView != null) {
			ItemAction action = new ItemAction();
			action.text = "btn";
			action.action = new Action();
			simpleMenuView.init(action); // 初始化
		}
	}
	// ItemAction可以设置自定义Layout各种属性, action为其事件

	public static class ItemAction {
		public String text;
		public Action action;
	}

	public static class Action {
		public void run(Button btn) {
			
		}
	}
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值