android ListView的使用

本文介绍如何在Android应用中使用BaseAdapter配合ListView来展示解析后的数据,包括ListView子视图布局设计、适配器实现、主布局设计及Activity数据显示流程。通过示例代码展示了从数据解析到ListView展示的完整过程。

        ListView在android的开发中使用较为频繁,在这篇文章中,我们将介绍ListView搭配适配器(BaseAdapter)的使用。

        ListView就好像是一个装视图(View)的容器,其作用就是将多个相似的视图垂直的展示出来。

        适配器(Adapter)可以将数据映射到视图上,是连接数据和视图的桥梁。android提供了多种适配器,其中BaseAdapter为通用适配器,其使用方便灵活,通用性高,所以在开发中使用较多。本篇文章的目的就是将上一篇中解析出来的数据用Listview展示出来。

        大概步骤:

        1、ListView子视图布局

        2、重写适配器

        3、设计主布局

        4、用Activity将数据显示出来


        1、item_emp.xml文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" 
    >
    
    <TextView 
        android:id="@+id/emp_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
	    android:layout_marginTop="20dp"
        android:textSize="30sp"
        />
    
    <TextView 
        android:id="@+id/emp_age"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/emp_name"
        android:layout_toRightOf="@+id/emp_name"
        android:layout_marginLeft="50dp"
        android:textSize="20sp"
        />

</RelativeLayout>

        2、重写适配器EmpAdapter


import java.util.List;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

/**
 * 当系统开始绘制ListView的时候,首先调用getCount()方法。
 * 得到它的返回值,即ListView的长度。然后系统调用getView()
 * 方法,根据这个长度逐一绘制ListView的每一行。也就是说,如果让
 * getCount()返回1,那么只显示一行。而getItem()和
 * getItemId()则在需要处理和取得Adapter中的数据时调用。 
 *
 */

//继承BaseAdapter,重写BaseAdapter中的方法
public class EmpAdapter extends BaseAdapter
{
	private Context context;
	private List<Employee> empList;
	
	public EmpAdapter(Context context,List<Employee> empList)
	{
		this.context = context;
		this.empList = empList;
	}
	
	public void freshView(List<Employee> list)
	{
		this.empList = list;
		//刷新数据
		notifyDataSetChanged();
	}

	@Override
	public int getCount()
	{
		return empList == null ? 0 : empList.size();
	}

	@Override
	public Object getItem(int position)
	{
		return empList == null ? null : empList.get(position);
	}

	@Override
	public long getItemId(int position)
	{
		return position;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent)
	{
		ViewHolder holder = null;
		if(convertView == null)
		{
			//ListView子视图布局
			convertView = LayoutInflater.from(context).inflate(R.layout.item_emp, null);
			holder = new ViewHolder();
			holder.emp_name = (TextView) convertView.findViewById(R.id.emp_name);
			holder.emp_age = (TextView) convertView.findViewById(R.id.emp_age);
			convertView.setTag(holder);
		}else{
			holder = (ViewHolder) convertView.getTag();
		}
		String empName = empList.get(position).getName();
		holder.emp_name.setText(empName);
		int age = empList.get(position).getAge();
		holder.emp_age.setText(String.valueOf(age));
		return convertView;
	}

	//一种优化的方法,避免系统重复的画一个视图
	class ViewHolder {
		public TextView emp_name;
		public TextView emp_age;
	}
}

        3、主布局文件activity_main.xml

<RelativeLayout 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" >

    <TextView
        android:id="@+id/dep_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_marginLeft="20dp"
        android:textSize="40sp"
        android:text="部门:" />

    <TextView
        android:id="@+id/deptment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toRightOf="@+id/dep_name" 
        android:layout_alignBottom="@+id/dep_name"
        android:layout_marginLeft="30dp"
        android:textSize="40sp"
        />

    <TextView
        android:id="@+id/txt_emp_total"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/dep_name"
        android:layout_below="@+id/dep_name"
        android:layout_marginTop="20dp"
        android:textSize="40sp"
        android:text="总人数:" />

    <TextView
        android:id="@+id/emp_total"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/txt_emp_total"
        android:layout_toRightOf="@+id/txt_emp_total" 
        android:layout_marginLeft="30dp"
        android:textSize="40sp"
        />

    <TextView
        android:id="@+id/emp_info"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/txt_emp_total"
        android:layout_below="@+id/txt_emp_total"
        android:layout_marginTop="20dp"
        android:textSize="40sp"
        android:text="员工信息" />

    <ListView
        android:id="@+id/emp_list"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/dep_name"
        android:layout_below="@+id/emp_info"
        android:layout_marginTop="20dp" >
    </ListView>

</RelativeLayout>

        4、Activity代码

package com.example.test;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.ListView;
import android.widget.TextView;

public class MainActivity extends Activity
{
	private Context context;

	private TextView depName;// 部门名称
	private TextView depTotal;// 部门总人数
	private ListView empList;

	private DepartmentInfo depInfo;
	private EmpAdapter adapter;
	// 此处的json数据时我们的一个示例,为了看出效果,我们多加了几条数据
	String jsonString = "{\"department\": \"研发\"," + "\"total\": 30,"
			+ "\"employeeList\": [" + "{\"name\": \"张三\",\"age\": 24},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25},"
			+ "{\"name\": \"李四\",\"age\": 25}]}";

	@Override
	protected void onCreate(Bundle savedInstanceState)
	{
		super.onCreate(savedInstanceState);
		// 设置布局
		setContentView(R.layout.activity_main);
		context = MainActivity.this;
		// 初始化视图
		initView();
		// 加载数据
		loadData();
	}

	private void initView()
	{
		depName = (TextView) findViewById(R.id.deptment);
		depTotal = (TextView) findViewById(R.id.emp_total);
		empList = (ListView) findViewById(R.id.emp_list);

		adapter = new EmpAdapter(context, null);
		empList.setAdapter(adapter);
	}

	private void loadData()
	{
		// 启动一个线程来加载数据
		new Thread()
		{

			@Override
			public void run()
			{
				// 解析json数据
				depInfo = JsonUtil.parseJson(jsonString);
			}
		}.start();
		// 发送消息通知数据加载完毕
		handler.sendEmptyMessage(0x101);
	}

	private Handler handler = new Handler()
	{
		@Override
		public void handleMessage(Message msg)
		{
			if (msg.what == 0x101)
			{
				depName.setText(depInfo.getDepName());
				depTotal.setText(String.valueOf(depInfo.getTotal()));
				// 刷新数据
				adapter.freshView(depInfo.getEmpList());
			}
			super.handleMessage(msg);
		}
	};

}

        看看运行效果:


                                           


        这布局设计得相当糟糕,继续努力……

该数据集通过合成方式模拟了多种发动机在运行过程中的传感器监测数据,旨在构建一个用于机械系统故障检测的基准资源,特别适用于汽车领域的诊断分析。数据按固定时间间隔采集,涵盖了发动机性能指标、异常状态以及工作模式等多维度信息。 时间戳:数据类型为日期时间,记录了每个数据点的采集时刻。序列起始于2024年12月24日10:00,并以5分钟为间隔持续生成,体现了对发动机运行状态的连续监测。 温度(摄氏度):以浮点数形式记录发动机的温度读数。其数值范围通常处于60至120摄氏度之间,反映了发动机在常规工况下的典型温度区间。 转速(转/分钟):以浮点数表示发动机曲轴的旋转速度。该参数在1000至4000转/分钟的范围内随机生成,符合多数发动机在正常运转时的转速特征。 燃油效率(公里/升):浮点型变量,用于衡量发动机的燃料利用效能,即每升燃料所能支持的行驶里程。其取值范围设定在15至30公里/升之间。 振动_X、振动_Y、振动_Z:这三个浮点数列分别记录了发动机在三维空间坐标系中各轴向的振动强度。测量值标准化至0到1的标度,较高的数值通常暗示存在异常振动,可能与潜在的机械故障相关。 扭矩(牛·米):以浮点数表征发动机输出的旋转力矩,数值区间为50至200牛·米,体现了发动机的负载能力。 功率输出(千瓦):浮点型变量,描述发动机单位时间内做功的速率,取值范围为20至100千瓦。 故障状态:整型分类变量,用于标识发动机的异常程度,共分为四个等级:0代表正常状态,1表示轻微故障,2对应中等故障,3指示严重故障。该列作为分类任务的目标变量,支持基于传感器数据预测故障等级。 运行模式:字符串类型变量,描述发动机当前的工作状态,主要包括:怠速(发动机运转但无负载)、巡航(发动机在常规负载下平稳运行)、重载(发动机承受高负荷或高压工况)。 数据集整体包含1000条记录,每条记录对应特定时刻的发动机性能快照。其中故障状态涵盖从正常到严重故障的四级分类,有助于训练模型实现故障预测与诊断。所有数据均为合成生成,旨在模拟真实的发动机性能变化与典型故障场景,所包含的温度、转速、燃油效率、振动、扭矩及功率输出等关键传感指标,均为影响发动机故障判定的重要因素。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值