国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android開發之ProgressBar字體隨著進度條的加載而滾動

2019-10-22 18:28:17
字體:
來源:轉載
供稿:網友

在網上翻閱了很多關于ProgressBar滾動效果,但是始終沒有找到適合項目中的這種效果,故自己寫這篇文章,記錄一下寫作過程,給大家做一個參考。先看下最終效果效果圖

progressBar,字體加載,滾動,progressBar進度條

我這里用的是LICEcap軟件錄制的gif圖,效果有點掉幀,哪位仁兄有比較好的錄制gif的軟件煩請相告,小弟在此先行謝過。

首先看下xml代碼,只有兩個系統控件,一個TextView和一個ProgressBar,Button只是為了方便觸發進度條的效果,實際項目中可以根據需求來做。首先看下xml中的代碼:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:layout_margin="5dp"> <TextView  android:layout_marginTop="50dp"  android:id="@+id/progress_precent"  android:layout_width="wrap_content"  android:layout_height="wrap_content"  android:text="0%"  android:textColor="#ff00"  android:textSize="12sp"  android:padding="3dp"/> <ProgressBar  android:id="@+id/pb_progressbar"  style="?android:attr/progressBarStyleHorizontal"  android:layout_width="match_parent"  android:layout_height="5dp"  android:max="100"  android:progress="0"  android:progressDrawable="@drawable/progressbar_color" /> <Button  android:id="@+id/btn_start"  android:layout_width="wrap_content"  android:layout_height="wrap_content"  android:layout_marginTop="30dp"  android:text="start" /></LinearLayout>

樣式:progressbar_color.xml

<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android" > <!-- 背景 gradient是漸變,corners定義的是圓角 --> <item android:id="@android:id/background">  <shape>   <corners android:radius="5dp" />   <solid android:color="#9a9a9a" />  </shape> </item> <!-- 進度條 --> <item android:id="@android:id/progress">  <clip>   <shape>    <corners android:radius="5dp" />    <solid android:color="#E14f50" />   </shape>  </clip> </item> </layer-list>

在onCreate()方法中得到控件的寬度,代碼如下:

 // 得到progressBar控件的寬度  ViewTreeObserver vto2 = pbProgressbar.getViewTreeObserver();  vto2.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {   @Override   public void onGlobalLayout() {    pbProgressbar.getViewTreeObserver().removeGlobalOnLayoutListener(this);    width = pbProgressbar.getWidth();    Log.i("TAG", "MainActivity onCreate()=="+pbProgressbar.getWidth());   }  });

先說下具體實現思路,再貼上最終代碼

實現思路是我們需要ProgressBar達到最大值時,TextView的位置移動到最遠處。要想得到progressBar的任意百分比可以移動到對應百分比的位置,咱們就需要知道每一個百分比移動的距離。說的還不夠明白的話咱們看看下面的公式,可以更好的理解。

    // 進度條的最小單位,默認是1,你也可以是其他數值,我在demo中為了方便使用了1:

    進度條的最小單位 / 進度條的最大值 = 每一個百分比移動的距離/總的距離(控件的總寬度)

    可以推導出:

    每一個百分比要移動距離 = (進度條的最小單位 / 進度條的最大值)*總的距離(控件的總寬度)

因為要做移動動畫效果,咱們為了避免ANR,直接開一個分線程來控制界面,主要代碼如下    

 //開啟分線程    new Thread(new Runnable() {      @Override      public void run() {        //每一段要移動的距離        scrollDistance = (float) ((1.0 / pbProgressbar.getMax()) * width);        for (int i = 1; i <= status; i++) {          runOnUiThread(new Runnable() {            @Override            public void run() {              currentStatue++;              currentPosition += scrollDistance;              pbProgressbar.incrementProgressBy(1);              //做一個平移動畫的效果              progressPrecent.setTranslationX(currentPosition);              progressPrecent.setText(currentStatue + "%");            }          });          try {            Thread.sleep(80);          } catch (InterruptedException e) {            e.printStackTrace();          }        }      }    }).start();

大功告成,但是當我們運行起來的時候發現,當ProgressBar達到最大值時,上面的字體超出了屏幕范圍而看不到了。效果如圖所示:

progressBar,字體加載,滾動,progressBar進度條

這給使用者造成了很大的困惑,靜下心來分析一下,可以知道TextView一直在對應ProgressBar數據的右面,語言功底不太好,咱們上圖看:

progressBar,字體加載,滾動,progressBar進度條

可以看出,當數據為0%時就在progressBar對應數據的右方,當數據為最大值時,超出屏幕顯示不了就不足為其了。咱們現在如果想讓progressBar是最大值時還能顯示,就需要當偏移的距離加上字體的寬度和字體右面的Padding值大于progressBar寬度的時候不偏移。接著修改代碼如下:

 //開啟分線程    new Thread(new Runnable() {      @Override      public void run() {        //每一段要移動的距離        scrollDistance = (float) ((1.0 / pbProgressbar.getMax()) * width);        for (int i = 0; i < status; i++) {          runOnUiThread(new Runnable() {            @Override            public void run() {              // 控制進度條的增長進度              pbProgressbar.incrementProgressBy(1);              currentStatue++;              tvPrecent.setText(currentStatue + "%");              // 得到字體的寬度              tvWidth = tvPrecent.getWidth();              currentPosition += scrollDistance;              //做一個平移動畫的效果              // 這里加入條件判斷              if (tvWidth + currentPosition <= width - tvPrecent.getPaddingRight()) {                tvPrecent.setTranslationX(currentPosition);              }            }          });          try {            Thread.sleep(80);          } catch (InterruptedException e) {            e.printStackTrace();          }        }      }    }).start();

我們運行起來,再來看下效果:

progressBar,字體加載,滾動,progressBar進度條

到這里咱們就完成了,有不清楚或者寫錯的地方歡迎留言指正,我會第一時間答復。需要源碼的朋友可以去github上下載,雙手奉上github地址:字體隨著ProgressBar的加載而滾動 。

總結

以上所述是小編給大家介紹的Android開發之ProgressBar字體隨著進度條的加載而滾動,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 微博| 石阡县| 梁平县| 定襄县| 开封市| 改则县| 宝清县| 凭祥市| 邛崃市| 桂林市| 波密县| 阳新县| 鹤庆县| 申扎县| 上犹县| 桐乡市| 延吉市| 肥东县| 凤冈县| 河北区| 金沙县| 施秉县| 讷河市| 荆门市| 高密市| 历史| 清流县| 四会市| 英德市| 嵊泗县| 鄂托克前旗| 镇平县| 徐汇区| 曲周县| 罗平县| 双城市| 普陀区| 黎川县| 莱州市| 唐海县| 杭州市|