Home

Awesome

<p align="center"> <img src="https://raw.githubusercontent.com/xuexiangjys/XUI/master/art/app_logo_xui.png" width="388" height="321" alt="Banner" /> </p>

XUI

api Issue Star

English | Chinese

A simple and elegant Android native UI framework, free your hands! Click on the instruction document and experience it!

Covers most of the UI components:TextView、Button、EditText、ImageView、Spinner、Picker、Dialog、PopupWindow、ProgressBar、LoadingView、StateLayout、FlowLayout、Switch、Actionbar、TabBar、Banner、GuideView、BadgeView、MarqueeView、WebView、SearchView...etc. A series of components and colorful style themes。

Please read 【wisdom of asking questions】 before raising the issue and strictly follow the issue template fill in and save everyone's time.

Please read the instruction document carefully before use, important things are to be repeated for three time!!!

please read the instruction document carefully before use, important things are to be repeated for three time!!!

Please read the instruction document carefully before use, important things are to be repeated for three time!!!

About me

WeChat public numberjuejinzhihuCSDNjianshusegmentfaultbilibilitoutiao
我的Android开源之旅Click meClick meClick meClick meClick meClick meClick me

Rapid integration of X-Library

In order to facilitate the rapid integration of X-Library, I provide a template project for your reference: https://github.com/xuexiangjys/TemplateAppProject

In addition, I have also produced several video tutorials for your reference.


Features

Stargazers over time

Stargazers over time


Usage

Before you consider using XUI, you must be clear that this framework provides a whole set of UI solutions. If you just want to use a few of them, you don't need to introduce such a huge UI library. You can find better component libraries on GitHub. If you want to have a customized, unified UI overall solution, then you can continue to look!

Add gradle dependency

1.In the project root directory build.gradle:

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

2.Then add in the dependencies of build.gradle of the application project (usually app):

dependencies {
  ...
  //androidx project
  implementation 'com.github.xuexiangjys:XUI:1.2.1'

  implementation 'androidx.appcompat:appcompat:1.3.1'
  implementation 'androidx.recyclerview:recyclerview:1.2.1'
  implementation 'com.google.android.material:material:1.4.0'
  implementation 'com.github.bumptech.glide:glide:4.12.0'
}

【Note】 If your project does not currently use androidx, please use the following configuration:

dependencies {
  ...
  //support project
  implementation 'com.github.xuexiangjys:XUI:1.0.9-support'

  implementation 'com.android.support:appcompat-v7:28.0.0'
  implementation 'com.android.support:recyclerview-v7:28.0.0'
  implementation 'com.android.support:design:28.0.0'
  implementation 'com.github.bumptech.glide:glide:4.8.0'
}

Initialization

1.Modify the basic theme of the application (required)

The basic theme of the application must be set, otherwise the component will not work normally! It is very important to ensure that the theme of all windows using XUI components is a subclass of XUITheme!!!

Basic topic type:

<style name="AppTheme" parent="XUITheme.Phone">

    <!-- Customize your own theme style -->

    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>

</style>

Of course, you can also call the following code at the beginning of the Activity to set the theme dynamically.

@Override
protected void onCreate(Bundle savedInstanceState) {
    XUI.initTheme(this);
    super.onCreate(savedInstanceState);
    ...
}

2.Adjust font library (omit if there is no requirement for font)

(1)Set the font library path you need to modify (under assets)

// Set the default font to Chinese line Kai, write your font library here
XUI.getInstance().initFontStyle("fonts/hwxk.ttf");

(2)Add the following code to the basic activity of the project to inject fonts

Note: after version 1.1.4, use the following settings for injection

@Override
protected void attachBaseContext(Context newBase) {
    // Injection font
    super.attachBaseContext(ViewPumpContextWrapper.wrap(newBase));
}

Note: versions 1.1.3 and earlier use the following settings for injection

@Override
protected void attachBaseContext(Context newBase) {
    // Injection font
    super.attachBaseContext(CalligraphyContextWrapper.wrap(newBase));
}

Demonstration

Screenshot

1_splash.png2_main.png3_about.png

4_menu.png5_dialog.png6_bottom_dialog.png

7_picker.png8_webview.png9_flowlayout.png

10_ninegrid.png11_radius_imageview.png12_badge_view.png

13_tabview.png14_citypicker.png15_refresh_layout.png

16_spinner.png

Demo download

The demo program is about 18M (mainly because the demo integrates a small video shooting library, which is about 13M, while XUI library is only 644k in size). The project is relatively large, and dandelion is recommended to download.

xui_size.png

Pgyer Download

Pgyer Download password: xuexiangjys

Pgyer

download_pugongying.png

Github Download

Github

download_github.png

Contribution

Due to my limited energy, you are welcome to actively contribute your idea. You will have the opportunity to participate in the maintenance of star over 1000 projects on GitHub and enhance your industry influence!

Code contribution requirements:

Thanks

Sponsor

Your support is the driving force of my maintenance. I will list the list of all the reward personnel at the bottom as the voucher. Please leave the notes of the support items before rewarding!

pay.png

Thank you for your sponsorship:

NameMoneyPlatform
C*y1¥WeChat
*流1¥WeChat
*声50¥WeChat
*宇涛5¥Alipay
*事10¥WeChat
优*1168¥WeChat
*、20¥WeChat
*钰晗6¥Alipay
*娜3¥WeChat
*米20¥WeChat
*忘10¥WeChat
*清红1¥Alipay
*口5¥WeChat
*10.24¥WeChat
*俊耀100¥Alipay
*俊杰1¥Alipay
*鸥10.24¥WeChat
*云20.21¥Alipay
*钰晗66¥Alipay
*杰柱10¥Alipay
*毛6.66¥WeChat
*凯10¥WeChat
r*o8.88¥WeChat
T*87.77¥WeChat
v*d20¥WeChat
B*G1¥WeChat
*舞10¥WeChat
*肉2¥WeChat
*拖12.12¥WeChat
*鱼20¥WeChat
*明20¥WeChat
*化8¥WeChat
*攀16.80¥Alipay
**航10¥Alipay
**飞10.24¥Alipay
*瑟1¥WeChat
*原10.24¥Alipay
*越10.24¥WeChat
**俊80¥Alipay
*尋10.24¥WeChat
爱生活100¥QQ
*茶100¥WeChat
*头2¥WeChat
*噜10.99¥WeChat
Wm10¥WeChat
*谷10¥WeChat
*望5¥WeChat
J*o10.24¥WeChat
*休10.24¥WeChat
**俊80¥Alipay
**伟1.1¥Alipay
**云5¥Alipay
*航3¥Alipay
*维5¥WeChat
*鑫188.88¥Alipay
*玉10¥Alipay
**贺100¥Alipay
**伟65¥Alipay
*G1¥WeChat
M*u10.24¥WeChat
S*m10.24¥WeChat
T*g15¥WeChat
*边10.24¥WeChat
*寻20.48¥WeChat
*凉10.24¥WeChat
S*y10.24¥WeChat
M*n1¥WeChat
J*e10.24¥WeChat
*、10.24¥WeChat
禹*)1¥WeChat
X*?18.88¥WeChat
*事5¥WeChat
*之10¥WeChat
*安18.88¥WeChat
*🎵10.24¥WeChat
*👔10¥WeChat
*洲10¥WeChat

Contact