自定义效果:实现:图片和文字混合

首先创建需要组合的子布局:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:orientation="horizontal" >    <ImageView        android:id="@+id/myimage"        android:layout_width="30dp"        android:layout_height="30dp" />    <TextView        android:id="@+id/mytext"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="确定" /></LinearLayout>


编写代码,为自定义控件设置值:
package com.example.userdefinedview;import android.content.Context;import android.util.AttributeSet;import android.view.LayoutInflater;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.TextView;/** * 自定义 组建的实现 -- * 功能:复合组件 * @author Administrator * */public class MyLinearLayout extends LinearLayout {// 声明对象属性private ImageView myimage;private TextView mytext; public MyLinearLayout(Context context, AttributeSet attrs) {super(context, attrs);LayoutInflater.from(context).inflate(R.layout.my_linearlayout,this,true); //视图容器装载myimage = (ImageView) findViewById(R.id.myimage); // 获取对象mytext = (TextView) findViewById(R.id.mytext);}/** * 设置图片资源 * @param resID 资源ID */public void setImageViewImageResource(int resID){myimage.setImageResource(resID);}/** * 设置文本内容 * @param text 字符信息 */public void setMyTextText(String text){mytext.setText(text);}}



主布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="horizontal" >    <com.example.userdefinedview.MyLinearLayout        android:id="@+id/my1"        android:layout_width="100dp"        android:layout_height="wrap_content"        android:background="#ff00ff"         />    <com.example.userdefinedview.MyLinearLayout        android:layout_marginLeft="20dp"        android:id="@+id/my2"        android:layout_width="100dp"        android:layout_height="wrap_content"       android:background="#ff00ff"       /></LinearLayout>




主程序入口代码:
package com.example.userdefinedview;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.view.View.OnClickListener;import android.widget.Toast;public class MainActivity extends Activity {private MyLinearLayout my1;private MyLinearLayout my2;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);my1 = (MyLinearLayout) findViewById(R.id.my1);my2 = (MyLinearLayout) findViewById(R.id.my2);my1.setImageViewImageResource(R.drawable.a1);my1.setMyTextText("确定");my2.setImageViewImageResource(R.drawable.a6);my2.setMyTextText("取消");my1.setOnClickListener(new OnClickListener() {public void onClick(View v) {Toast.makeText(MainActivity.this, "点击了确定",Toast.LENGTH_LONG).show();}});my2.setOnClickListener(new OnClickListener() {public void onClick(View v) {Toast.makeText(MainActivity.this, "点击了取消",Toast.LENGTH_LONG).show();}});}}

更多相关文章

  1. android布局属性之margin
  2. Android 新手入门(2)-界面布局
  3. android布局 LinearLayout和RelativeLayout
  4. 多点触控测试代码 PointerLocation
  5. Android中有关布局的几个问题
  6. Android帧布局-实现渐变效果
  7. Android布局属性大全

随机推荐

  1. android通过shape.xml制作渐变背景
  2. (二)Android系统信息
  3. android Linearlayout中有关gravity与lay
  4. 笔记 RelativeLayout:相对布局管理器:
  5. Android平台开发-Android(安卓)keypad ma
  6. Android单元测试之Local unit tests(下)
  7. Android内存管理、监测剖析
  8. android开发每日汇总【2011-12-6】
  9. android:visibility属性
  10. running Android(安卓)Studio on Windows