布局中,如果设计ListView的高度为包裹内容,那么ListView的高度是随着它的子条目的数量的变化而改变的,

这就可能会导致ListView下面的一些控件的位置也会随着ListView的高度的变化而变化。

项目中可能会碰到需要动态调整或控制ListView的高度的情况,下面就分享一下我自己使用的一种办法。

我遇到的问题:

ListView下面有一个Button,如果ListView子条目的数量较少,Button可以正常显示在屏幕上,但如果ListView子条目的数量较多时,Button就会被挤出屏幕

因为考虑效果(Button要紧跟着ListView),所以不能把ListView的高度写死,所以要使用包裹内容,

那么问题就是要解决Button的显示,保证Button不被挤出屏幕

设计思路:

ListView子条目数量少时,下面紧跟着Button,

ListView子条目多时,Button显示在屏幕底部,ListView的高度固定到Button上方

解决思路:

1、先计算出固定不变的控件的高度(屏幕中有些控件的大小是不需要改变的),基本就是除了ListView以外的控件(还要考虑是否需要计算状态栏的高度)

2、获取屏幕的高度

3、用屏幕高度 减掉 固定不变的高度 得到ListView的最大允许高度

4、计算ListView每个子条目的高度并累加,得到ListView的真实高度

5、判断真实高度和最大允许高度的差值,如果真实高度超出了最大允许高度,就把ListView的高度设定为最大允许高度,否则就不需要处理

代码:

/**
  * 测量控件高度的方法:
  * @param view 需要测量的控件
  * @return 测量到的高度
  */

public int mesHeight(View view) {
  int width = View.MeasureSpec.makeMeasureSpec(0,
    View.MeasureSpec.UNSPECIFIED);
  int height = View.MeasureSpec.makeMeasureSpec(0,
    View.MeasureSpec.UNSPECIFIED);
  view.measure(width, height);
  return view.getMeasuredHeight();
 }

step1:

// 固定不变的高度自己想办法计算吧,情况不同,计算方法也不同

// 提供一些信息:有固定值的直接累加,另外如果有margintop和marginbottom属性的也要加上,没有有固定值的使用上面的方法计算

// 如果需要计算状态栏高度的,也可以在网上搜索一下,应该有很多

step2:

// 获取屏幕高度

int screenHeight = getWindowManager().getDefaultDisplay().getHeight();

step3:

screenHeight 减掉 你计算的固定高度

step4:

// ListView子条目的高度也需要自己计算,情况不同方法不同,但思路和上面的固定高度的算法思路一样

step5:

// 当前listview的总高度

int currentHeight = 0;  :
  for (int i = 0; i < lv.size(); i++) {
   currentHeight += item;
  }

if (currentHeight > maxHeight) {
   LayoutParams param = new LayoutParams(LayoutParams.FILL_PARENT,
     maxHeight);
   lv.setLayoutParams(param);
   lv.setPadding(0,0, 0,0);//看个人情况
   lv_classes.setDivider(null);//看个人情况
  }

方法中代码不完整,主要是因为每个项目中的布局都是不一样的,所以无法给出一个准确的计算方法,但提供的思路希望能起到帮助。

Android - 动态调整ListView高度的更多相关文章

  1. Android重绘ListView高度

    Android重绘ListView高度 经常会有这样需求,需要ListView默认将所有的条目显示出来,这就需要外层使用ScrollView,ScrollView里面放置一个重绘高度的ListView ...

  2. 动态调整UITableViewCell高度的实现方法

    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPa ...

  3. android 动态改变listview的内容

    本文模拟:点击一个按钮,为已有的listview添加一行数据 <?xml version="1.0" encoding="utf-8"?> < ...

  4. Android 动态获取ListView的高度

    public static void setListViewHeightBasedOnChildren(ListView listView) { ListAdapter listAdapter = l ...

  5. ScrollView嵌套listview 时根据内容动态设置listview高度

    public static void setListViewHeightBasedOnChilds(ListView listView){ ListAdapter listAdapter = list ...

  6. 如何实现可动态调整隐藏header的listview

    (转自:http://blog.sina.com.cn/s/blog_70b9730f01014sgm.html) 需求:根据某种需要,可能需要动态调整listview的页眉页脚,譬如将header作 ...

  7. HighCharts 图表高度动态调整

    HighCharts 图表高度动态调整 前言 在使用HighCharts控件过程中,发现图表可以自适应div的高度,无法根据图表x.y轴的数量动态调整div高度,否则图标挤在一起,看起来非常不美观,也 ...

  8. 实现ScrollView中包含ListView,动态设置ListView的高度

    ScrollView 中包含 ListView 的问题 : ScrollView和ListView会冲突,会导致ListView显示不全 <?xml version="1.0" ...

  9. Android中动态更新ListView(转)

    在使用ListView时,会遇到当ListView列表滑动到最底端时,添加新的列表项的问题,本文通过代码演示如何动态的添加新的列表项到ListView中.实现步骤:调用ListView的setOnSc ...

随机推荐

  1. iOS 杂记

    一,demo 1,视图跳转 MaryPopin:  https://github.com/Backelite/MaryPopin 2,Nimbus是一个开源的iOS框架,比起Three20,Nimbu ...

  2. SQL2005中的事务与锁定(八)- 转载

    ------------------------------------------------------------------------ -- Author : happyflystone - ...

  3. emacs + quicklisp + slime

  4. 为什么要加 -moz- -webkit- -ms- -o- ?

    没有别的,为了兼容早期版本,为了解决CSS3标准正式发布以前的遗留问题.

  5. 配置DNS服务器

    一.配置基本的DNS 服务器(包含正向解析和反向解析)域名:abc.com服务器IP:10.1.2.11 1. 编辑主配置文件/etc/named.conf---------------------- ...

  6. redis入侵

    一.前言 前段时间,在做内网影响程度评估的时候写了扫描利用小脚本,扫描后统计发现,内网中60%开放了redis6379端口的主机处于可以被利用的危险状态,因为都是一些默认配置造成的考虑到本社区大部分开 ...

  7. maven 编译插件

    <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compi ...

  8. linux初始化配置-----网络配置

    一.设置linux网络 1)零时设置ip地址 由于centos7默认没有ifconfig命令所以为了使用方便我们先安装net-tool使我们能使用ifconfig命令查看ip地址 ·挂载系统光盘 [r ...

  9. Script循环语句 的相关知识跟练习

    循环语句有两种问题类型:穷举和迭代 穷举: 在不知道什么情况下才是我们需要的结果的时候,只能让它一个一个的都执行一遍 迭代:在现有的条件下,根据规律,不断求解中间情况,最终推选出结果 两个关键词 br ...

  10. Designing a CSS based template

    http://veerle-v2.duoh.com/blog/comments/designing_a_css_based_template_part_i/