Android循环确定ProgressBar

我想创build一个Circluar Determinate ProgressBar,它显示Bar中心的进度。 有没有任何默认的方式来创build这个,或者我将不得不创build我自己的自定义的。

Solutions Collecting From Web of "Android循环确定ProgressBar"

首先添加一个progress_circle.xml到你的res / drawable目录,像这样:

<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android" > <item android:drawable="@drawable/progress_circular_background"/> <item> <shape android:innerRadiusRatio="3.4" android:shape="ring" android:thicknessRatio="6.0" > <gradient android:endColor="#ffffffff" android:startColor="#ffffff" android:type="sweep" android:useLevel="true" /> </shape> </item> <item> <rotate android:drawable="@drawable/progress_particle" android:fromDegrees="0" android:pivotX="50%" android:pivotY="50%" android:toDegrees="360" /> </item> </layer-list> 

我谷歌search图像同时search“progress_particle.png”和“progress_circular_background.png”(带引号),因为缺省的android默认drawables。 你可能想要自定义这些,但他们会做,让你开始。

然后在你的xml布局中:

 <ProgressBar android:id="@+id/timer_progress" style="?android:attr/progressBarStyleHorizontal" android:layout_width="200dp" android:layout_height="200dp" android:indeterminate="false" android:max="60" android:progressDrawable="@drawable/progress_circle" /> 

我的最大值是60,因为我用了一个秒计时器,但是你可能有不同的东西。

诀窍是你需要使用style =“?android:attr / progressBarStyleHorizo​​ntal”,尽pipe这是一个循环的过程。

在我的博客demonuts.com上,我已经在Android环境进度条上写了详细的例子。您也可以在这里find完整的源代码和解释。

下面是我如何在没有任何库的情况下在纯代码中使用百分比圆形循环进度条。

在这里输入图像说明

首先创build一个名为circular.xml的可绘制文件

 <?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <item android:id="@android:id/secondaryProgress"> <shape android:innerRadiusRatio="6" android:shape="ring" android:thicknessRatio="20.0" android:useLevel="true"> <gradient android:centerColor="#999999" android:endColor="#999999" android:startColor="#999999" android:type="sweep" /> </shape> </item> <item android:id="@android:id/progress"> <rotate android:fromDegrees="270" android:pivotX="50%" android:pivotY="50%" android:toDegrees="270"> <shape android:innerRadiusRatio="6" android:shape="ring" android:thicknessRatio="20.0" android:useLevel="true"> <rotate android:fromDegrees="0" android:pivotX="50%" android:pivotY="50%" android:toDegrees="360" /> <gradient android:centerColor="#00FF00" android:endColor="#00FF00" android:startColor="#00FF00" android:type="sweep" /> </shape> </rotate> </item> </layer-list> 

现在在您的activity_main.xml添加以下内容:

  <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/dialog" tools:context="com.example.parsaniahardik.progressanimation.MainActivity"> <ProgressBar android:id="@+id/circularProgressbar" style="?android:attr/progressBarStyleHorizontal" android:layout_width="250dp" android:layout_height="250dp" android:indeterminate="false" android:max="100" android:progress="50" android:layout_centerInParent="true" android:progressDrawable="@drawable/circular" android:secondaryProgress="100" /> <ImageView android:layout_width="90dp" android:layout_height="90dp" android:background="@drawable/whitecircle" android:layout_centerInParent="true"/> <TextView android:id="@+id/tv" android:layout_width="250dp" android:layout_height="250dp" android:gravity="center" android:text="25%" android:layout_centerInParent="true" android:textColor="@color/colorPrimaryDark" android:textSize="20sp" /> </RelativeLayout> 

activity_main.xml我使用了一个带有白色背景的圆形图像,以百分比forms显示白色背景。 这是图像:

在这里输入图像说明

您可以更改此图像的颜色以设置百分比文字的自定义颜色。

现在,最后将下面的代码添加到MainActivity.java

 import android.content.res.Resources; import android.graphics.drawable.Drawable; import android.os.Handler; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.animation.DecelerateInterpolator; import android.widget.ProgressBar; import android.widget.TextView; public class MainActivity extends AppCompatActivity { int pStatus = 0; private Handler handler = new Handler(); TextView tv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Resources res = getResources(); Drawable drawable = res.getDrawable(R.drawable.circular); final ProgressBar mProgress = (ProgressBar) findViewById(R.id.circularProgressbar); mProgress.setProgress(0); // Main Progress mProgress.setSecondaryProgress(100); // Secondary Progress mProgress.setMax(100); // Maximum Progress mProgress.setProgressDrawable(drawable); /* ObjectAnimator animation = ObjectAnimator.ofInt(mProgress, "progress", 0, 100); animation.setDuration(50000); animation.setInterpolator(new DecelerateInterpolator()); animation.start();*/ tv = (TextView) findViewById(R.id.tv); new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub while (pStatus < 100) { pStatus += 1; handler.post(new Runnable() { @Override public void run() { // TODO Auto-generated method stub mProgress.setProgress(pStatus); tv.setText(pStatus + "%"); } }); try { // Sleep for 200 milliseconds. // Just to display the progress slowly Thread.sleep(8); //thread will take approx 1.5 seconds to finish } catch (InterruptedException e) { e.printStackTrace(); } } } }).start(); } } 

如果你想制作水平的进度条,请点击这个链接,它有许多有价值的例子与源代码:
http://www.skholingua.com/android-basic/user-interface/form-widgets/progressbar