Android组合控件

一个带图片和文字的按钮,效果图


1,Button的布局文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/imageview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
         />

    <TextView
        android:id="@+id/textview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
         />

</LinearLayout>

2,自定义的控件

package com.exmple.custonbutton;

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

public class ImgButton extends LinearLayout {
	private ImageView imageView;
	private TextView textView;

	public ImgButton(Context context) {
		super(context);
		// TODO Auto-generated constructor stub
	}

	public ImgButton(Context context, AttributeSet attrs) {
		super(context, attrs);
		//导入布局
		LayoutInflater.from(context)
				.inflate(R.layout.img_text_button, this,true);
		imageView = (ImageView) findViewById(R.id.imageview);
		textView = (TextView) findViewById(R.id.textview);
	}

	public void setImageResource(int resId) {
		imageView.setImageResource(resId);
	}

	public void setTextContent(String content) {
		textView.setText(content);
	}

}

3,使用

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="bottom"
    android:orientation="horizontal" >

    <com.exmple.custonbutton.ImgButton
        android:id="@+id/button_ok"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:layout_weight="1"
        android:background="@drawable/dialog_btn_selector"
        android:clickable="true" />

    <com.exmple.custonbutton.ImgButton
        android:id="@+id/button_cancle"
        android:layout_width="0dp"
        android:layout_height="50dp"
        android:layout_weight="1"
        android:background="@drawable/dialog_btn_selector"
        android:clickable="true" />

</LinearLayout>
4,代码中控制界面

package com.exmple.custonbutton;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		ImgButton buttonok = (ImgButton) findViewById(R.id.button_ok);
		buttonok.setImageResource(R.drawable.save_nomal);
		buttonok.setTextContent("确定");

		ImgButton buttonCancle = (ImgButton) findViewById(R.id.button_cancle);
		buttonCancle.setImageResource(R.drawable.cancel_nomal);
		buttonCancle.setTextContent("取消");

	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值