Convert Figma logo to code with AI

junixapp logoXPopup

🔥XPopup2.0版本重磅来袭,2倍以上性能提升,带来可观的动画性能优化和交互细节的提升!!!功能强大,交互优雅,动画丝滑的通用弹窗!可以替代Dialog,PopupWindow,PopupMenu,BottomSheet,DrawerLayout,Spinner等组件,自带十几种效果良好的动画, 支持完全的UI和动画自定义!(Powerful and Beautiful Popup for Android,can absolutely replace Dialog,PopupWindow,PopupMenu,BottomSheet,DrawerLayout,Spinner. With built-in animators , very easy to custom popup view.)

7,789
1,175
7,789
149

Quick Overview

XPopup is a powerful and flexible Android popup library that provides a wide range of customizable popup types, including alert dialogs, bottom sheets, and more. It aims to simplify the process of creating and managing complex popup interactions within Android applications.

Pros

  • Extensive Popup Types: XPopup offers a diverse range of popup types, including alert dialogs, bottom sheets, custom popups, and more, allowing developers to create a variety of user interactions.
  • Highly Customizable: The library provides a high degree of customization, enabling developers to tailor the appearance and behavior of the popups to match their application's design and user experience.
  • Smooth Animations: XPopup features smooth and visually appealing animations for the popup transitions, enhancing the overall user experience.
  • Flexible Positioning: The library allows developers to position the popups in various locations on the screen, including center, top, bottom, and custom positions.

Cons

  • Learning Curve: The library's extensive features and customization options may present a steeper learning curve for developers, especially those new to the project.
  • Dependency on Android Framework: As an Android-specific library, XPopup is dependent on the Android framework and may not be suitable for cross-platform development.
  • Performance Considerations: Depending on the complexity of the popups and the number of concurrent instances, the library's performance may be a concern in resource-constrained environments.
  • Potential Compatibility Issues: The library's ongoing development and updates may introduce compatibility issues with older Android versions or specific device configurations.

Code Examples

Creating a Simple Alert Popup

val popup = XPopup.Builder(context)
    .dismissOnTouchOutside(true)
    .asAlert()
    .setTitle("Alert")
    .setContent("This is an alert popup.")
    .setConfirmListener { popup.dismiss() }
    .show()

This code creates a simple alert popup with a title, content, and a confirm button that dismisses the popup when clicked.

Displaying a Bottom Sheet Popup

val popup = XPopup.Builder(context)
    .dismissOnTouchOutside(true)
    .asBottomList("Options", arrayOf("Option 1", "Option 2", "Option 3")) { position, text ->
        // Handle the selected option
    }
    .show()

This code creates a bottom sheet popup with a list of options. When an option is selected, the corresponding callback is invoked.

Customizing a Popup's Appearance

val popup = XPopup.Builder(context)
    .dismissOnTouchOutside(true)
    .popupAnimation(PopupAnimation.ScaleAlphaFromCenter)
    .popupPosition(PopupPosition.Top)
    .hasStatusBarShadow(true)
    .backgroundColor(Color.WHITE)
    .borderColor(Color.GRAY)
    .borderWidth(2f)
    .cornerRadius(16f)
    .maxWidth(800)
    .asCustom(MyCustomPopup(context))
    .show()

This code demonstrates how to customize various aspects of a popup, including the animation, position, background color, border, and corner radius. It also shows how to create a custom popup by providing a custom view.

Getting Started

To use XPopup in your Android project, follow these steps:

  1. Add the XPopup dependency to your app-level build.gradle file:
dependencies {
    implementation 'com.lxj:xpopup:2.2.0'
}
  1. In your activity or fragment, create an instance of the XPopup.Builder and configure the popup:
val popup = XPopup.Builder(this)
    .dismissOnTouchOutside(true)
    .asAlert()
    .setTitle("Alert")
    .setContent("This is an alert popup.")
    .setConfirmListener { popup.dismiss() }
    .show()
  1. Customize the popup's appearance and behavior by using the various methods provided by the XPopup.Builder class.

  2. If you need to create a custom popup, extend the BasePopupView class and override the necessary methods to define the popup

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

XPopup

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

好站推荐

  1. 国内真正免费使用ChatGPT大模型的网站 https://www.hermchats.com?code=0D27F4D8
  2. 稳定科学上网工具:https://panel.dg1.top/#/register?code=59H7dLR3

中文 | 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无
LOPER7https://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.