仿微信消息列表(RecycleView)双击移动未读消息
来源:互联网 发布:关口知宏漫画 编辑:程序博客网 时间:2024/06/16 18:23
/**
* 仿微信双击移动未读消息
*/
public void smoothMessageItem() {
if (mPostion.size() > 0) {
if (page == mPostion.size()) {
// 当前位置为最后后一个位置重置
page = 0;
}
LinearLayoutManager layoutManager = (LinearLayoutManager) mRfragment.recyclerView.getLayoutManager();
// 获取到所要移动到的postion
int postion = Integer.valueOf(mPostion.get(page));
// 单个item高度
int item = dp2px(62);
// 所有的移动距离都以 firstVisibleItemPosition 来做参照
int firstVisibleItemPosition = layoutManager.findFirstVisibleItemPosition();
// 获取到当前参照view的偏移量
int top = layoutManager.findViewByPosition(firstVisibleItemPosition).getTop();
// 移动目标位置大于参照view postion
// (这里item为等高)如果包含headview移动距离必须考虑到Headview的高度
if (postion > firstVisibleItemPosition) {
int transPostion = postion - firstVisibleItemPosition;
mRfragment.recyclerView.smoothScrollBy(0, (transPostion * item + top));
// 移动目标位置小于参照view postion
} else if (postion < firstVisibleItemPosition) {
int transPostion = firstVisibleItemPosition - postion;
mRfragment.recyclerView.smoothScrollBy(0, -(transPostion * item - top));
} else {
// 移动目标位置等于参照view postion
mRfragment.recyclerView.smoothScrollBy(0, top);
}
// 标记位置增加一为下一次移动做准备
page++;
}
}
- 仿微信消息列表(RecycleView)双击移动未读消息
- 未读消息
- 未读消息提醒
- 使用clipChildren实现仿微信的未读消息列表显式布局
- WinForm之拦截双击标题栏/移动窗体的系统消息
- 仿qq未读消息
- 未读消息橡皮动画
- 右上角未读消息数
- 小程序-未读消息
- 自定义未读消息提示
- 未读消息小红点(badgeview)
- 仿QQ未读消息
- 双击消息打开窗体
- Android 仿微信底部菜单栏 + 显示未读消息数量
- android底部菜单栏demo(未读消息提示)
- ios 设置 applicationIconBadgeNumber(多少消息未读)
- android app图标未读消息数(BadgeNumber)
- 自定义view实现未读消息提示(小红点)
- Canvas应用小结
- unity ui button ugui 按钮如何设置点击区域为圆形?【整理转载】
- Spring_Spring Boot Actuator
- QT编程时,,界面不阻塞立刻显示
- SharedPreference.Editor的apply和commit方法的区别
- 仿微信消息列表(RecycleView)双击移动未读消息
- Android Power Management 实现
- post请求网络数据,返回给主线程更新UI实例
- c++ 并行编程
- linux批量删除大量小文件
- spring applicationContext.xml 配置文件详解
- ASP.NET实现三层架构网站创建流程
- 三步实现控件悬浮
- 可以作为URL传输的BASE64编码格式的数据