IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 【Android】史上最简单,kotlin枚举注解 -> 正文阅读

[移动开发]【Android】史上最简单,kotlin枚举注解

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()的函数:

//展开就加入

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

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();

}

3 解决多指滑动冲突:

利用一个布尔值 flag,在ActionDown时判断是否继续接受触摸事件:

代码如下:

//防止多只手指一起滑我的flag 在每次down里判断, touch事件结束清空

private static boolean isTouching;

dispatchTouchEvent()的ActionDown里:

if (isTouching) {//如果有别的指头摸过了,那么就return false。这样后续的move…等事件也不会再来找这个View了。

return false;

} else {

isTouching = true;//第一个摸的指头,赶紧改变标志,宣誓主权。

}

ActionUp里:

isTouching = false;//没有手指在摸我了

4 支持GridLayoutManager

毕竟项目中在网格布局中使用侧滑菜单还属少数,所以一开始我将场景简单化,给本控件设置的宽度都是父控件的宽度-padding。后来有童鞋提出希望支持网格布局,一开始我思路也走了弯路,我还想着构建一个MatchParent的MeasureSpec,然后传给父控件(GridView、RecyclerView)用于测量呢。

正确思路是,取第一个子View,即ContentView的宽度用作本控件的宽度即可,这样在layout侧滑菜单时,自然而然将侧滑菜单layout在了不可见的区域,只有通过滑动才能显示它。

代码也没啥好说的:

onMeasure()中:

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

//2016 11 09 add,适配GridLayoutManager,将以第一个子Item(即ContentItem)的宽度为控件宽度

int contentWidth = 0;

int childCount = getChildCount();

for (int i = 0; i < childCount; i++) {

View childView = getChildAt(i);

if (childView.getVisibility() != GONE) {

measureChildWithMargins(childView, widthMeasureSpec, 0, heightMeasureSpec, 0);

final MarginLayoutParams lp = (MarginLayoutParams) childView.getLayoutParams();

mHeight = Math.max(mHeight, childView.getMeasuredHeight() + lp.topMargin + lp.bottomMargin);

if (i > 0) {//第一个布局是Left item,从第二个开始才是RightMenu

mRightMenuWidths += childView.getMeasuredWidth();

} else {

contentWidth = childView.getMeasuredWidth();

}

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-12-16 17:47:32  更:2021-12-16 17:50:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 8:33:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码