首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

动态更改listview的分隔高度?

动态更改listview的分隔高度是指在使用ListView控件时,根据需要动态地更改列表项之间的分隔线高度。在Android开发中,可以通过设置自定义的分隔线Drawable来实现这一目标。

以下是一个简单的示例,展示了如何在ListView中动态更改分隔高度:

  1. 创建一个自定义Drawable作为分隔线:
代码语言:java
复制
public class CustomDivider extends Drawable {
    private int mDividerHeight;
    private Paint mPaint;

    public CustomDivider(int dividerHeight, int dividerColor) {
        mDividerHeight = dividerHeight;
        mPaint = new Paint();
        mPaint.setColor(dividerColor);
        mPaint.setStrokeWidth(mDividerHeight);
    }

    @Override
    public void draw(Canvas canvas) {
        Rect bounds = getBounds();
        int left = bounds.left;
        int right = bounds.right;
        int top = bounds.top;
        int bottom = bounds.bottom;

        canvas.drawLine(left, top, right, bottom, mPaint);
    }

    @Override
    public void setAlpha(int alpha) {
        mPaint.setAlpha(alpha);
    }

    @Override
    public void setColorFilter(ColorFilter colorFilter) {
        mPaint.setColorFilter(colorFilter);
    }

    @Override
    public int getOpacity() {
        return PixelFormat.TRANSPARENT;
    }
}
  1. 在ListView的Adapter中设置自定义分隔线:
代码语言:java
复制
public class MyAdapter extends BaseAdapter {
    // ...

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // ...

        // 根据需要动态设置分隔线高度
        int dividerHeight = getDividerHeight(position);
        CustomDivider customDivider = new CustomDivider(dividerHeight, Color.BLACK);
        view.setDivider(customDivider);

        return view;
    }

    private int getDividerHeight(int position) {
        // 根据position返回需要的分隔线高度
        // 可以根据需要自定义逻辑
        return position % 2 == 0 ? 10 : 20;
    }
}

通过以上方法,可以实现在ListView中动态更改分隔高度的目标。需要注意的是,这个示例仅适用于Android开发,如果您使用的是其他平台或技术,请根据实际情况进行调整。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

android scrollview嵌套listview计算高度的问题

在LinearLayout中放需要呈现的内容。ListView也在其中,ListView的高度设为适应自身内容(wrap_content)。...但是为啥在scrollview中嵌套listview会出现只显示第一条listitem的高度呢,原因是:scrollview的ontach方法的滚动事件消费处理,ListView控件的高度设定问题 从谷歌那里找到的...        // listView.getDividerHeight()获取子项间分隔符占用的高度              // params.height最后得到整个ListView完整显示需要的高度...              listView.setLayoutParams(params);          }      这个代码让控件去计算Listview自己的高度然后设置这个Listview...的高度 但是这个代码里面有一个问题,就是这个当你的ListView里面有多行的TextView的话,ListView的高度就会计算错误,它只算到了一行TextView的高度, 这个问题在so上的概述为以下

2.3K60
  • 让动态的 iframe 内容高度自适应

    使用iframe加载其他页面的时候,需要自适应iframe的高度 这里加载了两个不同内容高度的页面至iframe中 1....在onload事件触发时,根据body的高度自适应iframe的高度 的 name值对应的iframe2,两种引用方式是等价的 ?...可以发现,高度虽然能自适应,不过只支持高度了“从小到大”的自适应 如iframe2的内容比iframe1的高,后者动态加载出前者能自适应,但前者动态加载出后者就不行了,这种高度减小不了 最后的解决办法是...在onload事件中动态设置高度为body高度之前,先将原高度还原为auto或空值 可以用setTimeout(fn,0)将高度设置放到下一轮事件循环中执行,或者在 onbeforeunload 事件中先把高度设置为

    6.8K51

    Android动态修改ListView中指定Item的组件属性

    Android动态修改ListView中指定Item的组件属性 在Android实际开发过程中经常会遇到,修改ListView中某一项的值。如何达到这一目的呢?...方法主要有两种: 第一种方式:当ListView中某一项的值发生变化之后,重新加载数据已达到更新ListView的目的。 虽然第一种方式能够解决问题,但不值得推荐。因为这样会带来不必要的资源消耗。...ListView中某一项的值发生改变,实际上是ListView的数据源发生了改变。既然数据源发生了改变那么我们就修改数据源。...下面就拿修改ListView中某一项文件名来演示具体步骤: 步骤一:获取单击ListView中tem的位置 //注册单击ListView中的Item响应的事件 list.setOnItemClickListener...中tem的位置 } }); 步骤二:根据单击ListView中tem的位置更新ListView的数据源,并通知适配器数据改变 String newFileName=edtFileName.getText

    3.8K80

    利用Flutter中的ListView进行动态卡片布局

    本文主要介绍 listView下进行动态卡片布局 真香!本来觉得用以前的java就能做的为啥还用flutter,但是最近接触flutter之后感觉这才是写移动应用的神器啊!...尤其是用java写的listView,各种适配器传参简直了 效果 可以显示gif动图哦,真强大,某些模拟器中可能有闪烁现象,但是我的手机上没有,可能是兼容问题 ) 原理 在完成这个效果之前, 分两步走...,listview列表和card布局 listView 没有适配器,没有viewHolder,没有entity,flutter将他变成了一个纯前端的项目,简单到任何的注释都是那么的苍白 return...subtitle: Text('工程师'), ) ], ), ), ​ ] ); // ​ 合并 难点在于,不能像一开始的listView...) 将listData通过map形式传入成为value,然后取相应的key值传入对应的参数,listView会自动循环遍历value中的内容 import 'package:flutter/material.dart

    2.1K20

    Android隐藏Listview和RecyclerView 滑动边界的阴影,去除滚动条加分隔线等

    1、Listview的属性设置,虽然我现在经常用RecyclerView,很少用Listview了,但是还是顺便写一下,以便巩固一下知识,万一以后需要呢。...android:overScrollMode="never" 当然设置上面的话也行,下面来看看整体 //以下是整体设置(overScrollHeader和overScrollFooter可不写,此处写了是引用的透明色...) ListView android:id="@+id/lv_listview" android:layout_width="match_parent" android:layout_height...,分隔线的高度必须大于0 android:headerDividersEnabled="true" headview下是否加分隔线 android:footerDividersEnabled="true..." footview是否加分隔线 android:scrollbars="none" 设置滚动条不显示,当然ScroollView 也同样有用 2、RecyclerView的属性设置 和ListView

    1.1K30

    动态生成DOM元素的高度及行数获取与计算方法

    背景 在开发IM的项目过程中,经常会有出现一些需要计算DOM高度,然后超出若干行隐藏等需求。很多时候,需要计算高度的DOM元素都是动态生成的,我们无法在数据渲染前获取到它的高度。...但是,如果我们需要获取到这段在内存中未渲染的动态文本,也能够通过如下几个方法。...技术方案 根据前端的基本常识,在内存中未渲染的DOM元素是无法获取到高度的,因此我们有两个方向来解决这个难题: 通过字数对行数进行估算 将元素渲染后进行高度测算 实现方案 以下的实现方案将根据上面所选择的技术方案来进行实现...因为在实际的页面中进行计算能够保证页面高度计算没有任何误差,因此我们需要一个实际的场景,让浏览器来帮助我们进行高度计算。...总结 获取动态元素的高度一直都是IM项目中的一个重要需求,自己在这个方面也踩了许多坑,因此写了这一篇博客来进行记录,同时其他人如果看到了也可以避免一些常见问题。

    4K30

    动态更改 Spring 定时任务 Cron 表达式的优雅方案!

    到定时任务真正启动之前,我们都有机会更改任务的执行周期等参数。...这是 Spring 提供给我们的可变的部分。 但是我们往往要得更多。能否在定时任务已经在执行过的情况下,去动态更改Cron表达式,甚至禁用某个定时任务呢?...: 定时调度任务动态加载开始>>>>>> 定时任务[CronTaskBar]的任务表达式未发生变化,无需刷新 定时任务[CronTaskFoo]已加载,当前任务表达式为[0/6 * * * * ?]...定时任务[CronTaskUnavailable]的任务表达式配置为禁用,将被不会被调度执行 定时调度任务动态加载结束<<<<<< Say Bar Say Bar Say Foo Say Bar Say...Unavailable Say Bar Say Unavailable Say Bar 小结 我们在上文通过定时刷新和重建任务的方式来实现了动态更改Cron表达式的需求,能够满足大部分的项目场景,而且没有引入

    99010

    分享个刚写好的 android 的 ListView 动态加载类,功能全而代码少。

    (转载声明出处:https://cloud.tencent.com/developer/user/1148436/activities) 简介:       该ListView 实现动态加载数据,为了方便用户充分地自定义自己的数据源...1,所有关键的操作使用接口,由用户自己定义,               包括:数据适配器的配置、动态加载函数的配置、item点击接口;       2,已经新建线程来执行动态函数。      ...//3,提供一个默认的动态执行函数; 用法:       你只需要在自己的 activity、fragment或者其他,之后调用其构造函数new 一个该类对象,同时传入你的 ListView,然后再继承它的两个接口...实现动态加载数据 22 * 1,所有关键的操作使用接口,由用户自己定义, 23 * 包括:数据适配器的配置、动态加载函数的配置、item点击接口; 24 *...25 * //3,提供一个默认的动态执行函数; 26 */ 27 public class mainListview implements AbsListView.OnScrollListener

    62770

    实现动态高度下的不同样式展现

    ,应用该规则下的样式 具体规则为,如果容器的高度小于等于 260px 时,.g-content 元素的伪元素将变得透明 这样,我们就非常简单的实现了容器在不同高度下,ICON 元素的显示隐藏切换: 完整的代码...方法二:clamp + calc 大显神威 上面效果的核心在于: 如果容器的高度大于某个值,显示样式 A 如果容器的高度小于等于某个值,显示样式 B 那么想想看,如果拿容器的高度减去一个固定的高度值,会发生什么...bottom 属性中,100% 表示的是容器当前的高度,因此 calc(100% - 200px) 的含义就代表,容器当前高度减去一个固定高度 200px。...因此: 当容器高度大于 200px,calc(100% - 200px) 表示的是一个正值 当容器高度小于 200px,calc(100% - 200px) 表示的是一个负值 当容器高度等于 200px...有什么办法让它在出现后,一直定位在容器的最下方吗? 别忘了,CSS 中,还有几个非常有意思的数学函数:min()、max()、clamp(),它们可以有效限定动态值在某个范围之内!

    42550

    android ListView实现圆角(两种解决方案)

    首先我们要实现一个完整的圆角背景,用于默认与listview的background. <?xml version="1.0" encoding="utf-8"?...这里我运用第一种方法:(也巩固下shape) 创建自定义的listview,用于实现setSelector及选中的效果....和listview是冤家,不可能同时存在,不过网上有解决办法,原理就是我们动态show 我们的listview, 实现方法: /*** * 动态设置listview的高度 * * @param...// listView.getDividerHeight()获取子项间分隔符占用的高度 // params.height最后得到整个ListView完整显示需要的高度 listView.setLayoutParams...(params); } 我们在Listview的setAdapter后,在调用下这个方法就OK了,代码内容,我想大家都看的明白,就不多介绍了.

    97820
    领券