XPopup

Project Url: li-xiaojun/XPopup
Introduction: 🔥功能强大,UI 简洁,交互优雅的通用弹窗!可以替代 Dialog,PopupWindow,PopupMenu,BottomSheet,DrawerLayout,Spinner 等组件,自带十几种效果良好的动画, 支持完全的 UI 和动画自定义!(Powerful and Beautiful Popup,can absolutely replace Dialog,PopupWindow,PopupMenu,BottomSheet,DrawerLayout,Spinner. With built-in animators , very easy to custom Popup View.)
More: Author   ReportBugs   
Tags:

国内 Gitee 镜像地址:https://gitee.com/lxj_gitee/XPopup

中文 | English

  • 内置几种了常用的弹窗,十几种良好的动画,将弹窗和动画的自定义设计的极其简单;目前还没有出现 XPopup 实现不了的弹窗效果。 内置弹窗允许你使用项目已有的布局,同时还能用上 XPopup 提供的动画,交互和逻辑封装。
  • UI 动画简洁,遵循 Material Design,在设计动画的时候考虑了很多细节,过渡,层级的变化
  • 交互优雅,实现了优雅的手势交互,智能的嵌套滚动,智能的输入法交互,具体看 Demo
  • 适配全面屏和各种挖孔屏,目前适配了小米,华为,谷歌,OPPO,VIVO,三星,魅族,一加全系全面屏手机
  • 自动监听 Activity/Fragment 生命周期或任意拥有 Lifecycle 的 UI 组件,自动释放资源。在 Activity/Fragment 直接 finish 的场景也避免了内存泄漏
  • XPopup 实现了 LifecycleOwner,可以直接被 LiveData 监视生命周期,弹窗可见时才更新数据,不可见不更新
  • 很好的易用性,自定义弹窗只需继承对应的类,实现你的布局,然后像 Activity 那样,在onCreate方法写逻辑即可
  • 性能优异,动画流畅;精心优化的动画,让你很难遇到卡顿场景
  • 支持在应用后台弹出(需要申请悬浮窗权限,一行代码即可)
  • 支持 androidx,完美支持 RTL 布局,完美支持横竖屏切换,支持小窗模式
  • 如果你想要时间选择器和城市选择器,可以使用 XPopup 扩展功能库 XPopupExt: https://github.com/li-xiaojun/XPopupExt

设计思路: 综合常见的弹窗场景,我将其分为几类:

  • Center 类型,就是在中间弹出的弹窗,比如确认和取消弹窗,Loading 弹窗
  • Bottom 类型,就是从页面底部弹出,比如从底部弹出的分享窗体,知乎的从底部弹出的评论列表,内部已经处理好手势拖拽和嵌套滚动
  • Attach 类型,就是弹窗的位置需要依附于某个 View 或者某个触摸点,就像系统的 PopupMenu 效果一样,但 PopupMenu 的自定义性很差,淘宝的商品列表筛选的下拉弹窗,微信的朋友圈点赞弹窗都是这种。
  • Drawer 类型,就是从窗体的坐边或者右边弹出,并支持手势拖拽;好处是与界面解耦,可以在任何界面实现 DrawerLayout 效果
  • ImageViewer 大图浏览类型,就像微信那样的图片浏览弹窗,带有良好的拖拽交互体验,内部嵌入了改良的 PhotoView 和 subsampling-scale-imageview,支持加载超长长达图片并且不 OOM
  • FullScreen 类型,全屏弹窗,看起来和 Activity 一样,可以设置任意的动画器;适合用来实现登录,选择性的界面效果。
  • Position 自由定位弹窗,弹窗是自由的,你可放在屏幕左上角,右下角,或者任意地方,结合强大的动画器,可以实现各种效果。

演示

内置弹窗(支持复用已有布局) 列表 Center 弹窗
Bottom 列表弹窗(手势拖拽,横竖滚动) 自定义 Bottom 弹窗(天然支持嵌套滚动,多层弹窗)
Attach 弹窗(动画优雅,智能定位,长按支持) 自定义 Attach 弹窗(任意方向支持,灵活易用)
Drawer 弹窗(手势拖拽,状态栏阴影) 全屏弹窗(可作为 Activity 替代品,搭配十几个动画使用更佳)
Position 自由定位弹窗(放在屏幕任意地方) 自定义贴在输入法之上的弹窗
PartShadow 局部阴影弹窗 向上向下都可以
ImageViewer 大图浏览弹窗(拖拽自然,如丝般顺滑) 超长图片,永不 OOM(图像渐变过渡,优雅从容)
大图浏览弹窗,支持界面自定义 配合 ViewPager 使用
自定义弹窗和自定义动画 内置优雅美观的动画器,可搭配弹窗结合使用
应用后台弹出(一行代码实现权限申请) 联想搜索实现,轻而易举
气泡弹窗,横向和竖向已准备好!

快速体验

Gif 录制的有些卡顿,真机预览效果更佳。扫描二维码下载 Demo:

如果二维码图片不可见,点我下载 Demo 体验

Gradle

implementation 'com.github.li-xiaojun:XPopup:版本号看上面'

jitpack 还要求在工程根目录的build.gradle中添加如下:

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}

其中编译版本必须 >= 29:

compileSdkVersion 29

必须添加的依赖库,版本不用和我一致:

implementation 'androidx.appcompat:appcompat:1.3.1'
implementation 'com.google.android.material:material:1.4.0'
implementation 'androidx.recyclerview:recyclerview:1.2.1'

xpopup 依赖了subsampling-scale-image-view, 如果你也依赖了这个库并且版本冲突,可以做个 exclude 即可:

implementation ('com.github.li-xiaojun:XPopup:版本号看上面'){
  exclude group: "com.davemorrissey.labs", module: "subsampling-scale-image-view-androidx"
}

使用文档

具体使用方法全在 WIKI 中,请查看下面各个章节:

混淆

-dontwarn com.lxj.xpopup.widget.**
-keep class com.lxj.xpopup.widget.**{*;}

谁在用 XPopup

我本人很希望您能点击这里附上使用这个库的 App 名或者公司名,这样会给我更大的动力和热情去维护这个类库。

根据热心朋友提供的信息,目前使用 XPopup 的产品和公司有(70+):

打个赏

如果你觉得我帮助到了你,节省了你的时间,可以对我进行打赏(打赏时可以附上自己的大名和 Github 地址),金额随意,以表支持。

名字 Github 地址
Alfred
LOPER7 https://github.com/loperSeven
microshow(RxFFmpeg 作者) https://github.com/microshow

阿里云链接

如果有朋友购买阿里云服务器,可以点我的链接进入:

https://www.aliyun.com/minisite/goods?userCode=bak7qpav

有大量的代金券和折扣!!!

ECS-1 核 2G40G 硬盘 1M 带宽 : 91 元/年

ECS-2 核 4G40G 硬盘 1M 带宽 : 414 元/年

ECS-4 核 8G40G 硬盘 5M 带宽 : 1046 元/年

更多产品点击链接进入查看。。。

联系方式

Android 开发交流群:783659607

QQ Email: 16167479@qq.com

QQ: 16167479

Licenses

 Copyright 2019 li-xiaojun

 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
Apps
About Me
GitHub: Trinea
Facebook: Dev Tools