Android之旅九 ExpandableList、SeekBar、RatingBar、DatePickerDialog控件详细介绍

接上篇博客中的控件介绍:

一、ExpandableListView,这是一个伸缩展开页列表控件,效果如下:

下面让我们看看怎么实现的吧:

一、首先定义我们的布局文件,其中有我们的main.xml文件将我们的ExpandableListView控件加入进去,还要有我们页面初始化显示出来的group1、group2这些数据的布局文件,定义为group.xml,还要有点击展开group1后child1data1等这些数据的布局文件,定义为child.xml,下面我们分别给它们进行定义:

main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <ExpandableListView
        android:id="@id/android:list"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:drawSelectorOnTop="false"/>
        
    <TextView
        android:id="@id/android:empty"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:text="No Data" />

</LinearLayout>

在main.xml中加入我们的ExpendableListView控件上面的TextView中的android:text="No Data"是默认无数据的时候所显示的文本信息

group.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/groupTo"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:paddingLeft="60px"
        android:paddingTop="10px"
        android:paddingBottom="10px"
        android:textSize="26sp"
        android:text="No Data" />

</LinearLayout>


child.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/childTo"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:paddingLeft="50px"
        android:paddingTop="5px"
        android:paddingBottom="5px"
        android:textSize="20sp"
        android:text="No Data" />

</LinearLayout>


好了,把各部分布局定义好了,下面我们通过代码显示我们要的信息吧:

我们创建的Activity必须继承自:ExpendableListActivity

/**
 * 创建一个Activity,继承自ExpandableListActivity
 * @author Administrator
 *
 */
public class MainActivity extends ExpandableListActivity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //定义一个List,该List为一级条目提供数据
        List<Map<String,String>> groups=new ArrayList<Map<String,String>>();
        Map<String,String> group1=new HashMap<String,String>();
        group1.put("group", "group1");
        Map<String,String> group2=new HashMap<String,String>();
        group2.put("group", "group2");
        groups.add(group1);
        groups.add(group2);
        
        //定义一个List,该List为第一个一级条目提供二级条目数据
        List<Map<String,String>> child1=new ArrayList<Map<String,String>>();
        Map<String,String> child1Data1=new HashMap<String,String>();
        child1Data1.put("child", "child1Data1");
        child1.add(child1Data1);
        Map<String,String> child1Data2=new HashMap<String,String>();
        child1Data2.put("child", "child1Data2");
        child1.add(child1Data2);
        
        //定义一个List,该List为第二个一级条目提供二级条目数据
        List<Map<String,String>> child2=new ArrayList<Map<String,String>>();
        Map<String,String> child2Data1=new HashMap<String,String>();
        child2Data1.put("child", "child2Data1");
        child2.add(child2Data1);
        
        //定义一个List,该List对象用来存储所有的二级条目数据
        List<List<Map<String,String>>> childs=new ArrayList<List<Map<String,String>>>();
        childs.add(child1);
        childs.add(child2);
        
        /**
         * 生成一个SimpleExpandableListAdapter对象,参数介绍
         * 1、当前上下文对象
         * 2、一级条目数据
         * 3、用来设置一级条目样式的布局文件
         * 4、指定一级条目的数据key,要与Map中的可以一样
         * 5、指定一级条目数据显示控件的id
         * 6、二级条目数据
         * 7、用来设置二级条目样式的布局文件
         * 8、指定二级条目的数据key,要与Map中的可以一样
         * 9、指定二级条目数据显示控件的id
         */
        SimpleExpandableListAdapter sela=new SimpleExpandableListAdapter
        		(this, groups, R.layout.group, new String[]{"group"},new int[]{R.id.groupTo},
        				childs, R.layout.child, new String[]{"child"}, new int[]{R.id.childTo});
        //将SimpleExpandableListAdapter对象设置给当前的ExpandableListActivity
        setListAdapter(sela);
    }
}


详细解答见代码中的注释部分,运行程序就可以看到我们之前那个页面的效果了!

二、SeekBar和RatingBar:分别表示可拖拽的进度条和星级评分条,显示效果如下:

相信大家看到图片后就应该知道它所表示的是什么了,下面我们来看看它是怎么实现的吧,很简单哦!

1、定义布局文件,main.xml在布局文件中加入:SeekBar和RatingBar控件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="测试SeekBar" />
    <SeekBar 
        android:id="@+id/seekBarId"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"/>
    
    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="测试RatingBar" />
    <!--numStars:初始化显示几颗星   stepSize:移动后增加或减少的大小-->
    <RatingBar 
        android:id="@+id/ratingBarId"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:numStars="5"
        android:stepSize="1.0"/>
</LinearLayout>

2、通过代码控制显示和加入相应的方法:

package com.harder.xin;

import android.app.Activity;
import android.os.Bundle;
import android.widget.RatingBar;
import android.widget.SeekBar;

public class MainActivity extends Activity {
	private SeekBar seekBar=null;
	private RatingBar ratingBar=null;
	
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        seekBar=(SeekBar)findViewById(R.id.seekBarId);
        //设置SeekBar的最大值
        seekBar.setMax(100);
        //为进度条绑定监听器
        seekBar.setOnSeekBarChangeListener(new SeekBarChangeListener());
        ratingBar=(RatingBar)findViewById(R.id.ratingBarId);
        //为评分条绑定监听器
        ratingBar.setOnRatingBarChangeListener(new RatingBarChangeListener());
    }
    
    //监听器,监听进度条进度的改变
    class SeekBarChangeListener implements SeekBar.OnSeekBarChangeListener{
    	//当进度条进度发生改变的时候触发该事件
    	//fromUser 是否由用户触发,true则由用户触发,false,可能是由程序控制,例如Handler
		@Override
		public void onProgressChanged(SeekBar seekBar, int progress,
				boolean fromUser) {
			System.out.println("progress-->"+progress);
		}

		//当用户开始滑东滑块的时候触发的事件
		@Override
		public void onStartTrackingTouch(SeekBar seekBar) {
			System.out.println("start-->"+seekBar.getProgress());
		}

		//当用户停止滑东滑块的时候触发的事件
		@Override
		public void onStopTrackingTouch(SeekBar seekBar) {
			System.out.println("stop-->"+seekBar.getProgress());
		}
    }
    
    class RatingBarChangeListener implements RatingBar.OnRatingBarChangeListener{
    	//当Rating发生改变的时候触发该事件
		@Override
		public void onRatingChanged(RatingBar ratingBar, float rating,
				boolean fromUser) {
			System.out.println("rating-->"+rating);
		}
    	
    }
}

相信大家看代码注释基本上就能明白他们的意思了,这里就不多描述了!!

三、DatePickerDialog和TimePickerDialog,见名之意,他们就是用来显示和设置日期和时间的对话框咯,页面展示效果如下:

    

呵呵....他们实现方法也很简单哦:

在main.xml中定义两个按钮,分别用来测试他们:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    
    <Button 
        android:id="@+id/DateButton"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="显示和设置日期"/>
   
    <Button 
        android:id="@+id/TimeButton"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="显示和设置时间"/>

</LinearLayout>

下面在代码中控制:

package com.harder.xin;

import android.app.Activity;
import android.app.DatePickerDialog;
import android.app.Dialog;
import android.app.TimePickerDialog;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.TimePicker;

public class MainActivity extends Activity {
	private Button showDateButton=null;
	private Button showTimeButton=null;
	private static final int DATE_PICKER_ID=1;
	private static final int Time_PICKER_ID=2;
	
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        showDateButton=(Button)findViewById(R.id.DateButton);
        showDateButton.setOnClickListener(new ShowDateButtonListener());
        showTimeButton=(Button)findViewById(R.id.TimeButton);
        showTimeButton.setOnClickListener(new ShowTimeButtonListener());
    }
    
    class ShowDateButtonListener implements OnClickListener{
    	//此方法用于显示DatePickerDialog
		@Override
		public void onClick(View v) {
			showDialog(DATE_PICKER_ID);
		}
    }
    
    class ShowTimeButtonListener implements OnClickListener{
		@Override
		public void onClick(View v) {
			showDialog(Time_PICKER_ID);
		}
    }
    
    @Override
    protected Dialog onCreateDialog(int id) {
    	switch (id) {
		case DATE_PICKER_ID:
			//创建一个DatePickerDialog对象,接收一个监听对象,用来显示用户设置后所显示的信息
			//后面三个参数表示启动DatePickerDialog后所提供的默认的时间
			//注意月份时间是从0开始,0到11月,所以我们得到实际月份的时间需要加1
			return new DatePickerDialog(this, onDateSetListener, 2012, 11, 25);
		case Time_PICKER_ID:
			return new TimePickerDialog(this, onTimeSetListener, 8, 23, true);
		}
    	return null;
    }
    
    //监听器,监听用户点下DatePickerDialog的set按钮后,所设置的年月日
    DatePickerDialog.OnDateSetListener onDateSetListener=new DatePickerDialog.OnDateSetListener() {
		@Override
		public void onDateSet(DatePicker view, int year, int monthOfYear,
				int dayOfMonth) {
			System.out.println(year+"--"+(monthOfYear+1)+"--"+dayOfMonth);
		}
	};
	
	TimePickerDialog.OnTimeSetListener onTimeSetListener=new TimePickerDialog.OnTimeSetListener() {
		@Override
		public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
			System.out.println("hourOfDay="+hourOfDay+"---"+"minute="+minute);
		}
	};
	
}


基本思路就是:获取new DatePickerDialog(this, onDateSetListener, 2012, 11, 25);和new TimePickerDialog(this, onTimeSetListener, 8, 23, true);对象,其中的Listener是监听里面日期或者时间变化时所触发的事件,后面的几个参数是启动后默认的日期和时间,TimePickerDialog最后一个参数表示是否启用24小时制,当我们点击set后,就会触发监听器里面的方法,相应的方法就会得到调用!注意:

1、创建相应监听器,使用的是其中的类部类:

DatePickerDialog.OnDateSetListener onDateSetListener=new DatePickerDialog.OnDateSetListener(){};

TimePickerDialog.OnTimeSetListener onTimeSetListener=new TimePickerDialog.OnTimeSetListener(){};

2、因为是在窗口中显示,所以调用了showDialog方法,将相应的标识作为参数传入进去!

3、DatePickerDialog和TimePickerDialog一般和DatePicker及TimePicker搭配使用,DatePicker及TimePicker大家可以在网上找相关资料学习,也比较简单。

4、其中日期里面的月份和java里面的new date()是一样的,都是从0开始到11月,没有12月之说,所以我们获取得到的月份需要加上1。

大家自己去把这些控件写出来吧!!欢迎大家一起来交流分享!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值