(转载) 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备 ...
随机推荐
- Segment公司--整合数据进行分析
YC毕业生Segment获得1500万美元A轮融资 现在收集数据是每一个公司的必修课了,而且是从各种不同 API 上收集数据,但是你还要把这些数据整合起来才能发挥作用,Segment就能帮你整合各个平 ...
- 01-初学总结之《谭浩强C程序设计》
注:个人针对于课本的易错点进行了相关的整理.整理的不专业,多多见谅. C语言中的易出错的点 这个笔记综合了 0. 常量&变量 常量 整型常量 -345,1000,0 实型常量 1) 十进制 ...
- jquery获取元素内容-text()和val()
不传参数的text()方法在获取文本内容时,会把子元素的文本也获取过来(会删除 HTML 标记),例子: <!doctype html> <html> <head> ...
- JS 实现1!+2!+3!+4!+5!+....+n!
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 记一次vip视频破解过程(爱奇艺 芒果 腾讯 优酷 )
1. 在爱奇艺或者优酷中拿到视频的url地址.此时拿到的是加密地址(也可以直接在牛巴巴里面搜名字然后开f12跟踪路由) 2.进入牛巴巴vip视频解析网站.粘贴拿到的url.点击解析 3.f12在net ...
- centos7编译安装mysql5.6
先安装如下依赖包: $ yum -y install make gcc-c++ cmake bison-devel ncurses-devel 下载MySQL5.6.14安装包,https://pa ...
- Ubuntu Server 与 Ubuntu Desktop区别
今天有位朋友问我,Ubuntu Server 与 Ubuntu Desktop的区别在哪里!区别如下: SERVER没有GUI SERVER没有一堆的桌面软件 SERVER在编译时使用的参数不一样,会 ...
- java中String和int的互相转化
1. String 转 int 方式1:Integer.parseInt(); 方式2: Integer.valueOf(myStr).intValue(); 2. int 转String 方式1: ...
- Flex教程
详细教程: 1.基础知识:一劳永逸的搞定 flex 布局 2.阮一峰的flex教程:flex syntax flex example
- Project Euler 2 Even Fibonacci numbers
题意:斐波那契数列中的每一项都是前两项的和.由1和2开始生成的斐波那契数列前10项为:1, 2, 3, 5, 8, 13, 21, 34, 55, 89, -考虑该斐波那契数列中不超过四百万的项,求其 ...