Android Studio列表用法之一:ListView图文列表显示(实例)
前言:
ListView这个列表控件在Android中是最常用的控件之一,几乎在所有的应用程序中都会使用到它。
目前正在做的一个记账本APP中就用到了它,主要是用它来呈现收支明细,是一个图文列表的呈现方式,下面就讲讲具体是如何实现的。
效果图:
该功能是在另一篇博文【Android Studio 使用ViewPager + Fragment实现滑动菜单Tab效果 --简易版】的基础上进行添加的
实现的思路:
1、该功能是用fragment来做布局的,首先创建一个fragment.xml布局文件,在里面添加一个ListView控件;
2、由于List里面既要呈现图片,也要呈现文字,所以再创建一个fragment_item.xml布局文件,在里面添加ImageView、TextView,用来显示图片和文字;
3、使用SimpleAdapter来绑定数据;
具体实现逻辑:
1、创建fragment_one.xml
1 <ListView 2 android:id="@+id/lv_expense" 3 android:layout_width="match_parent" 4 android:layout_height="wrap_content"> 5 6 </ListView>
2、创建fragment_one_item.xml
1 <ImageView 2 android:id="@+id/image_expense" 3 android:layout_width="wrap_content" 4 android:layout_height="wrap_content" 5 android:paddingTop="10dp" 6 android:paddingRight="10dp" 7 android:paddingBottom="10dp" 8 android:adjustViewBounds="true" 9 android:maxWidth="72dp" 10 android:maxHeight="72dp"/> 11 <TextView 12 android:id="@+id/tv_expense_category" 13 android:layout_width="wrap_content" 14 android:layout_height="wrap_content" 15 android:layout_weight="1" 16 android:padding="10dp"/> 17 <TextView 18 android:id="@+id/tv_expense_money" 19 android:layout_width="wrap_content" 20 android:layout_height="wrap_content" 21 android:text="10.0000"/>
3、主逻辑OneFragment.java
1 List<Map<String, Object>> listitem = new ArrayList<Map<String, Object>>(); //存储数据的数组列表 2 //写死的数据,用于测试 3 int[] image_expense = new int[]{R.mipmap.detail_income, R.mipmap.detail_payout }; //存储图片 4 String[] expense_category = new String[] {"发工资", "买衣服"}; 5 String[] expense_money = new String[] {"30000.00", "1500.00"}; 6 for (int i = 0; i < image_expense.length; i++) 7 { 8 Map<String, Object> map = new HashMap<String, Object>(); 9 map.put("image_expense", image_expense[i]); 10 map.put("expense_category", expense_category[i]); 11 map.put("expense_money", expense_money[i]); 12 listitem.add(map); 13 } 14 15 //创建适配器 16 // 第一个参数是上下文对象 17 // 第二个是listitem 18 // 第三个是指定每个列表项的布局文件 19 // 第四个是指定Map对象中定义的两个键(这里通过字符串数组来指定) 20 // 第五个是用于指定在布局文件中定义的id(也是用数组来指定) 21 SimpleAdapter adapter = new SimpleAdapter(getActivity() 22 , listitem 23 , R.layout.fragment_one_item 24 , new String[]{"expense_category", "expense_money", "image_expense"} 25 , new int[]{R.id.tv_expense_category, R.id.tv_expense_money, R.id.image_expense}); 26 27 ListView listView = (ListView) v.findViewById(R.id.lv_expense); 28 listView.setAdapter(adapter);
以上就是整个功能实现的逻辑,本文代码中,List中呈现的数据是写死的,从数据库中获取源数据的方式可以参考我的源代码,且使用的数据库是SQLite。
源代码:https://github.com/AnneHan/ListViewDemo
SQLite数据库的使用:Android Studio 通过一个登录功能介绍SQLite数据库的使用
如果您看了本篇博客,觉得对您有所收获,请点击右下角的 [推荐]
如果您想转载本博客,请注明出处
如果您对本文有意见或者建议,欢迎留言
感谢您的阅读,请关注我的后续博客
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android Studio 打包自定义apk文件名
原文: Android Studio 打包自定义apk文件名 使用Android Studio打包的时候,我们有时候需要自定义apk的文件名,在此记录一下。 在app的build.gradle中,根节点下使用关键词def声明一个全局变量,用于获取打包的时间,格式可自定义,如下所示: 然后,在android节点中添加以下代码,注意:Gradle 3.0.0之前和3.0.0之后的做法是不一样的! 这样设置好了,打包出来的apk文件名就是:t8app_2.0.6_171_20180929162356_debug.apk 或t8app_2.0.6_171_20180929162605_release.apk
- 下一篇
android高级页面效果集锦
程序员界有个神奇的网站,那就是github,这个网站集合了一大批优秀的开源框架,极大地节省了开发者开发的时间,在这里我进行了一下整理,这样可以使我们在使用到时快速的查找到,希望对大家有所帮助! 一个强大的二维码扫描框架 可打开默认二维码扫描页面,支持对图片Bitmap的扫描功能,支持对UI的定制化操作,支持对条形码的扫描功能,支持生成二维码操作 项目地址 https://github.com/yipianfengye/android-zxingLibrary 高仿蘑菇街欢迎页 项目地址 https://github.com/listen2code/Test_Mogu_View 闪屏页是如何像云一样消失的 项目地址 https://github.com/githubwing/WingUE 饿了么丝滑无缝过度搜索栏的实现 项目地址 https://github.com/githubwing/WingUE 模仿饿了么详情页可以跟随手指移动 viewpager变详情页 项目地址 https://github.com/githubwing/ZoomHeader 如何让详情页缩小为横向列表 项目地...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8安装Docker,最新的服务器搭配容器使用
- Hadoop3单机部署,实现最简伪集群
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8编译安装MySQL8.0.19
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境