Android实现listview滑动时渐隐渐现顶部栏实例代码

Android实现listview滑动时渐隐渐现顶部栏实例代码,第1张

概述我在开发的时候遇到了这样的需求,就是在listview的滑动中,需要对顶部的栏目由透明慢慢的变为不透明的状态,就是以下的效果

我在开发的时候遇到了这样的需求,就是在ListvIEw的滑动中,需要对顶部的栏目由透明慢慢的变为不透明的状态,就是以下的效果

最先开始的时候想的很简单,无非就是监听ListvIEw的滑动距离,然后根据距离算出透明度的比值,就可以了,但是事实上呢也的确是这样做的

只是在获取ListvIEw的滑动距离上可能没法直接获取,需要动态的去计算

下面贴出全部代码吧,不想码字了,最近感冒了,脑袋晕乎乎的,还疼,代码更直观一些

private voID initListener() { lvList.setonScrollchangelistener(new VIEw.OnScrollchangelistener() { @OverrIDe public voID onScrollChange(VIEw v,int scrollX,int scrollY,int oldScrollX,int oldScrollY) { } }); lvList.setonScrollListener(new AbsListVIEw.OnScrollListener() { @OverrIDe public voID onScrollStateChanged(AbsListVIEw vIEw,int scrollState) { } @OverrIDe public voID onScroll(AbsListVIEw vIEw,int firstVisibleItem,int visibleItemCount,int totalitemCount) { // Logger.myLog("firstVisibleItem=" + firstVisibleItem + "visibleItemCount=" + visibleItemCount + "totalitemCount=" + totalitemCount); Logger.myLog(getScroolY()+"top=" + gettop()); tvText.setAlpha(getAlphafloat(getScroolY())); } }); } /** * 获取渐变透明值 * @param dis * @return */ public float getAlphafloat(int dis){ int step = 5000; if(dis == 0){ return 0.0f; } if(dis < step){ return (float)(dis * (1.0/step)); }else{ return 1.0f; } } /** * 获取上滑的距离 * @return distance */ public int getScroolY(){ VIEw c = lvList.getChildAt(0); if(null == c){ return 0; } int firstVisibleposition = lvList.getFirstVisibleposition(); int top = c.gettop(); /** * 声明一下,这里测试得到的top值始终是ListvIEw条目中显示的第一条距离顶部的距离, * 而这个在坐标中的表示是一个负数,所以需要对其取一个绝对值 */ return firstVisibleposition * c.getHeight() + Math.abs(top); } /** * 获取首条距离顶部的高度 * @return distance top */ private int gettop(){ VIEw c = lvList.getChildAt(0); if(null == c){ return 0; } return c.gettop(); } 

以上所述是小编给大家介绍的AndroID实现ListvIEw滑动时渐隐渐现顶部栏实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的Android实现listview滑动时渐隐渐现顶部栏实例代码全部内容,希望文章能够帮你解决Android实现listview滑动时渐隐渐现顶部栏实例代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1148026.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存