#创作者激励#【FFH】自制ArkUI组件-文件管理器(二)悬浮小球! 原创 精华
FFH_PETSJ
发布于 2023-2-24 03:04
浏览
5收藏
【本文正在参加2023年第一期优质创作者激励计划】
前言
交互设计
前言
经过重重的改造封装,这一版的FilerBall组件基本达到了辅助开发的效果
继上一篇文章,组件的基本功能完成了,但它的实用性和简洁性还可以有很大的提高。
为了让它变成一款可用性强的开发辅助组件,我决定从UI交互下手,将其打造成悬浮动态窗口,并封装成组件接口 FilerBall。
上一篇介绍了文件管理接口的使用,这篇就以它为案例,简单介绍如何发挥ArkUI框架在前端独特的优势,包括UI交互动画、组件自适应能力、自定义组件封装等,经验值满满!
上文链接:https://ost.51cto.com/posts/21308
先上效果图:组件悬浮小窗
交互设计
组件UI整体设计:
- 顶部可滑动横幅:展示当前访问的路径
滑动效果使用Scroll组件
- 中间主体:展示该层级的文件,文件夹目录可进入下一级
- 底部返回按键:返回上一级文件
- “进入箭头”实现:由于属于三方组件,不方便用icon图片,因此用“>”符号经过 图形变换 来代替
属性 | |
---|---|
scale | 可以分别设置X轴、Y轴、Z轴的缩放比例,默认值为1,同时可以通过centerX和centerY设置缩放的中心点。 |
自适应布局:
ArkUI自身具有自适应的能力,我们则需要用对属性方法和遵循某些规律就可实现组件自适应布局
本组件中基本使用Column和Row容器组件实现布局,例如:
- 顶部和底部高度固定,中间主体的高度弹性伸缩
- 单个文件UI,内容信息左对齐,箭头右对齐,宽度采用百分比设置
竖屏
横屏
悬浮窗改造!
在不修改原代码的基础上,利用自身的自适应性,额外封装一层组件: 原组件Filer ==> 悬浮球动态扩展组件FilerBall 。
FilerBall 调用示例:
父组件及接口基本属性设置:
参数 | 描述 | 必填 | ETS类型 |
---|---|---|---|
positionX | 悬浮球初始屏幕定位 X | 是,需与父组件一致 | number |
positionY | 悬浮球初始屏幕定位 Y | 是,需与父组件一致 | number |
ballSize | 悬浮球大小 | 是 | Length |
Height | Filer组件高度 | 否,默认 100% | Length |
Width | Filer组件高度 | 否,默认 100% | Length |
代码实现:
封装FilerBall的代码主要是这几点:
- 拖动效果
- 悬浮球与Filer组件的切换效果
- 拖动效果
下面是实现拖动效果的代码:
- 悬浮球与Filer组件的切换效果
- 使用ArkUI的条件渲染来切换悬浮球和Filer组件的UI。
- 给Filer添加加上像手机应用小窗顶部的横条组件,用于按住拖拽、点击切换悬浮球态。
- 为切换添加显示动画(文档传送门:显示动画 )
Filer封装操作横条
显示动画
最终效果图GIF
END
构想源于实践,实践启发构想。在开发当中偶然的想法一步步凝聚了现实,编写FilerBall组件的过程学到了很多经验。它仍具有很高的扩展性和创造性,作为一个简单的开发辅助工具组件,可能实现的不是很好,但也许日后的某次开发中我会需要它,正好接下来也学习学习怎么封装成第三方库。
(源代码在文章的资源附件FilerBall.md中,是在 https://ost.51cto.com/posts/21308 附件代码基础上封装的,测试用的Demo工程压缩包也一起上传了)
©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
FilerBall组件.zip 62.34K 127次下载
已于2023-2-27 11:57:21修改
赞
9
收藏 5
回复
9
6
5
相关推荐
还有这种优化的方法,悬浮效果真不错
3点发文,开源的大佬们可真卷
很好的想法,点赞
这个小球手机杀毒软件经常能见到
在中断微信公号阅读的时候,微信会有一个贴边的悬浮求,能够从对话中快速回到阅读的文章。
先搞出来,具体做什么用途还是得脑暴一哈哈
动画很丝滑
===========
一个思路,手机下图片很多时候下载完成后仅提示下载完成和存储路径,短时间用户记不住文件存储的路径了,只能打文件管理器里面硬翻了。
如果这个悬浮小球能够直接读取toast里面的文件路径,是不是可以直接通过悬浮小球定位到刚刚下载的图片,然后在悬浮小球中做分享、删除、移动等等操作
这个思路不错!悬浮球能扩展的功能确实很多,之后可以继续研究迭代