iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android实现的ListView分组布局改进示例
  • 691
分享到

Android实现的ListView分组布局改进示例

示例布局listviewAndroid 2022-06-06 07:06:53 691人浏览 独家记忆
摘要

本文实例讲述了Android实现的ListView分组布局改进方法。分享给大家供大家参考,具体如下: 由于是在网上转载的一篇文章,在这里就不多说废话了,首先看一下最终的效果图:

本文实例讲述了Android实现的ListView分组布局改进方法。分享给大家供大家参考,具体如下:

由于是在网上转载的一篇文章,在这里就不多说废话了,首先看一下最终的效果图:

然后是实现该ListView布局的主要代码:

1、程序主界面 SeparateListView.java


package whu.iss.wuxianglong;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class SeparateListView extends Activity {
  ListView listView;
  MyAdapter myAdapter;
  public List<String> listTag = new ArrayList<String>();
  
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    listView = (ListView) findViewById(R.id.list);
    myAdapter = new MyAdapter(this,
        android.R.layout.simple_expandable_list_item_1, getData());
    listView.setAdapter(myAdapter);
  }
  private List<String> getData() {
    List<String> data = new ArrayList<String>();
    int i = 0;
    data.add("A");
    listTag.add("A");
    data.add("aa试数据" + (i++));
    data.add("a试数据" + (i++));
    data.add("aa试数据" + (i++));
    listTag.add("B");
    data.add("B");
    data.add("bb试数据" + (i++));
    data.add("b试数据" + (i++));
    data.add("b试数据" + (i++));
    data.add("b试数据" + (i++));
    listTag.add("C");
    data.add("C");
    data.add("c测试数据" + (i++));
    data.add("c测试数据" + (i++));
    listTag.add("D");
    data.add("D");
    data.add("d测试数据" + (i++));
    data.add("d测试数据" + (i++));
    data.add("d测试数据" + (i++));
    listTag.add("E");
    data.add("E");
    data.add("e测试数据" + (i++));
    data.add("e测试数据" + (i++));
    data.add("e测试数据" + (i++));
    listTag.add("F");
    data.add("F" );
    data.add("f测试数据" + (i++));
    return data;
  }
  class MyAdapter extends ArrayAdapter<String> {
    public MyAdapter(Context context, int textViewResourceId,
        List<String> objects) {
      super(context, textViewResourceId, objects);
    }
    @Override
    public boolean areAllItemsEnabled() {
      return false;
    }
    @Override
    public boolean isEnabled(int position) {
      // 如果-开头,则该项不可选
      return !listTag.contains(getItem(position));
    }
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
      View view = convertView;
     //根据标签类型加载不通的布局模板
      if(listTag.contains(getItem(position))){
        //如果是标签项
        view = LayoutInflater.from(getContext()).inflate(R.layout.group_list_item_tag, null);
      }else{
        //否则就是数据项
        view = LayoutInflater.from(getContext()).inflate(R.layout.group_list_item, null);
      }
     //显示名称
      TextView textView = (TextView) view.findViewById(R.id.group_list_item_text);
      textView.setText(getItem(position));
     //返回重写的view
      return view;
    }
  }
}

2、程序主界面布局文件main.xml


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  >
  <ListView
    android:id="@+id/list"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content">
  </ListView>
</LinearLayout>

3、ListView中数据部分样式布局文件group_list_item.xml


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="horizontal"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:padding="5dip">
  <ImageView
    android:src="@drawable/icon"
    android:layout_width="50px"
    android:layout_height="50px">
  </ImageView>
  <TextView
    android:id="@+id/group_list_item_text"
    android:layout_width="wrap_content"
    android:layout_height="fill_parent"
    android:paddingLeft="5dip"
    android:gravity="center_vertical">
  </TextView>
</LinearLayout>

4、ListView中分组标志行的样式布局文件group_list_item_tag.xml


<?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="wrap_content"
  android:background="#555555"
  android:paddingLeft="10dip">
  <TextView
    android:id="@+id/group_list_item_text"
    android:layout_width="wrap_content"
    android:layout_height="20dip"
    android:textColor="#ffffff"
    android:gravity="center_vertical">
  </TextView>
</LinearLayout>

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android操作sqlite数据库技巧总结》、《Android操作JSON格式数据技巧总结》、《Android数据库操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:android 通过向viewpage中添加listview来完成滑动效果(类似于qq滑动界面)android Listview模拟聊天界面Android 新闻界面模拟ListView和ViewPager的应用Android ListView自定义Adapter实现仿QQ界面Android App界面的ListView布局实战演练Android中使用Expandablelistview实现微信通讯录界面android动态布局之动态加入TextView和ListView的方法Android ListView添加头布局和脚布局实例详解神奇的listView实现自动显示隐藏布局Android代码Android开发之ListView的简单用法及定制ListView界面操作示例


--结束END--

本文标题: Android实现的ListView分组布局改进示例

本文链接: https://www.lsjlt.com/news/24382.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android仿微信布局的实现示例
    目前没有实现微信的功能,只是对微信的各个界面的调动以及对通讯录,发现和我中各个按钮的设置,同时如果你想尝试给微信中各个按钮背后添加功能时间可以用此作为模板哦,如拍照,朋友圈的添加都可...
    99+
    2024-04-02
  • Android使用ViewStub实现布局优化方法示例
    目录实践过程实现方式知识点实践过程 Hello,大家好啊,我是小空,今天带大家了解下动态加载控件ViewStub。 在平时开发中经常会遇到复杂布局,而每一个view都是会占据内存和消...
    99+
    2024-04-02
  • HTML布局的示例分析
    这篇文章主要介绍HTML布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 网站常常以多列显示内容(就像杂志和报纸)。 使用 <div> 元素的 HTML ...
    99+
    2024-04-02
  • Flex布局的示例分析
    小编给大家分享一下Flex布局的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Flex布局基础一,Absolute布局用Flex布局新建Applicati...
    99+
    2023-06-17
  • Android基础知识及线性布局的示例分析
    这篇文章主要介绍Android基础知识及线性布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.常见控件的基本属性android:id="@+id/button1":【设置控件id】a...
    99+
    2023-06-26
  • Android线性布局与相对布局的实现
    目录线性布局(LinearLayout)相对布局(RelativeLayout)总结线性布局(LinearLayout) 名字含义android:id设置一个id方便使用androi...
    99+
    2024-04-02
  • Android中卡顿优化布局实例分析
    小编今天带大家了解Android中卡顿优化布局实例分析,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Android中卡顿优化布局实例...
    99+
    2023-06-28
  • CSS布局方案的示例分析
    这篇文章给大家分享的是有关CSS布局方案的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。居中布局水平居中1)使用inline-block+text-align原理:先将子...
    99+
    2024-04-02
  • Dreamweaver CS3中布局的示例分析
    小编给大家分享一下Dreamweaver CS3中布局的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、CSS规则定义之“类型”类型主要针对文本属性进行...
    99+
    2023-06-08
  • PHP架构布局的示例分析
    这篇文章主要介绍PHP架构布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!执行流程从上图中看出主要从解析PHPCode到执行主要经过了四个阶段。获取token可以通过Token_get_all('...
    99+
    2023-06-15
  • CSS中Gird布局的示例分析
    这篇文章主要介绍CSS中Gird布局的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!CSS网格布局是一个二维的基于网格的布局系统, 其目的在于完全改变我们设计基于网络的用户界...
    99+
    2024-04-02
  • 使用flex布局的示例分析
    这篇文章主要介绍了使用flex布局的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Flex布局Flex 是 Flexible Box 的缩写,意为"弹性布局...
    99+
    2023-06-08
  • html布局命名的示例分析
    小编给大家分享一下html布局命名的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 头:header 模式:cont...
    99+
    2024-04-02
  • Android ListView实现单选及多选等功能示例
    本文实例讲述了Android ListView实现单选及多选等功能的方法。分享给大家供大家参考,具体如下:在项目中也遇到过给ListView的item添加选择功能。比如一个网购APP,有个历史浏览页面,这个页面现点击item单选/多选及全选...
    99+
    2023-05-30
    android listview roi
  • css中div+css布局实现2端对齐的示例分析
    这篇文章主要介绍css中div+css布局实现2端对齐的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!div+css布局实现2端对齐是我们网页排版中经常会使用到的,这篇文章将总结一下可以实现的方法:html结...
    99+
    2023-06-08
  • css中sticker-footer布局的示例分析
    这篇文章将为大家详细讲解有关css中sticker-footer布局的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在网页设计中,Sticky footers设计...
    99+
    2024-04-02
  • css中双飞翼布局和圣杯布局的示例分析
    这篇文章主要为大家展示了“css中双飞翼布局和圣杯布局的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中双飞翼布局和圣杯布局的示例分析”这篇文章吧...
    99+
    2024-04-02
  • redis分布式锁的实现示例
    小编给大家分享一下redis分布式锁的实现示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Redissonredisson和下...
    99+
    2024-04-02
  • Android实现布局全屏的方法
    这篇文章给大家分享的是有关Android实现布局全屏的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Android是什么Android是一种基于Linux内核的自由及开放源代码的操作系统,主要使用于移动设备,...
    99+
    2023-06-14
  • css布局之BFC模式的示例分析
    这篇文章主要为大家展示了“css布局之BFC模式的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css布局之BFC模式的示例分析”这篇文章吧。详解BFC...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作