亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

Android自定義加載框效果

瀏覽:2日期:2023-12-10 17:50:59

本文實例為大家分享了Android自定義加載框效果的具體代碼,供大家參考,具體內容如下

效果圖

Android自定義加載框效果

菊花圖標(mipmap-xxhdpi)

Android自定義加載框效果

加載框圓角背景drawable

<?xml version='1.0' encoding='utf-8'?><shape xmlns:android='http://schemas.android.com/apk/res/android' android:shape='rectangle'> <corners android:radius='12dp' /> <solid android:color='@color/transparent_black'/></shape>

布局文件

<?xml version='1.0' encoding='utf-8'?><layout xmlns:android='http://schemas.android.com/apk/res/android' xmlns:tools='http://schemas.android.com/tools' xmlns:app='http://schemas.android.com/apk/res-auto'> <data> </data> <androidx.constraintlayout.widget.ConstraintLayoutandroid:orientation='vertical'android:layout_width='wrap_content'android:layout_height='wrap_content'android:background='@drawable/bg_message_dialog'android:minWidth='132dp'android:minHeight='100dp'android:padding='15dp'><ImageView android: android:layout_width='35dp' android:layout_height='35dp' android:src='http://m.lshqa.cn/bcjs/@mipmap/ic_loading' app:layout_constraintTop_toTopOf='parent' app:layout_constraintStart_toStartOf='parent' app:layout_constraintEnd_toEndOf='parent' app:layout_constraintBottom_toTopOf='@id/tv'/><TextView android: android:layout_width='0dp' android:layout_height='wrap_content' android:textSize='12sp' android:textColor='@color/white' android:layout_marginTop='15dp' android:text='@string/loading' android:lineSpacingExtra='8dp' android:gravity='center_horizontal' app:layout_constraintTop_toBottomOf='@id/iv' app:layout_constraintStart_toStartOf='parent' app:layout_constraintEnd_toEndOf='parent' app:layout_constraintBottom_toBottomOf='parent' /> </androidx.constraintlayout.widget.ConstraintLayout></layout>

LoadingDialog.kt

package com.lzk.libcommon.widgetimport android.animation.ObjectAnimatorimport android.animation.ValueAnimatorimport android.graphics.Colorimport android.graphics.drawable.ColorDrawableimport android.os.Bundleimport android.view.LayoutInflaterimport android.view.Viewimport android.view.ViewGroupimport android.view.Windowimport android.view.animation.LinearInterpolatorimport androidx.databinding.DataBindingUtilimport androidx.fragment.app.DialogFragmentimport androidx.fragment.app.FragmentManagerimport com.blankj.utilcode.util.LogUtilsimport com.lzk.libcommon.Rimport com.lzk.libcommon.databinding.ViewLoadingDialogBinding/** * @Author: LiaoZhongKai * @Date: 2021/7/14 9:04 * @Description: 加載框 */class LoadingDialog: DialogFragment() { private var mTips: String? = null private lateinit var mLoadingDialogBinding: ViewLoadingDialogBinding private lateinit var mAnimation: ObjectAnimator override fun onStart() {super.onStart()//去掉DialogFragment外部的背景色dialog?.window?.apply { attributes = attributes.apply { //======================這里設置背景陰影透明度=============== //======================0是全透明===========================dimAmount = 0.0f }} } override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle? ): View {mLoadingDialogBinding = DataBindingUtil.inflate(inflater, R.layout.view_loading_dialog,container,false)dialog?.apply { requestWindowFeature(Window.FEATURE_NO_TITLE) setCanceledOnTouchOutside(false) window?.apply {//去掉DialogFragment內部的背景色setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))//去掉PaddingdecorView.setPadding(0,0,0,0) }}return mLoadingDialogBinding.root } override fun onViewCreated(view: View, savedInstanceState: Bundle?) {super.onViewCreated(view, savedInstanceState)rotate()setTips(mTips) } private fun rotate(){mAnimation = ObjectAnimator.ofFloat(mLoadingDialogBinding.iv,'rotation',360f).apply { repeatCount = ObjectAnimator.INFINITE repeatMode = ValueAnimator.RESTART interpolator = LinearInterpolator() duration = 1000}mAnimation.start() } override fun onDestroyView() {super.onDestroyView()mAnimation.cancel() } //顯示 fun showDialog(fragmentManager: FragmentManager, msg: String? = null){mTips = msgif (isVisible){ dismiss()}show(fragmentManager,'') } //隱藏 fun dismissDialog(){if (isAdded){ dismiss() mTips = null} } /** * 設置加載提示文字 */ private fun setTips(msg: String?): LoadingDialog{mLoadingDialogBinding.tv.visibility = if (msg.isNullOrEmpty()) View.GONE else View.VISIBLEif (!msg.isNullOrEmpty()){ mLoadingDialogBinding.tv.text = msg}return this }}

基類封裝

abstract class BaseVMActivity<T: ViewDataBinding,VM: BaseViewModel> : AppCompatActivity(){ private var mLoadingDialog: LoadingDialog? = null override fun onDestroy() {super.onDestroy()mLoadingDialog?.dismissDialog()mLoadingDialog = null } /** * 顯示加載彈框 */ fun showLoadingDialog(msg: String? = null){mLoadingDialog = LoadingDialog()mLoadingDialog!!.showDialog(supportFragmentManager,msg) } /** * 隱藏加載彈框 */ fun dismissLoadingDialog(){mLoadingDialog?.dismissDialog() }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
主站蜘蛛池模板: 香蕉网影院在线观看免费 | 免费看v片网站 | 久久久久久久国产 | 久久精品视频免费 | 国产综合精品一区二区 | 欧美一级片播放 | 日韩欧美一区二区三区在线 | 国产偷国产偷亚洲高清在线 | 波多野结衣在线视频观看 | 亚洲天堂久久精品 | 国产精品二区高清在线 | 久久久久久尹人网香蕉 | 亚洲图片视频在线 | 成人国产三级精品 | 玖玖精品视频在线观看 | 色婷婷久久综合中文久久蜜桃 | 欧美精品成人一区二区在线观看 | 国产精品成人免费观看 | 碰碰碰精品视频在线观看 | 亚洲综合久久久 | 国产精品一区二区久久精品涩爱 | 在线成人播放毛片 | 色噜噜国产精品视频一区二区 | 全国男人天堂网 | 国内自拍视频在线播放 | 精品在线一区 | 国产欧美成人一区二区三区 | 久久国产免费 | 日韩一级性生活片 | 狠狠色噜噜狠狠狠米奇9999 | 亚洲国产高清视频在线观看 | 色老头一区二区三区在线观看 | 久久精品视频免费播放 | 青青操在线视频 | 91久久精品青青草原伊人 | 亚洲精品视频久久久 | 在线视频日韩 | 日本亚欧乱色视频在线网站 | 免费在线一区二区三区 | 国产精品三级国语在线看 | 亚洲毛片免费在线观看 |