[转载]Android: 如何实现ScrollView中含有ListView?
要想把ListView嵌入ScrollView,有二个方法:
方法1:整体上使用一个ListView, 把不需滚动的部分放入ListView的Header或Footer中。
注意: 一定要先添加HearderView和FooterView,然后再设置ListView的Adapter.
缺陷: Header或Footer中的内容不能滚动;并且只能允许同时存在一个ListView。
代码如下:
LayoutInflater mLI =
(LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
listView = (ListView) findViewById(R.id.listView);
datas = new ArrayList<Object>();
fillDatas();
datasAdapter = new DemoListAdapter(context, datas);
MyListHeaderView headerView = mLI.inflate(R.layout.my_header_layout, null);
FillDataToHeaderView(headerView);
MyListFooterView footerView = mLI.inflate(R.layout.my_footer_layout, null);
FillDataToFooterView(footerView);
listView.addHeaderView(headerView);
listView.addFooterView(footerView);
listView.setAdapter(datasAdapter);
方法2:用LinearLayout模拟ListView, 从而实现任意内容的滚动。
下面实现的是一个通用的LinearLayoutForListView,可以为它设置不同的Adapter从而显示不同的数据。
LinearLayoutForListView的代码如下:
public class LinearLayoutForListView extends android.widget.LinearLayout {
static final String LOG_TAG = "LinearLayoutForListView";
private android.widget.BaseAdapter adapter;
private OnClickListener onClickListener = null;
public void fillLinearLayout() {
int count = adapter.getCount();
for (int i = 0; i < count; i++) {
View v = adapter.getView(i, null, null);
v.setOnClickListener(this.onClickListener);
addView(v, i);
}
Log.v("countTAG", "" + count);
}
public LinearLayoutForListView(Context context) {
super(context);
}
public LinearLayoutForListView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public android.widget.BaseAdapter getAdpater() {
return adapter;
}
public void setAdapter(android.widget.BaseAdapter adpater) {
this.adapter = adpater;
fillLinearLayout();
}
public OnClickListener getOnclickListner() {
return onClickListener;
}
public void setOnclickLinstener(OnClickListener onClickListener) {
this.onClickListener = onClickListener;
}
}
注意,上面LinearLayoutForListView的成员adapter是BaseAdapter,因此可以自定义其它的Adapter来加入数据。下面是一个Adapter的参考实现,用于显示一个软件开发者的联系信息:
public class DeveloperInfoAdapter extends BaseAdapter {
static final String LOG_TAG="DeveloperInfo";
public final int VIEW_INDEX = 3000;
private Context mContext;
private String[] mKeys;
private String[] mTitles;
private String[] mVals;
LayoutInflater mLI = null;
public DeveloperInfoAdapter(Context context, String[] keys, String[] titles, String[] vals) {
mContext = context;
mKeys = keys;
mTitles = titles;
mVals = vals;
mLI = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// to Make sure mKeys(...) are NOT null:
if(mKeys==null || mTitles==null || mVals==null) {
mKeys = mTitles = mVals = new String[]{};
}
}
@Override
public int getCount() {
return mKeys.length;
}
@Override
public String getItem(int index) {
if(index>=0 && index<mVals.length)
return mVals[index];
else
return null;
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if(position <0 || position > mKeys.length)
return null;
final String key = mKeys[position];
final String title = mTitles[position];
final String val = mVals[position];
View v = convertView;
if (v == null) {
v = mLI.inflate(R.layout.dev_web_email_layout, null);
}
v.setId(position+VIEW_INDEX);
v.setClickable(true);
if (true) {
TextView v_title = (TextView) v.findViewById(R.id.dev_title);
TextView v_val = (TextView) v.findViewById(R.id.dev_val);
v_title.setText(title);
v_val.setText(val);
}
return v;
}
private void callBrowser(String url){
if(TextUtils.isEmpty(url))
return;
final String prefix = "http://";
try {
if(!url.startsWith(prefix))
url = prefix + url;
Uri uri = Uri.parse(url);
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
mContext.startActivity(intent);
} catch (Exception e) {
String err_msg = e.getMessage();
Log.d(LOG_TAG, "Uri err: " + err_msg);
}
}
private void callEmail(String emailbox){
if(TextUtils.isEmpty(emailbox))
return;
final String prefix = "mailto:";
try {
if(!emailbox.startsWith(prefix))
emailbox = prefix + emailbox;
Uri uri = Uri.parse(emailbox);
Intent intent = new Intent(Intent.ACTION_SENDTO, uri);
mContext.startActivity(intent);
} catch (Exception e) {
String err_msg = e.getMessage();
Log.d(LOG_TAG, "Uri err: " + err_msg);
}
}
public android.view.View.OnClickListener myOnClickListener
= new android.view.View.OnClickListener() {
@Override
public void onClick(View v) {
try {
int id = v.getId();
int position = id-VIEW_INDEX;
if(position <0 || position > mKeys.length)
return;
final String key = mKeys[position];
final String title = mTitles[position];
final String val = mVals[position];
if("website".equals(key)) {
callBrowser(val);
} else if("email".equals(key)) {
callEmail(val);
}
} catch (Exception e) {
// Do nothing!
}
}
};
}
相关的layout文件部分如下:
<TextView android:id="@+id/detail_developer"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/lbl_title_developer"
android:textStyle="bold"
android:background="#008F00"
>
</TextView>
<com.xxx.yyy.LinearLayoutForListView android:id="@+id/detail_lst_web_email"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:visibility="visible"
android:clickable="true"
>
</com.xxx.yyy.LinearLayoutForListView>
以下代码向这个假的ListView填入数据:
com.xxx.yyy.LinearLayoutForListView lst_developer
= (com.xxx.yyy.LinearLayoutForListView) findViewById(R.id.detail_lst_web_email);
String keys[]={ "website", "email"};
String titles[]={getResources().getString(R.string.lbl_title_developer_website),
getResources().getString(R.string.lbl_title_developer_email)};
String vals[]={"http://abc.com", "abc@def.com"};
DeveloperInfoAdapter developerAdapter = new DeveloperInfoAdapter(this, keys, titles, vals);
lst_developer.setOnclickLinstener(developerAdapter.myOnClickListener);
lst_developer.setAdapter(developerAdapter);
<完>
结伴旅游,一个免费的交友网站:www.jieberu.com
推推族,免费得门票,游景区:www.tuituizu.com
[转载]Android: 如何实现ScrollView中含有ListView?的更多相关文章
- Android 如何在ScrollView中嵌套ListView
前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView.但刚开始的时候,会发现放入的小ListVie ...
- android 布局文件 ScrollView 中的 listView item 显示不全解决方案
import android.content.Context;import android.util.AttributeSet;import android.widget.ListView; /** ...
- Android实战技巧:如何在ScrollView中嵌套ListView
前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView.但刚开始的时候,会发现放入的小ListVie ...
- Android -- 在ScrollView中嵌套ListView
在做一个工程,这个工程的布局可以相当的复杂,最外面是ScrollView,在ScrollView里面有两个Listview,这下好了,布局出来了,放在机子上跑,卡得想死有木有,信息乱跑乱出现,表示非常 ...
- Android ScrollView中嵌套ListView
由于要做一个相似美团的团购产品.scrollview中还有嵌入listview,要是直接把listview嵌进scrollview中.listview的高度是固定的不能进行滑动.默认情况下Androi ...
- ScrollView中嵌套ListView时,listview高度显示的问题
方法一:直接更改listview的控件高度,动态获取(根据条目和每个条目的高度获取) 前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个Lis ...
- Android实践之ScrollView中滑动冲突处理
转载注明出处:http://blog.csdn.net/xiaohanluo/article/details/52130923 1. 前言 在Android开发中,假设是一些简单的布局.都非常easy ...
- 解决在ScrollView中套用ListView显示不正常
最近在设计Android程序时,因为需要在ScrollView中添加一个ListView列表来显示一些信息.刚开始并没有想太多,但添加进去后才发现ListView不论怎样定义都只能显示一行,显示效果很 ...
- 实现ScrollView中包含ListView,动态设置ListView的高度
ScrollView 中包含 ListView 的问题 : ScrollView和ListView会冲突,会导致ListView显示不全 <?xml version="1.0" ...
随机推荐
- 【DSP开发】【Linux开发】基于ARM+DSP进行应用开发
针对当前应用的复杂性,SOC芯片更好能能满足应用和媒体的需求,集成众多接口,用ARM做为应用处理器进行多样化的应用开发和用户界面和接口,利用DSP进行算法加速,特别是媒体的编解码算法加速,既能够保持算 ...
- Python示例-Logging
logging.ini日志配置文件内容示例: [loggers] keys=root,demo [handlers] keys=consoleHandler,timedRotatingFileHand ...
- linux/work
0.切换用户 //默认root用户是无固定密码的,并且是被锁定的,如果想给root设置一个密码 sudo passwd root //输入密码 & 确认密码 //切换root用户 su roo ...
- Spark集成的包与引入包冲突
今天在编写Spark应用的时候,想把处理结果输出为JSON字符串,查到Java比较常用的JSON处理包gson,按照其API编写代码后运行程序,总是出现"NoSuchMethodExcept ...
- Balanced Binary Tree(平衡二叉树)
来源:https://leetcode.com/problems/balanced-binary-tree Given a binary tree, determine if it is height ...
- getopt_long函数解析命令行参数
转载:http://blog.csdn.net/hcx25909/article/details/7388750 每一天你都在使用大量的命令行程序,是不是感觉那些命令行参数用起来比较方便,他们都是使用 ...
- Python 入门之 Python三大器 之 迭代器
Python 入门之 Python三大器 之 迭代器 1.迭代器 (1)可迭代对象: <1> 只要具有__ iter __()方法就是一个可迭代对象 (我们可以通过dir()方法去判断一个 ...
- 一:jvm的五大内存区(内存结构)
jvm五大内存区域(即jvm运行时数据区),描述的是类被加载时,经过解析后,存储到特定的数据区.方法区和堆是所有线程共享的,而栈和计数器是线程私有的.栈处理程序运行的问题,堆处理数据的存储问题.所以才 ...
- CPU与GPU,我们应该使用哪个?
CPU与GPU,我们应该使用哪个? CPU与GPU CPU即中央处理器,GPU即图形处理器. 两者的相同之处:两者都有总线和外界联系,有自己的缓存体系,以及数字和逻辑运算单元 两者的区别之处:在于存在 ...
- Spring基础07——配置集合属性
1.集合属性 在Spring中可以通过一组内置的xml标签(例如<list>,<set>或<map>)来配置集合属性. 2.配置List集合 配置java.util ...