我是那些想把ListView放进ScrollView里面的可怜的菜鸟。
现在我知道他们不想要嵌套的滚动元素-我不确定我是否同意他们的设计,但我可以理解。我不明白的是为什么我不能创建一个不可滚动的ListView并将其嵌套到另一个可滚动的元素中。
listView.setScrollContainer(false)似乎是一个解决方案(因为我认为它可以关闭ListView的滚动功能),但运气不佳。
那么,有人能解释一下为什么谷歌不让listViews滚动吗?有没有一种方法可以做到这一点,而这个数字只是被忽略了?
发布于 2011-01-11 07:26:30
就像Mayra说的,你应该重新考虑你的UI。
除非您有多个ListViews,否则我可以看到您的问题的解决方案。因为在滚动视图中似乎只有一个列表视图。这意味着你想把一些东西放在上面或下面。
你有setHeader,setFooter。你只需要放上你想要的任何东西。您必须在setAdapter()之前添加这些视图。
如果滚动视图中有多个ListViews。我有第二个解决方案给你。我真的不能详细说明。但是您必须创建一个自定义适配器并覆盖ViewTypeCount,这样您才能处理多种类型的项。这样,您就可以通过适配器加载您想要的所有内容。而你真正需要的只是一个ListView。
如果你想处理多种类型的项目(多个列表视图),这里有一个“未测试”的例子。
您必须将adapter子类化并覆盖getView。习惯上,我们应该有一些类似于视图回收的东西
if(view == null){
//inflate view
}在您的情况下,您需要这样做。
package com.neutrino.lvt;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class Main extends Activity {
private ListView lv;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
lv = (ListView)findViewById(R.id.lv);
ArrayList<Items> items = new ArrayList<Items>();
items.add(new ItemA("Une"));
items.add(new ItemA("Une3"));
items.add(new ItemA("Une4"));
items.add(new ItemA("Une5"));
items.add(new ItemA("Une6"));
items.add(new ItemA("Une7"));
items.add(new ItemA("Une8"));
items.add(new ItemA("Une9"));
items.add(new ItemA("Une0"));
items.add(new ItemA("Une0-"));
items.add(new ItemB("bbb", "cc1c"));
items.add(new ItemB("bbb3", "c2cc"));
items.add(new ItemB("bbb4", "c2cc"));
items.add(new ItemB("bbb5", "c1cc"));
items.add(new ItemB("bbb6", "cc5c"));
items.add(new ItemB("bbb7", "cc4c"));
items.add(new ItemB("bbb7", "c2cc"));
items.add(new ItemB("bbb8", "c1cc"));
items.add(new ItemB("bbb9", "cc6c"));
items.add(new ItemB("bbb0", "cc8c"));
items.add(new ItemB("bbb0", "cc0c"));
items.add(new ItemB("bb3b", "cc6c"));
items.add(new ItemA("Une"));
items.add(new ItemA("Une3"));
items.add(new ItemA("Une4"));
items.add(new ItemA("Une5"));
items.add(new ItemA("Une6"));
items.add(new ItemA("Une7"));
items.add(new ItemA("Une8"));
items.add(new ItemA("Une9"));
items.add(new ItemA("Une0"));
items.add(new ItemA("Une0-"));
items.add(new ItemB("bbb6", "cc5c"));
items.add(new ItemB("bbb7", "cc4c"));
items.add(new ItemB("bbb7", "c2cc"));
items.add(new ItemB("bbb8", "c1cc"));
items.add(new ItemB("bbb9", "cc6c"));
items.add(new ItemB("bbb0", "cc8c"));
items.add(new ItemB("bbb0", "cc0c"));
items.add(new ItemB("bb3b", "cc6c"));
SpecialAdapter b = new SpecialAdapter(this, items);
lv.setAdapter(b);
}
private class SpecialAdapter extends BaseAdapter{
List<Items> list;
Context context;
public SpecialAdapter(Context context, List<Items> list) {
this.list = list;
this.context = context;
}
public Context getContext(){
return this.context;
}
@Override
public int getCount() {
return list.size();
}
@Override
public Items getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return list.get(position).hashCode();
}
@Override
public int getViewTypeCount() {
return 2;
}
@Override
public int getItemViewType(int position) {
Items b = getItem(position);
if(b instanceof ItemA){
return 0;
}else{
return 1;
}
}
@Override
public View getView(int position, View v, ViewGroup parent) {
Items o = getItem(position);
if(v == null){
LayoutInflater vi = (LayoutInflater)this.getContext()
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
if(getItemViewType(position) == 0){
v = vi.inflate(
android.R.layout.simple_list_item_multiple_choice,
null
);
Log.i(this.getClass().getName(),
"Inflate two line"
);
}else{
v = vi.inflate(
android.R.layout.two_line_list_item,
null
);
Log.i(this.getClass().getName(),
"Inflate one line"
);
}
}
switch (getItemViewType(position)) {
case 0:
ItemA oa = (ItemA)o;
((TextView)v.findViewById(android.R.id.text1)).setText(oa.toString());
break;
case 1:
ItemB ob = (ItemB)o;
((TextView)v.findViewById(android.R.id.text1)).setText(ob.toString());
((TextView)v.findViewById(android.R.id.text2)).setText(ob.getClasse());
break;
}
return v;
}
}
private abstract class Items {}
private class ItemA extends Items {
String name;
public ItemA(String name) {
this.name = name;
}
@Override
public String toString() {
return "ItemA: " + name;
}
}
private class ItemB extends Items {
private String name;
private String classe;
public ItemB(String name, String classe) {
this.name = name;
this.classe = classe;
}
public String getClasse(){
return classe;
}
@Override
public String toString() {
return "ItemB: " + name;
}
}
}我会试着写一个样例,很快就会更新。我想我遗漏了一些东西,因为当回收视图时,您需要检查回收的视图是否与ItemType相对应。但您绝对可以仅通过ListView来完成此操作。不需要滚动。
发布于 2011-01-11 05:59:53
您可以使用LinearLayout作为不可滚动的ListView。ListView的强大之处在于它如何处理元素的延迟加载。这在不可滚动版本的上下文中没有实际意义。
但实际上,您很可能需要重新考虑您的UI。为什么需要多个滚动部分?从用户的角度来看,这似乎真的很不友好。您可以通过页眉或页脚轻松地将内容放在ListView的上方和下方。
https://stackoverflow.com/questions/4651793
复制相似问题