ListView 中嵌套 GridView
1、主布局文件
<?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="fill_parent"
android:background="#F5F5F5"
android:orientation="vertical" > <ListView
android:id="@+id/lv_apply_classify"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:cacheColorHint="#00000000"
android:dividerHeight="10dip"
>
</ListView> </LinearLayout>
2、listview 对应的item
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <TextView
android:id="@+id/tv_apply_classify_name"
android:layout_width="match_parent"
android:layout_height="35dip"
android:layout_marginLeft="10dip"
android:layout_marginRight="10dip"
android:gravity="center_vertical"
android:singleLine="true"
android:text="应用"
android:textSize="@dimen/font_body_16"
android:textColor="@color/black" /> <com.example.view.ClassifyGridView
android:id="@+id/gv_toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="5dip"
android:layout_marginRight="5dip"
android:layout_marginTop="5dp"
android:horizontalSpacing="1dip"
android:numColumns="2"
android:verticalSpacing="1dip" >
</com.<span style="font-family: Arial, Helvetica, sans-serif;">exaple</span><span style="font-family: Arial, Helvetica, sans-serif;">.ClassifyGridView></span> </LinearLayout>
3、gridview对应的item
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@drawable/lv_item_selector"
android:orientation="vertical"
android:padding="5dip" > <TextView
android:id="@+id/tv_apply_name"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dip"
android:singleLine="true"
android:text="应用"
android:textSize="@dimen/font_body_16"
android:textColor="@color/black" /> <TextView
android:id="@+id/tv_description_name"
android:layout_width="120dip"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dip"
android:maxLines="2"
android:textSize="@dimen/font_body_14"
android:text="应用 描述"
android:textColor="@color/gray" /> </LinearLayout>
4、主Activity
public class ClassifyActivity extends Activity { private ListView mListView;
private ClassifyListViewAdapter mListViewAdapter;
private List<ApplyTest> mArrayList; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.apply_main_classify);
init();
} private void init() {
mListView = (ListView) findViewById(R.id.lv_apply_classify);
initData();
mListViewAdapter = new ClassifyListViewAdapter(mArrayList,
ClassifyActivity.this);
mListView.setAdapter(mListViewAdapter);
} private void initData() {
mArrayList = new ArrayList<ApplyTest>(); for (int i = 0; i < 2; i++) {
ApplyTest testApplyTest = new ApplyTest();
testApplyTest.setName("测试分类"+i);
List<ApplySub> arrayListForEveryGridView = new ArrayList<ApplySub>();
for (int j = 0; j < 4; j++) {
ApplySub sub = new ApplySub();
sub.setName("子项"+i+j);
arrayListForEveryGridView.add(sub);
}
testApplyTest.setSubs(arrayListForEveryGridView);
mArrayList.add(testApplyTest);
} } public class ApplyTest {
private String name;
private List<ApplySub> subs; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public List<ApplySub> getSubs() {
return subs;
} public void setSubs(List<ApplySub> subs) {
this.subs = subs;
} } public class ApplySub {
private String id;
private String name; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} }
}
5、listview适配器
public class ClassifyListViewAdapter extends BaseAdapter {
private List<ApplyTest> mList;
private Context mContext; public ClassifyListViewAdapter(List<ApplyTest> mList,
Context mContext) {
super();
this.mList = mList;
this.mContext = mContext;
} @Override
public int getCount() {
if (mList == null) {
return 0;
} else {
return this.mList.size();
}
} @Override
public Object getItem(int position) {
if (mList == null) {
return null;
} else {
return this.mList.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) {
holder = new ViewHolder();
convertView = LayoutInflater.from(this.mContext).inflate(R.layout.apply_main_classify_gv, null);
holder.gridView = (GridView) convertView.findViewById(R.id.gv_toolbar);
holder.tv_apply_classify_name = (TextView) convertView.findViewById(R.id.tv_apply_classify_name);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
} if (this.mList != null) {
if (holder.gridView != null) {
ApplyTest mApplyTest = this.mList.get(position);
ClassifyGridViewAdapter gridViewAdapter = new ClassifyGridViewAdapter(mContext,mApplyTest.getSubs());
holder.gridView.setAdapter(gridViewAdapter);
holder.tv_apply_classify_name.setText("分类"+position+mApplyTest.getName());
}
}
return convertView;
} private class ViewHolder {
GridView gridView;
public TextView tv_apply_classify_name;
}
}
6、gridview 适配器
public class ClassifyGridViewAdapter extends BaseAdapter {
private Context mContext;
private List<ApplySub> mList; public ClassifyGridViewAdapter(Context mContext,
List<ApplySub> mList) {
super();
this.mContext = mContext;
this.mList = mList;
} @Override
public int getCount() {
if (mList == null) {
return 0;
} else {
return this.mList.size();
}
} @Override
public Object getItem(int position) {
if (mList == null) {
return null;
} else {
return this.mList.get(position);
}
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if (convertView == null) {
holder = new ViewHolder();
convertView = LayoutInflater.from(this.mContext).inflate(R.layout.apply_main_classify_group, null);
holder.tv_apply_name = (TextView) convertView.findViewById(R.id.tv_apply_name);
holder.tv_description_name = (TextView) convertView.findViewById(R.id.tv_description_name);
holder.iv_apply_classify_icon = (RemoteImageView) convertView.findViewById(R.id.iv_apply_classify_icon);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
} if (this.mList != null) {
ApplySub sApplySub = this.mList.get(position);
if (holder.tv_apply_name != null) {
holder.tv_apply_name.setText(sApplySub.getName());
// holder.tv_description_name.setText(hashMap.get("content").toString());
holder.tv_apply_name.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(mContext, "第" + (position + 1) + "个",
Toast.LENGTH_SHORT).show();
}
});
}
}
return convertView;
} private class ViewHolder {
TextView tv_apply_name;
TextView tv_description_name;
}
}
7、重写gridview让其不滚动
public class ClassifyGridView extends GridView { public ClassifyGridView(android.content.Context context,android.util.AttributeSet attrs) {
super(context, attrs);
} /**
* 设置不滚动
*/
public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,
MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec); } }
ListView 中嵌套 GridView的更多相关文章
- ListView中嵌套GridView点击事件
做一个项目时,需要在ListView中嵌套GridView,因为ListView的每个条目中不一定出现GridView,那么问题来了,添加GridView的Item的点击事件后,有GridView出现 ...
- [置顶] gridview中嵌套gridview(并实现子gridview的数据绑定),页面传值,加密,数据绑定
先来张效果图 gridview 中嵌套gridview的原理是这样的,在父gridview中建一个摸板列,然后再模版列当中在放入子gridview,然后再父gridview的OnRowDataBoun ...
- ScrollView中嵌套GridView,ListView只显示一行的解决办法
转载:http://blog.csdn.net/luohai859/article/details/39347583 关于为什么只显示一行,个人理解是:如果单独使用GridView和ListView, ...
- ScrollView中嵌套GridView,Listview的办法
按照android的标准,ScrollView中是不能嵌套具有滑动特性的View的,但是有时如果设计真的有这样做的需要,或者为了更方便简单的实现外观(比如在外在的大布局需要有滑动的特性,并且内部有类似 ...
- android 之 ListView 里面嵌套 GridView 遇到的问题及其解决方法。
我们直接入主题.所有问题例子请参照下图 1,怎样使图片具有点击事件? 答: 解决方法: 在你的BaseAdapter里面不要设置下面这三个东西,然后再设置GridView的onItemClick. g ...
- ListView 里面嵌套 GridView 遇到的问题及其解决方法。
我们直接入主题.所有问题例子请参照下图 1,怎样使图片具有点击事件? 答: 解决方法: 在你的BaseAdapter里面不要设置下面这三个东西,然后再设置GridView的onItemClick. g ...
- Android如何在ListView中嵌套ListView
前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView.但刚开始的时候,会发现放入的小ListVie ...
- 在ListView中使用GridView, Style这样写:
参考:http://msdn.microsoft.com/zh-cn/library/vstudio/ms788747.aspx 需求,自定义ListView中的滚动条 这岂不是很简单?刷刷刷写完了, ...
- Android 在ListView中嵌套ListView的事件处理
前天在工作中遇到在ListView中的Item需要用ListView来展现处理后的内容,然后就遇到了一个很头疼的问题,作为Item的ListView没法进行滑动,而且显示也不正常,只是显示几个子Ite ...
随机推荐
- 梯度寻优与logistic算法
一.一些基本概念 最优化:在给定约束之下如何寻求某些因素(的量),以使某一(或某些)指标达到最优.高中学过的线性规划就是一类典型的最优化问题. 凸集:在集合空间中,凸集就是一个向四周凸起的图形.用数学 ...
- 读EntityFramework.DynamicFilters源码_心得_单元测试03
上个星期我们只是显示了一个示例,怎么在EF的框架内,注入我们拓展的动态过滤器 第一步:安装EntityFramework.DynamicFilters 第二步:重写OnModelCreating方法 ...
- flex固定底部栏
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 爬虫之Beautifulsoup的基本实用
基本方法如下: # soup.a 只能找到第一个符合要求的标签 # soup.a.attrs 获取a所有的属性和属性值 # soup.a.attrs['href'] 获取href属性 # soup.a ...
- 原生js模拟jquery写法
function $_custom(fun) { document.onreadystatechange = function() { if (document.readyState == " ...
- cf1043E. Mysterious Crime(二分 前缀和)
题意 题目链接 Sol 考场上做完前四题的时候大概还剩半个小时吧,那时候已经困的不行了. 看了看E发现好像很可做?? 又仔细看了几眼发现这不是sb题么... 先考虑两个人,假设贡献分别为\((x, y ...
- CSS属性: 阴影 轮廓 渐变
注: 本文摘自 宁静致远 - CSDN / 但愿人长久 千里共婵娟 - CSDN 阴影 使用box-shadow属性可以为元素添加阴影效果, 比如 box-shadow: h-shadow v-sha ...
- Java设计模式—原型模式
原型设计模式是一种比较简单的设计模式,在项目中使用的场景非常多. 个人理解: 原型模式实现了对Java中某个对象的克隆功能,即该对象的类必须implements实现Cloneable接口来标识为可被克 ...
- SpringCloud+Git+Maven+Docker+Jenkins自动化构建
1.JDK安装-OpenJDK安装 yum list java-1.8* yum install -y java-1.8.0-openjdk-devel.x86_64 PS: JDK安装有两种方法:一 ...
- 【 Oral English】Pronunciation
一.英语音素 1.元音(元首,主要部分) 特点: a.无阻碍,拖很长认可辨别 b.声音响亮 2.辅音(重点,刻意练习) 特点: a.刻意阻碍 b.短促 二.汉语元素 1.音节:最小组成成分,而非元/辅 ...