溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框

發(fā)布時間:2022-06-22 09:20:26 來源:億速云 閱讀:476 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框”,在日常操作中,相信很多人在Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

先來展示下效果圖:

Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框

需要準備好素材。如上圖中的那個旋轉(zhuǎn)的圈圈,素材圖是一張png圖片,分辨率114x114:

Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框

如何實現(xiàn)自動旋轉(zhuǎn)的效果呢,使用android的Rotate動畫。

在res/drawable下建一個rotate_dialog_progress.xml文件,內(nèi)容如下:

<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/loading_white"
    android:fromDegrees="0"
    android:interpolator="@android:anim/cycle_interpolator"
    android:pivotX="50%"
    android:pivotY="50%"
    android:toDegrees="1440" />

這里面的幾個屬性解釋:

<?xml version="1.0" encoding="utf-8"?>
 <rotate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromDegrees="0"            #初始角度
    android:toDegrees="1440"           #結(jié)束時角度,值為正時順時針旋轉(zhuǎn),值為負時逆時針旋轉(zhuǎn)
    android:pivotX="50%"               #旋轉(zhuǎn)中心x軸坐標,取值可以是數(shù)值(50)、百分數(shù)(50%)、百
                                        分數(shù)p(50%p),當取值為數(shù)值時,縮放起點為View左上角坐標
                                        加具體數(shù)值像素,當取值為百分數(shù)時,表示在當前View左上角坐
                                        加上View寬度的具體百分比,當取值為百分數(shù)p時,表示在View
                                        左上角坐標加上父控件寬度的具體百分比
    android:pivotY="50%"               #同上
    android:duration="700"             #動畫持續(xù)時間,毫秒為單位
    android:fillAfter="true"           #動畫結(jié)束后,保持結(jié)束時的狀態(tài)
    android:fillBefore="true"          #動畫結(jié)束后,恢復為初始狀態(tài)
    android:fillEnabled="true"         #效果同上
    android:repeatCount="5"            #重復次數(shù),取值為-1時無限重復,默認動畫執(zhí)行一次
    android:repeatMode ="reverse"      #重復模式,有reverse和restart兩個值,前者為倒序回放,后者為重新開始
    android:interpolator="@android:anim/accelerate_decelerate_interpolator" #插值器            
    />

接下來在styles.xml文件中定義一個樣式文件供使用。內(nèi)容如下:

<style name="myProgressBarStyleLarge">
        <item name="android:indeterminateDrawable">@drawable/rotate_dialog_progress</item>
        <item name="android:width">200dp</item>
        <item name="android:height">200dp</item>
    </style>

然后就可以這樣使用我們自定義的progressbar啦:

<ProgressBar
        android:id="@+id/loadingImageView"
        
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:layout_gravity="center"
        android:padding="20dp" />

這還不算完,一般progressbar要放在dialog對話框中來用??聪聦蚩騞ialog的樣式dialog_progress.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/corner_bg_dialog_progress"
    android:orientation="vertical"
    android:gravity="center"
    android:paddingTop="30dp"
    android:paddingBottom="30dp"
    android:paddingLeft="30dp"
    android:paddingRight="30dp">
 
    <ProgressBar
        android:id="@+id/loadingImageView"
        
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:layout_gravity="center"
        android:padding="20dp" />
 
    <TextView
        android:id="@+id/loadingmsg"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:textColor="@android:color/white"
        android:text="正在處理中..."
        android:textSize="30dp"
        android:layout_marginBottom="30dp"
        android:layout_marginTop="10dp" />
 
</LinearLayout>

為了使Dialog的背景和邊框的棱角好看,這里自定義了Dialog的背景。

android:background="@drawable/corner_bg_dialog_progress"

它就是一個放在res/drawable文件夾下的一個自定義shape。

corner_bg_dialog_progress.xml文件內(nèi)容如下:

<?xml version="1.0" encoding="UTF-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="@color/light_black" />
    <corners android:radius="@dimen/corner_radius_one" />
</shape>

最后,實現(xiàn)一個Dialog并加載這個dialog_progress.xml布局,顯示出來即可。

在需要提示進度的地方,showProgressDialog。在結(jié)束時closeProgressDialog。

override fun showProgressDialog(msg: String) {
                if (dialogProgress == null) {
                    dialogProgress = DialogProgress(mPresentation!!.context, activity.getString(R.string.loading), false)
                }
                dialogProgress!!.setMessage(msg)
                dialogProgress!!.show()
            }
 
override fun closeProgressDialog() {
                dialogProgress?.dismiss()
            }

到此,關(guān)于“Android怎么自定義ProgressBar實現(xiàn)漂亮的進度提示框”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI