Android:使用时间轴创建ListView

时间:2012-12-06 00:42:28

标签: android listview

我的应用程序中有一个ListView,其中包含在不同时间发生的事件。

在我的ListView中,我希望按时间顺序显示它们,并在左侧显示时间。

| 12:00 |   Event1
| 13:00 |   
| 14:00 |   Event2
| 15:00 |   Event2
| 16:00 |   Event3

这样的事情,任何人都可以提供从哪里开始的建议吗?

2 个答案:

答案 0 :(得分:0)

您必须创建自己的适配器,它将扩展BaseAdapter并在其上创建将用于每一行的特定布局文件!

假设您有一个Map<String,String> mMap = new HashMap<String,String>,其中有事件,另一个位置是事件的时间。

然后你创建新的适配器,让我们说它是MyAdapter。

MyAdapter mAdapter = new MyAdapter(mMap);

通过调用.setAdapter()方法将适配器添加到ListView。

例如。 myListView.setAdapter(MyAdapter);

在自定义适配器中,您必须实现一些方法。他们是getView()

您必须通过传递给适配器的HashMap<String,String>提供的数据进行解析。 在row_layout.xml中,您必须使用相对布局并添加相应的文本字段以显示所需的信息!

希望它有所帮助!!!

也请检查此链接:http://www.androidhive.info/2012/02/android-custom-listview-with-image-and-text/

答案 1 :(得分:0)

通常,列表适配器使用某种数据结构或容器来存储其对象。如果需要添加新元素,请先将其添加到容器中,对其元素进行排序,然后调用

adapter.notifyDataSetChanged();

让它知道它的数据已经改变,需要更新。

这只是一个引导您朝着正确方向前进的小例子。我希望你会发现它很有用。

定义ListActivity:

package com.myapp.listviewexample;

import android.app.ListActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class ListViewExampleActivity extends ListActivity {

    static final String[] COUNTRIES = new String[] {
        "Afghanistan", "Albania", "Algeria", "American Samoa", "Andorra",
        "Angola", "Anguilla", "Antarctica", "Antigua and Barbuda", "Argentina",
        "Armenia", "Aruba", "Australia", "Austria", "Azerbaijan"
      };


    @Override
    public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);

      //setListAdapter(new ArrayAdapter<String>(this, R.layout.list_item, COUNTRIES));
      final MyListAdapter adapter = new MyListAdapter(this, COUNTRIES);
      setListAdapter(adapter);

      ListView lv = getListView();
      //lv.setTextFilterEnabled(true);

      lv.setOnItemClickListener(new OnItemClickListener() {
        public void onItemClick(AdapterView<?> parent, View view,
            int position, long id) {

            adapter.removeItem(position);
            adapter.notifyDataSetChanged();
          // When clicked, show a toast with the TextView text
          Toast.makeText(getApplicationContext(), ((TextView) view).getText() + " removed",
              Toast.LENGTH_SHORT).show();
        }
      });
    }

}

定义列表适配器:

package com.myapp.listviewexample;

import java.util.ArrayList;
import java.util.Arrays;

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

public class MyListAdapter extends BaseAdapter {

    private ArrayList<String> items;
    private Context mContext;

    public MyListAdapter(Context c, String[] countries) {
        items = new ArrayList<String>(Arrays.asList(countries));
        mContext = c;
        Log.i("MyListAdapter", "countries.length == items.size() " + (countries.length == items.size()));
    }

    public int getCount() {
        return items.size();
    }

    public Object getItem(int position) {
        return items.get(position);
    }

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

    public void removeItem(int position) {
        items.remove(position);
    }

    // create a new ImageView for each item referenced by the Adapter
    public View getView(int position, View convertView, ViewGroup parent) {
        View view;
        if (convertView == null) {  // if it's not recycled, initialize some attributes
            LayoutInflater li = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            view = li.inflate(R.layout.list_item, null);
        } else {
            view = convertView;
        }

        TextView tv = (TextView) view;//.findViewById(R.id.text_view_item);
        tv.setText(items.get(position));

        return view;
    }

}

考虑使用适配器的ViewHolder模式,以避免不必要的视图膨胀。这篇文章可能有所帮助: How can I make my ArrayAdapter follow the ViewHolder pattern?

定义list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/text_view_item"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:padding="10dp"
    android:textSize="16sp" >
</TextView>

您只需在list元素中定义另一个TextView即可满足您的需求。 不要忘记通过addElement(..)方法扩展适配器,该方法将元素添加到ArrayList(在本例中),然后使用Collections.sort(..)对其进行排序。 考虑使用一对必须实现Comparable的两个字符串,这样您就可以根据时间进行排序,甚至可以根据更复杂的情况进行排序。