(转载) listview实现微信朋友圈嵌套

版权声明:本文为博主原创文章,未经博主允许不得转载。
项目下载:https://github.com/Victoria0316/NestListview/tree/master
在项目中用到listview中再嵌套一个listview,两层也有监听,都没有问题。其实,主要解决里面那一层的listview的高度计算就可以,外面那一层listview自动计算。
实现效果图
这上面效果图的监听两层都有,以及外面的button都可以。够多样化吧。
3、ChildListView
- package com.nest.view;
- import android.content.Context;
- import android.util.AttributeSet;
- import android.widget.ListView;
- public class ChildListView extends ListView {
- public ChildListView(Context context, AttributeSet attrs, int defStyle) {
- super(context, attrs, defStyle);
- // TODO Auto-generated constructor stub
- }
- public ChildListView(Context context, AttributeSet attrs) {
- super(context, attrs);
- // TODO Auto-generated constructor stub
- }
- public ChildListView(Context context) {
- super(context);
- // TODO Auto-generated constructor stub
- }
- @Override
- public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
- super.onMeasure(widthMeasureSpec, expandSpec);
- }
- }
里面listview的高度的计算。
4、外面那层listview的适配器ParentAdapt
- package com.nest.adapt;
- import java.util.ArrayList;
- import java.util.List;
- import android.content.Context;
- import android.view.View;
- import android.view.ViewGroup;
- import android.view.View.OnClickListener;
- import android.widget.AdapterView;
- import android.widget.AdapterView.OnItemClickListener;
- import android.widget.Button;
- import android.widget.ListView;
- import android.widget.TextView;
- import android.widget.Toast;
- import com.nest.activity.R;
- import com.nest.base.BaseObjectListAdapter;
- import com.nest.entity.Entity;
- import com.nest.entity.ShowEntity;
- /**
- * 父listview适配器
- * @author mmsx
- *
- */
- public class ParentAdapt extends BaseObjectListAdapter{
- private ArrayList<ShowEntity> mChildList;
- public static int mParentItem = -1;
- public static boolean mbShowChild = false;
- public ParentAdapt(Context context, List<? extends Entity> datas) {
- super(context, datas);
- initData();
- }
- private void initData() {
- mChildList = new ArrayList<ShowEntity>();
- mChildList.clear();
- for (int i = 0; i < 5; i++) {
- ShowEntity tempEntity = new ShowEntity("字标题" + String.valueOf(i), "内容");
- mChildList.add(tempEntity);
- }
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- ViewHolder vHolder = null;
- if (convertView == null) {
- vHolder = new ViewHolder();
- convertView = mInflater.inflate(R.layout.activity_main_list_item, null);
- vHolder.textViewTitle = (TextView)convertView.findViewById(R.id.textView_1);
- vHolder.textViewContent= (TextView)convertView.findViewById(R.id.textView_2);
- vHolder.listViewItem = (ListView)convertView.findViewById(R.id.listView_child);
- vHolder.buttonStake = (Button)convertView.findViewById(R.id.button_1);
- convertView.setTag(vHolder);
- }else {
- vHolder = (ViewHolder) convertView.getTag();
- }
- ShowEntity tempEntity = (ShowEntity) mDatas.get(position);
- vHolder.textViewTitle.setText(tempEntity.getTitle());
- vHolder.textViewContent.setText(tempEntity.getContent());
- //点击那个弹出那个,如果已经弹出就收回子listview
- if (mParentItem == position && mbShowChild) {
- //子listview实在这里加载数据的
- ChildAdapt tempAdapt = new ChildAdapt(mContext, mChildList);
- vHolder.listViewItem.setAdapter(tempAdapt);
- vHolder.listViewItem.setVisibility(View.VISIBLE);
- //子listview的点击监听
- vHolder.listViewItem.setOnItemClickListener(new OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> parent, View view,
- int position, long id) {
- Toast.makeText(mContext, "Child Listview" + String.valueOf(position), Toast.LENGTH_SHORT).show();
- }
- });
- }else {
- vHolder.listViewItem.setVisibility(View.GONE);
- }
- vHolder.buttonStake.setOnClickListener(new ParentButtonLisener());
- //记住是那个button事件
- vHolder.buttonStake.setTag(position);
- return convertView;
- }
- class ViewHolder{
- TextView textViewTitle;
- TextView textViewContent;
- ListView listViewItem;
- Button buttonStake;
- }
- //父listview的button的监听
- private class ParentButtonLisener implements OnClickListener{
- @Override
- public void onClick(View v) {
- Integer nPosition = (Integer) (v.getTag());
- Toast.makeText(mContext, "提示" + String.valueOf(nPosition.intValue()), Toast.LENGTH_SHORT).show();
- }
- }
- }
5、里面那层listview的适配器ChildAdapt
- package com.nest.adapt;
- import java.util.List;
- import android.content.Context;
- import android.view.View;
- import android.view.ViewGroup;
- import android.widget.TextView;
- import com.nest.activity.R;
- import com.nest.base.BaseObjectListAdapter;
- import com.nest.entity.Entity;
- import com.nest.entity.ShowEntity;
- /**
- * 子listview适配器
- * @author mmsx
- *
- */
- public class ChildAdapt extends BaseObjectListAdapter{
- public ChildAdapt(Context context, List<? extends Entity> datas) {
- super(context, datas);
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- ViewHolder vHolder = null;
- if (convertView == null) {
- vHolder = new ViewHolder();
- convertView = mInflater.inflate(R.layout.activity_main_list_item_1, null);
- vHolder.textViewTitle = (TextView)convertView.findViewById(R.id.textView_1);
- vHolder.textViewContent= (TextView)convertView.findViewById(R.id.textView_2);
- convertView.setTag(vHolder);
- }else {
- vHolder = (ViewHolder) convertView.getTag();
- }
- ShowEntity tempEntity = (ShowEntity) mDatas.get(position);
- vHolder.textViewTitle.setText(tempEntity.getTitle());
- vHolder.textViewContent.setText(tempEntity.getContent());
- return convertView;
- }
- class ViewHolder{
- TextView textViewTitle;
- TextView textViewContent;
- }
- }
6、实现调用MainActivity
- package com.nest.activity;
- import java.util.ArrayList;
- import com.nest.adapt.ParentAdapt;
- import com.nest.entity.ShowEntity;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.AdapterView;
- import android.widget.AdapterView.OnItemClickListener;
- import android.widget.ListView;
- import android.app.Activity;
- /**
- * listview嵌套listview实现效果
- * @author mmsx
- *
- */
- public class MainActivity extends Activity {
- private ParentAdapt mParentAdapt;
- private ArrayList<ShowEntity> mParentList;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- initData();
- initView();
- }
- private void initData() {
- mParentList = new ArrayList<ShowEntity>();
- mParentList.clear();
- for (int i = 0; i < 20; i++) {
- ShowEntity tempEntity = new ShowEntity("标题" + String.valueOf(i), "内容");
- mParentList.add(tempEntity);
- }
- }
- private void initView() {
- ListView listView = (ListView)findViewById(R.id.listView1);
- mParentAdapt = new ParentAdapt(this, mParentList);
- listView.setAdapter(mParentAdapt);
- listView.setOnItemClickListener(new AdaptItemClick());
- //长按listview就不写示范了
- // listView.setOnItemLongClickListener(listener);
- }
- //父listview的单击事件的监听
- private class AdaptItemClick implements OnItemClickListener{
- @Override
- public void onItemClick(AdapterView<?> parent, View view, int position,
- long id) {
- if (ParentAdapt.mParentItem == position && ParentAdapt.mbShowChild) {
- ParentAdapt.mbShowChild = false;
- }else {
- ParentAdapt.mbShowChild = true;
- }
- ParentAdapt.mParentItem = position;
- mParentAdapt.notifyDataSetChanged();
- }
- }
- }
- 顶
- 0
- 踩
- 0
(转载) listview实现微信朋友圈嵌套的更多相关文章
- Android 高仿微信朋友圈动态, 支持双击手势放大并滑动查看图片。
转载请注明出处:http://blog.csdn.net/sk719887916/article/details/40348873 作者skay: 最近参与了开发一款旅行APP,其中包含实时聊天和动态 ...
- iOS版微信朋友圈数据库的简要分析
本文版权归cxun所有,如有转载请注明出处与本文链接,谢谢!原文地址:http://www.cnblogs.com/cxun/p/4550523.html 之前写了一些关于微信聊天记录的博文之后,不少 ...
- 仿QQ空间和微信朋友圈,高解耦高复用高灵活
先看看效果: 用极少的代码实现了 动态详情 及 二级评论 的 数据获取与处理 和 UI显示与交互,并且高解耦.高复用.高灵活. 动态列表界面MomentListFragment支持 下拉刷新与上拉加载 ...
- 分享:android图片浏览器—类微信朋友圈相片浏览【android代码下载】
今天给大家分享个android图片/相册浏览器,类似微信朋友圈相片浏览,可以左右滑动,可以双击放大,捏拉放大 效果如下:<ignore_js_op> device-2013-09-04-1 ...
- python爬虫24 | 搞事情了,用 Appium 爬取你的微信朋友圈。
昨天小帅b看到一些事情不顺眼 有人偷换概念 忍不住就写了一篇反讽 996 的 看不下去了,我支持996,年轻人就该996! 没想到有些人看不懂 这就算了 还来骂我 早些时候关注我的小伙伴应该知道我第一 ...
- Android NineGridLayout — 仿微信朋友圈和QQ空间的九宫格图片展示自定义控件
NineGridLayout 一个仿微信朋友圈和QQ空间的九宫格图片展示自定义控件. GitHub:https://github.com/HMY314/NineGridLayout 一.介绍 1.当只 ...
- android 滚动栏下拉反弹的效果(相似微信朋友圈)
微信朋友圈上面的图片封面,QQ空间说说上面的图片封面都有下拉反弹的效果,这些都是使用滚动栏实现的.下拉,当松开时候.反弹至原来的位置.下拉时候能看到背景图片.那么这里简介一下这样的效果的实现. 本文源 ...
- iOS燃烧动画、3D视图框架、天气动画、立体相册、微信朋友圈小视频等源码
iOS精选源码 iOS天气动画,包括太阳,云,雨,雷暴,雪动画. 较为美观的多级展开列表 3D立体相册,可以旋转的立方体 一个仪表盘Demo YGDashboardView 一个基于UIScrollV ...
- 域名在微信朋友圈内分享需要ICP备案 杜绝不良信息传播
就在刚刚,腾讯微信团队发布公告表示域名在朋友圈内分享需要ICP备案,杜绝打击不良互联网信息的传播.公告称根据互联网管理相关规定,即日起在微信朋友圈内分享的域名,请在2014年12月31日前完成ICP备 ...
随机推荐
- 僧多粥少?还原 OpenStack 的真实“钱景”
原文链接:http://www.oschina.net/news/57994/openstack-income-analysis 451 Research发布了OpenStack的收入分析预测,指出O ...
- 基于物品的协同过滤ItemCF的mapreduce实现
文章的UML图比较好看..... 原文链接:www.cnblogs.com/anny-1980/articles/3519555.html 基于物品的协同过滤ItemCF 数据集字段: 1. Use ...
- PCL:PCL可视化显示点云
(1):引用:仅仅是简单的显示点云,可以使用CloudViewer类.这个类非常简单易用.但要注意,它不是线程安全的.如果要用于多线程,还要参考PCLVisualizer. 需要注意的是,PointC ...
- Amaze UI的一点总结
做一个微信公众号内的网页的时候,用到了Amaze UI,也称妹子UI. 官网上宣称,Amaze UI中国首个开源 HTML5 跨屏前端框架,用下来的感觉是比较类似于bootstrap,都是移动端优先. ...
- python编写简单的html登陆页面(3)
1 在python编写简单的html登陆页面(2)的基础上在延伸一下: 可以将静态分配数据,建立表格,存放学生信息 2 加载到静态数据 3 html的编写直接在表格里添加一组数据就行了 4 V ...
- JS 写<ul><li>
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- C#学习 第九节
构造器 1.构造器(constructor)是类型的成员之一: 2.狭义的构造器是指“实例构造器”(instance constructor): 3.构造器的调用 student stu =new s ...
- "SetDestination" can only be called on an active agent that has been placed on a NavMesh. 解决办法
1.设置了 navmesh之后 要bake 也就是烘焙之后 才有效果 2.在unity 中 window->navigation 4.基本上问题应该得以解决:
- php 流
php:// — 访问各个输入/输出流(I/O streams) 说明 PHP 提供了一些杂项输入/输出(IO)流,允许访问 PHP 的输入输出流.标准输入输出和错误描述符, 内存中.磁盘备份的临时文 ...
- Hibernate Session操作
1.增加 @Test public void add(){ Configuration cfg=new Configuration().configure(); SessionFactory fact ...