Listview实现多个栏目(多个标题+每个标题下的内容)

 http://qsyz2002.blog.163.com/blog/static/7216669201143115331662/

 

 

 其中日期标题部分视图布局:

view sourceprint?1 <?xml version=”1.0″ encoding=”utf-8″?>  

 <LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”  

 android:orientation=”vertical” android:layout_width=”fill_parent”  

 android:layout_height=”10dip” android:background=”@drawable/section_background”>  

 <TextView android:id=”@+id/section_title”  

 android:layout_width=”fill_parent” android:layout_height=”match_parent” />  

 </LinearLayout> 

 

带图片的条目布局部分:

<?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=”wrap_content”  

android:orientation=”horizontal” >  

 <ImageView android:id=”@+id/image” android:src=”@drawable/p”  

 android:layout_width=”wrap_content” android:layout_height=”wrap_content” />  

 <TextView android:id=”@+id/title” android:layout_width=”wrap_content”  

 android:layout_height=”wrap_content” />  

 </LinearLayout> 

 

 

 

问题在于,如何在ListView中既有标题条目又有内容条目。

这里用到了设计模式中的Iterator模式。在java代码中示例有Iterator,可以迭代ArrayList,HashSet等不同的数据结构对象。

 

ListElement是接口:

package com.easymorse.listview.customer;    

 import android.content.Context;  

 import android.view.LayoutInflater;  

import android.view.View;  

  

 public interface ListElement {  

 public int getLayoutId();  

   

 public boolean isClickable();  

 

 public View getViewForListElement(LayoutInflater layoutInflater,  

 Context context, View view);  

} 

  

其中:

  • getLayoutId()返回布局的值;
  • isClickable()返回是否可点击;
  • getViewForListElement()返回视图对象。

这个接口有两个实现:

  • SectionListElement,用于实现标题条目;
  • ContentListElement,用于实现内容条目。

见SectionListElement代码:

package com.easymorse.listview.customer;    

 import android.content.Context;  

 import android.view.LayoutInflater;  

 import android.view.View;  

 import android.widget.LinearLayout;  

 import android.widget.TextView;  

  

 public class SectionListElement implements ListElement {  

  

 private String text;  
   

public void setText(String text) {  

 this.text = text;  

 }  
   

 @Override 

 public int getLayoutId() {  

 return R.layout.section;  

 }  
   

 @Override 

 public boolean isClickable() {  

 return false;  

 }     

 @Override 

public View getViewForListElement(LayoutInflater layoutInflater,  

 Context context, View view) {  

 LinearLayout layout = (LinearLayout) layoutInflater.inflate(getLayoutId(), null);  

TextView textView=(TextView) layout.findViewById(R.id.section_title);  

 textView.setText(text);  

 return layout;  

}  

    

 } 

 

见ContentListElement代码:

public class ContentListElement implements ListElement {  
   

 private String title;  

public void setTitle(String title) {  

 this.title = title;  

 }  
 

@Override 

 public int getLayoutId() {  

return R.layout.item;  
}  

 

 @Override 

 public View getViewForListElement(LayoutInflater layoutInflater,  

 Context context, View view) {  
 LinearLayout layout = (LinearLayout) layoutInflater.inflate(  

getLayoutId(), null);  

 TextView textView = (TextView) layout.findViewById(R.id.title);  

 textView.setText(title);  

 return layout; 

 

 

ListView需要ListAdapter的实现。在这里是直接集成BaseAdapter来实现的。用于交给ListView生成出列表。代码:

public class CustomerListAdapter extends BaseAdapter {  
private Context context;  

  

 protected ArrayList<ListElement> resultList;  

 

 private LayoutInflater layoutInflater;  

  

 public CustomerListAdapter(Context context) {  

 super();  

 this.context = context;  
 this.layoutInflater = (LayoutInflater) context  

 .getSystemService(“layout_inflater”);  

 this.resultList = new ArrayList<ListElement>();  

 }  

 

@Override 

 public int getCount() {  

 return this.resultList.size();  

 }  

    
@Override 

 public Object getItem(int position) {  

 return this.resultList.get(position);  

 }  

    

 @Override 

public long getItemId(int position) {  

 return position;  

}  

    

 @Override 

 public View getView(int position, View view, ViewGroup parent) {  

 return this.resultList.get(position).getViewForListElement(  

 layoutInflater, context, view);  

}  

   

 public void addList(List<ListElement> elements) {  

 this.resultList.addAll(elements);  

 }  

    

 @Override 

 public boolean isEnabled(int position) {  

 return this.resultList.get(position).isClickable();  
 }  

 
 public void addSectionHeaderItem(String text) {  

 SectionListElement element = new SectionListElement();  

 element.setText(text);  

 this.resultList.add(element);  

 }  

} 

  

在Activity中创建CustomerListAdapter以及设置它的代码部分:

CustomerListAdapter adapter = new CustomerListAdapter(this);  


 adapter.addSectionHeaderItem(“2002-3-1″);  

  

 ArrayList<ListElement> elements = new ArrayList<ListElement>();  

 for (int i = 0; i < 5; i++) {  

ContentListElement element = new ContentListElement();  

 element.setTitle(“哈利波特第” + (i+1) + “集”);  

elements.add(element);  

}  

 adapter.addList(elements);  

   

adapter.addSectionHeaderItem(“2002-2-2″);  

    

 elements = new ArrayList<ListElement>();  

 for (int i = 0; i < 3; i++) {  

ContentListElement element = new ContentListElement();  

 element.setTitle(“指环王第” + (i+1) + “集”);  

elements.add(element);  

}  

 adapter.addList(elements);  

   

 this.setListAdapter(adapter); 

  

这里ListActivity,还需要注意两件事情,Activity要继承ListActivity。另外,在layout中:

ListView的id要用系统自带的

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你的ListView每个项中有多个CheckBox,那么你需要在ItemCheck事件中判断哪个CheckBox发生了改变,从而采取相应的处理措施。 以下是一个示例代码,演示如何在ListView每个项中添加多个CheckBox,并在用户勾选或取消勾选时触发事件: ```csharp private void Form1_Load(object sender, EventArgs e) { // 添加ListView的列头 listView1.Columns.Add("Name", 100); listView1.Columns.Add("Math", 50); listView1.Columns.Add("English", 50); listView1.Columns.Add("Science", 50); // 添加ListView的项 ListViewItem item1 = new ListViewItem("Tom"); item1.SubItems.Add(""); item1.SubItems.Add(""); item1.SubItems.Add(""); listView1.Items.Add(item1); ListViewItem item2 = new ListViewItem("Jerry"); item2.SubItems.Add(""); item2.SubItems.Add(""); item2.SubItems.Add(""); listView1.Items.Add(item2); // 添加CheckBox控件到每个项中 for (int i = 0; i < listView1.Items.Count; i++) { ListViewItem item = listView1.Items[i]; for (int j = 1; j < item.SubItems.Count; j++) { CheckBox checkBox = new CheckBox(); checkBox.Size = new Size(15, 15); checkBox.Checked = false; listView1.Controls.Add(checkBox); checkBox.Location = new Point(listView1.Columns[j].Width - 15, item.Position.Y + 2); checkBox.CheckedChanged += new EventHandler(checkBox_CheckedChanged); } } } private void checkBox_CheckedChanged(object sender, EventArgs e) { CheckBox checkBox = (CheckBox)sender; ListViewItem item = (ListViewItem)checkBox.Parent; for (int i = 1; i < item.SubItems.Count; i++) { if (checkBox.Location.X == listView1.Columns[i].Width - 15) { // 当前CheckBox位于第i列 item.SubItems[i].Text = checkBox.Checked.ToString(); } } } ``` 在上述代码中,我们首先在ListView每个项中添加了多个CheckBox,并将它们添加到ListView控件中。然后,我们为每个CheckBox的CheckedChanged事件添加了一个处理程序,以便在用户勾选或取消勾选一个CheckBox时触发相应的事件处理逻辑。在事件处理程序中,我们可以通过sender获取到被点击的CheckBox控件,进而获取该控件所在的项以及该控件所在的列。根据该列的索引,我们可以获取到该项的各个子项的内容,然后修改相应子项的文本内容。 需要注意的是,在添加多个CheckBox时,我们需要通过设置CheckBox的Location属性将它们放置到每个子项的相应位置。在本例中,我们将CheckBox放置在每个子项的右侧,以便用户方便地勾选和取消勾选。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值