BasicLibrary——基于kotlin+jetpack+mvvm封装一套框架,提高Android开发效率
BasicLibrary
- BasicLibrary是基于kotlin+jetpack+mvvm封装的一套框架,提高Android开发效率
- 集成了自己封装的BasicUI库,关于BasicUI大家可以看我之前写的文章BasicUI常用UI组件和实用工具类封装,提高Android开发的效率
还包括:
- MMKV的封装
- 防止多次点击事件的处理
- Retrofit封装实现网络解耦
- 线程的切换,View的抖动效果
- LiveData实现事件分发总线
- 项目地址:https://github.com/Peakmain/BasicLibrary
怎样使用
Step 1. Add the JitPack repository to your build file
- Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Step 2. Add the dependency
-
|
功能列表
集成BaseActivity
class XXActivity(override val layoutId: Int = 自定义布局) :
BaseActivity<T : ViewDataBinding, E : BaseViewModel>() {
override fun initView() {
}
}- T一般是Databinding布局实现自动生成的类
- E需要继承于BaseViewModel,之后会自动实现initModel方法
class MainViewModel : BaseViewModel() {
override fun initModel() {
}
} - initModel在initView之前,setContentView之后实现的方法
- 之后可在activity中直接使用mViewModel来获取E的实例,无需初始化
- 也可通过getViewModel(modelClass: Class
)获取ViewModel,并多次获取是同一个ViewModel实例 Log.e("TAG","测试${getViewModel(MainViewModel::class.java)}")
Log.e("TAG","测试${getViewModel(MainViewModel::class.java)}")
集成BaseFragment
class XXFragment(override val layoutId: Int = 自定义布局) :
BaseFragment<T : ViewDataBinding, E : BaseViewModel>() {
override fun initView(fragmentView:View) {
}
}- 其他性质和BaseActivity一样,不再阐述
MMKV的使用
- 初始化
在Application中添加如下代码即可try {
TaskDispatcher dispatcher = BasicLibraryConfig.Companion.getInstance().getApp().getDispatcher();
dispatcher.start();
} catch (Exception e) {
e.printStackTrace();
} - 使用
保存数据获取数据PreferencesUtils.getInstance(this).saveParams(key,value)//👈🏻key: String, objects: Any
PreferencesUtils.getInstance(this).getParam(key,defalutParams)//👈🏻key: String, defaultObject: Any?
- 关于启动优化——启动器TaskDispatcher大家可以看我之前关于BasicUI的wiki:有向无环图实现启动器优化
防止多次点击事件的处理
- 立即处理延时处理
mBinding.tvTitle.click{
//todo 事件处理
}TextView事件的拆分//或者
mBinding.tvTitle.clickViewDelay{
//todo 事件处理
}mBinding.tvTitle.clickClipListener( mBinding.tvTitle,leftClick = {
//todo drawableLeft的点击事件
}){
//todo drawableRight的点击事件
}关于线程切换
切换到主线程延迟delayMills切换到主线程mBinding.tvTitle.ktxRunOnUiThread {
}延迟加载,默认是500msmBinding.tvTitle.ktxRunOnUiThreadDelay(delayMills) {
}延迟加载,设置延迟时间mBinding.tvTitle.wait {
}延迟加载,设置延迟时间和单位mBinding.tvTitle.wait(600) {
}mBinding.tvTitle.wait(600,TimeUnit.SECONDS) {
}
View的抖动效果
View.shakeAnimation( fromXDelta: Float = 0f,
toXDelta: Float = 5f,
fromYDelta: Float = 0f,
toYDelta: Float = 0f,
duration: Long = 500)
网络库的使用
- 推荐在ViewModel中进行初始化
- 创建Service
service就是Retrofit请求网络层的Service接口
private var api: WanAndroidApi = RetrofitManager.createService(WanAndroidApi::class.java,"https://wanandroid.com/")
如果想用自己的封装方法实现Service,可以调用以下方法
private var api: WanAndroidApi = RetrofitManager.createService(WanAndroidApi::class.java) {
//todo 自己创建的Service
}请求网络
第一种写法RetrofitManager.createData(api.getList(0,10), object : ApiStatus<ApiModel<ProjectBean>>() {
override fun before() {
//todo 调用请求网络前
}
override fun error(exception: Exception) {
//todo 返回错误
}
override fun success(t: ApiModel<ProjectBean>) {
//返回成功
}
})第二种写法
RetrofitManager.createData(api.projectTree, {
//todo before()
}, {
//todo success(
}, {
//todo error()
})
LiveData实现事件分发总线
- 注册或获取实例
val rxBus = RxBus.instance.register<Int>("test")
- 发送数据
rxBus.setData(100)
- 接受数据
val value=rxBus.value
CommonRecyclerDataBindingAdapter RecycleView在Binding的使用
class TestAdapter(data: MutableList<String>, layoutManager: LinearLayoutManager) :
CommonRecyclerDataBindingAdapter<String, RecyclerAdpterTestBinding>(
data,//👈🏻数据源
R.layout.recycler_adpter_test,//👈自定义布局
DefaultAdapterFooterConfig<String,RecyclerAdpterTestBinding>(layoutManager).item//👈是否显示加载更多,如果为null,则不显示加载更多,可自定义,可参考DefaultAdapterFooterConfig的源码
) {
override fun convert(
holder: BaseLibraryViewHolder<RecyclerAdpterTestBinding>,
itemData: String,
position: Int
) {
val binding = holder.itemDataBinding
binding.vm = itemData
}
}
获取协程的全局异常
GlobalCoroutineExceptionHandler().coroutineExceptionCallback={ context, exception->
//context:CoroutineContext
//exception:Throwable
}
BindingAdapter的使用
- ①、文本添加*前缀
app:asteriskPrevText=""//文本的名字
app:asteriskColor=""//星号的颜色 - ②、设置image的url图片
app:loadUrl=""//参数url
- ③、设置view的visibility是View.VISIBLE还是View.Gone
app:visibilityOrGone="@{!vm.isShow}"//true表示View.Visible,false则表示View.Gone
- ④、设置view的visibility是View.VISIBLE还是View.InVisibile
app:visibilityOrInVisible="@{vm.isShow}"//true表示View.Visible,false则表示View.InVisbile
- ⑤、防止多次重复点击
app:clickDelayTime="@{vm.delayTime}"//设置点击事件的延迟时间,参数为long类型
app:click="@{vm.clickListener}"//设置点击事件的事件处理 - ⑥、textView的drawableLeft和drawableRight的点击事件
app:drawableLeftClick=""//drawableLeft的点击事件
app:drawableRightClick=""//drawableRight的点击事件关于我
- 简书(https://www.jianshu.com/u/3ff32f5aea98)
- 我的GitHub地址(https://github.com/Peakmain)
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Peakmain的个人博客!
评论