当前位置: 代码网 > it编程>编程语言>Java > 【Android】史上最简单,一步集成侧滑(删除)菜单,高仿QQ、IOS。(1)

【Android】史上最简单,一步集成侧滑(删除)菜单,高仿QQ、IOS。(1)

2024年07月28日 Java 我要评论
开发是面向对象。我们找工作应该更多是面向面试。哪怕进大厂真的只是去宁螺丝,但你要进去得先学会面试的时候造飞机不是么?作者13年java转Android开发,在小厂待过,也去过华为,OPPO等,去年四月份进了阿里一直到现在。等大厂待过也面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含。

(itemdecorationindexbar : https://github.com/mcxtzhang/itemdecorationindexbar)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

android special version (无阻塞式,侧滑菜单展开时,依然可以展开其他侧滑菜单,同时上一个菜单会自动关闭):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

gridlayoutmanager (和上图的代码比,只需修改recyclerview的layoutmanager。):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

linearlayout (不需任何修改,连linearlayout也可以简单的实现侧滑菜单):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

ios interaction (阻塞式交互,高仿qq,侧滑菜单展开式,屏蔽其他item所有操作):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

使用:

===

step 1. 在项目根build.gradle文件中增加jitpack仓库依赖。

allprojects {

repositories {

maven { url “https://jitpack.io” }

}

}

step 2. add the dependency

dependencies {

compile ‘com.github.mcxtzhang:swipedelmenulayout:v1.2.1’

}

step 3. 在需要侧滑删除的contentitem外面套上本控件,在本控件内依次排列contentitem、菜单即可:

至此 您就可以使用高仿ios、qq 侧滑删除菜单功能了

(侧滑菜单的点击事件等是通过设置的id取到,与其他控件一致,不再赘述)

demo里,我的contentitem是一个textview,那么我就在其外嵌套本控件,并且以侧滑菜单出现的顺序,依次排列菜单控件即可。

<?xml version="1.0" encoding="utf-8"?>

<com.mcxtzhang.swipemenulib.swipemenulayout

xmlns:android=“http://schemas.android.com/apk/res/android”

android:layout_width=“match_parent”

android:layout_height=“100dp”

android:clickable=“true”

android:paddingbottom=“1dp”>

<textview

android:id=“@+id/content”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:background=“?android:attr/selectableitembackground”

android:gravity=“center”

android:text=“项目中我是任意复杂的原contentitem布局”/>

<button

android:id=“@+id/btntop”

android:layout_width=“60dp”

android:layout_height=“match_parent”

android:background=“#d9dee4”

android:text=“置顶”

android:textcolor=“@android:color/white”/>

<button

android:id=“@+id/btnunread”

android:layout_width=“120dp”

android:layout_height=“match_parent”

android:background=“#ecd50a”

android:clickable=“true”

android:text=“标记未读”

android:textcolor=“@android:color/white”/>

<button

android:id=“@+id/btndelete”

android:layout_width=“60dp”

android:layout_height=“match_parent”

android:background=“@color/red_ff4a57”

android:text=“删除”

android:textcolor=“@android:color/white”/>

</com.mcxtzhang.swipemenulib.swipemenulayout>


支持属性:

=====

1 通过 isios 变量控制是否是ios阻塞式交互,默认是打开的。

2 通过 isswipeenable 变量控制是否开启右滑菜单,默认打开。(某些场景,复用item,没有编辑权限的用户不能右滑)

3 通过开关 isleftswipe支持左滑右滑

有两种方式设置:

一:xml:

<com.mcxtzhang.swipemenulib.swipemenulayout

xmlns:app=“http://schemas.android.com/apk/res-auto”

app:ios=“false”

app:leftswipe=“true”

app:swipeenable=“true”>

二: java代码:

//这句话关掉ios阻塞式交互效果 并依次打开左滑右滑 禁用掉侧滑菜单

((swipemenulayout) holder.itemview).setios(false).setleftswipe(position % 2 == 0 ? true : false).setswipeenable(false);

支持特性:

=====

  • 不会同时展开2+个侧滑菜单。(可见界面上最多只会出现一个侧滑菜单)。

  • 侧滑过程中,禁止父控件上下滑动。

  • 多指同时滑动,屏蔽后触摸的几根手指。

  • 增加viewchache 的 get()方法,可以用在:当点击外部空白处时,关闭正在展开的侧滑菜单。

  • 以第一个子item(即contentitem)的宽度为控件宽度

每次更新的checklist:

===============

由于持续迭代,会发生完成一个feature、fix一个bug后,导致新的bug。

so,整理一份checklist,供每次迭代后验证,都通过,才会push到github库上。

| 项目 | 备注 | 验证 |

| — | — | — |

| isios | 切换至ios阻塞交互模式、android特色无阻塞交互模式 以下feature都可正常工作 | |

| isswipeenable | 是否支持关闭侧滑功能 | |

| isleftswipe | 是否支持双向滑动 | |

| contentitem内容可单击 | | |

| contentitem内容可长按 | | |

| 侧滑菜单显示时,contentitem不可点击 | | |

| 侧滑菜单显示时,contentitem不可长按 | | |

| 侧滑菜单显示时,侧滑菜单可以点击 | | |

| 侧滑菜单显示时,点击contentitem区域关闭菜单 | | |

| 侧滑过程中,屏蔽长按事件 | | |

| 通过滑动关闭菜单,不应该触发contentitem点击事件 | | |

难点、冲突的解决:

=========

1 contentitem的长按和本控件侧滑的冲突。

一开始我还是老思路,一直都是通过判断手指起始落点的坐标,判断手指落点处于何位置,屏蔽一些操作。当本控件功能越来越庞大,计算开始复杂,也容易出错。但也跌跌撞撞的撑了过来,但就在今天,我想到了另一种思路:通过禁用子view的longclickable属性来完成这个功能。于是我重构这部分代码,先利用git 查看之前的提交,去除掉那部分代码,并

在侧滑菜单展开smoothexpand()、关闭smoothclose()的函数中分别加入:

//2016 11 13 add 侧滑菜单展开,屏蔽content长按

if (null != mcontentview) {

mcontentview.setlongclickable(true);

}

//2016 11 13 add 侧滑菜单展开,屏蔽content长按

if (null != mcontentview) {

mcontentview.setlongclickable(true);

}

代码就这么简单,几小时前我才想到这么简单的解决方法,这也是促使我新撸一遍文章,记录本控件的一些改动的缘由之一。

2 如何支持任意父控件

这算是本控件最酷炫的魅力之一吧,在之前的文章 ,我详细描述了实现过程。

总结起来,我利用了一个static变量,保存了当前正在展开的view,

在进行各项操作时就可预先判断,如若会引起冲突,例如界面上出现两个侧滑菜单,

便自动关闭上一个菜单。

代码如下:

//存储的是当前正在展开的view

private static swipemenulayout mviewcache;

dispatchtouchevent()的actiondown里:

//如果down,view和cacheview不一样,则立马让它还原。且把它置为null

if (mviewcache != null) {

if (mviewcache != this) {

mviewcache.smoothclose();

}

//只要有一个侧滑菜单处于打开状态, 就不给外层布局上下滑动了

getparent().requestdisallowintercepttouchevent(true);

}

在侧滑菜单展开smoothexpand()、关闭smoothclose()的函数:

//展开就加入viewcache:

mviewcache = swipemenulayout.this;

//关闭置为null

mviewcache = null;

ondetachedfromwindow()里:

//每次viewdetach的时候,判断一下 viewcache是不是自己,如果是自己,关闭侧滑菜单,且viewcache设置为null,

// 理由:1 防止内存泄漏(viewcache是一个静态变量)

// 2 侧滑删除后自己后,这个view被recycler回收,复用,下一个进入屏幕的view的状态应该是普通状态,而不是展开状态。

@override

protected void ondetachedfromwindow() {

if (this == mviewcache) {

mviewcache.smoothclose();

mviewcache = null;

}

super.ondetachedfromwindow();

}

先自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、oppo等大厂,18年进入阿里一直到现在。

深知大多数初中级android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以扫码领取!!!!

总结

开发是面向对象。我们找工作应该更多是面向面试。哪怕进大厂真的只是去宁螺丝,但你要进去得先学会面试的时候造飞机不是么?

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和pdf(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

960页全网最全android开发笔记

资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图

《android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,即可免费领取!

体系的学习效果低效漫长且无助。

这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和pdf(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

相信它会给大家带来很多收获:

[外链图片转存中…(img-awoxqw2k-1711252183523)]

[外链图片转存中…(img-yubrf9k5-1711252183524)]

资料太多,全部展示会影响篇幅,暂时就先列举这些部分截图

《android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,即可免费领取!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com