标签:
现在有些应用,状态栏最初全透明,当用户下滑时,状态栏透明度逐渐恢复,参见下图
实现这种效果并不难,listview的head设置为图片,listview实现OnScrollListener事件,当listview下滑时就能实现这个效果,重要代码如下:
@Override
public void onScroll(AbsListView listView, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
if (firstVisibleItem == 0) {
// 获取头布局
View view = listView.getChildAt(0);
if (view != null) {
// 获取头布局现在的最上部的位置的相反数
int top = -view.getTop();
// 获取头布局的高度
int headerHeight = view.getHeight();
Log.i("info", "firstVisibleItem " + firstVisibleItem + ",top:"
+ top + ",headerHeight:" + headerHeight);
// 满足这个条件的时候,是头布局在XListview的最上面第一个控件的时候,只有这个时候,我们才调整透明度
if (top <= headerHeight && top >= 0) {
// 获取当前位置占头布局高度的百分比
float f = (float) top / (float) headerHeight;
rl_title.getBackground().setAlpha((int) (f * 255));
// 通知标题栏刷新显示
rl_title.invalidate();
}
}
} else if (firstVisibleItem > 0) {
// rl_title.setBackgroundColor(Color.argb(255, 0, 00, 0));
rl_title.getBackground().setAlpha(255);
} else {
rl_title.getBackground().setAlpha(0);
}
}
其实就是计算listview下滑的距离。透明随着listview下滑变动。当head下滑完后,状态栏恢复定义的颜色。
完整代码下载地址:
http://blog.csdn.net/bisubisu/article/details/47835359
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/bisubisu/article/details/47835359