【Android】ProgressBar圆形加载样式、进度条样式以及代码控制显示隐藏

一、预览

ProgressBar的使用很简单,先看一下效果图
progressBar的两种样式

二、layout布局

就放了两个progressBar和两个Button

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:gravity="center_horizontal"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <TextView
        android:layout_marginTop="50dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="圆形加载样式progressBar"/>
        
        默认的样式是圆形加载样式
    <ProgressBar
        android:id="@+id/progressBar1"
        android:layout_width="match_parent"
        android:visibility="gone"  先让它隐藏,代码控制显示
        android:layout_height="wrap_content"/>

    <Button
        android:id="@+id/btn1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="显示"/>


    <TextView
        android:layout_marginTop="50dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="进度条样式progressBar"/>
    <ProgressBar
        android:id="@+id/progressBar2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:visibility="gone"  先让它隐藏,代码控制显示
        style="?android:attr/progressBarStyleHorizontal"  设置为水平进度条样式
        android:max="100"  设置进度条的最大值为100
        />
    <Button
        android:id="@+id/btn2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="显示"/>

</LinearLayout>

三、代码控制progressBar的显示和隐藏

public class MainActivity extends AppCompatActivity implements View.OnClickListener{
    private Button btn1,btn2;
    private ProgressBar progressBar1,progressBar2;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        btn1 = findViewById(R.id.btn1);
        btn2 = findViewById(R.id.btn2);
        progressBar1 = findViewById(R.id.progressBar1);
        btn1.setOnClickListener(this);
        progressBar2 = findViewById(R.id.progressBar2);
        btn2.setOnClickListener(this);

    }

    @Override
    public void onClick(View view) {
        switch (view.getId()){
            //显示圆形加载样式progressBar
            case R.id.btn1:
            	//判断ProgressBar当前是否可见,并且设置其是否可见
            	//View.VISIBLE是显示,View.INVISIBLE是隐藏但占位置,View.GONE是消失不占位置
                if (progressBar1.getVisibility()==View.GONE){
                    progressBar1.setVisibility(View.VISIBLE);
                }else {
                    progressBar1.setVisibility(View.GONE);
                }
                break;
            //显示进度条样式progressBar
            case R.id.btn2:
                progressBar2.setVisibility(View.VISIBLE);
                int progress = progressBar2.getProgress();//获取当前进度
                progress += 10;
                progressBar2.setProgress(progress); //重新设置进度
                if(progress > 100){
                    progressBar2.setVisibility(View.GONE);
                }
                break;
             default:
                 break;
        }

    }
}
要自定义半圆形进度条,我们可以通过继承ProgressBar类,并重写其中的一些方法来实现。 首先,我们需要创建一个自定义的ProgressBar类,并在构造方法中定义一些必要的属性,如进度条的颜色、进度值等。然后,我们可以通过重写onMeasure方法来测量进度条的大小,保证其为一个半圆形。接着,我们需要重写onDraw方法来绘制进度条样式。在这个方法中,我们可以利用Canvas和Paint来绘制一个半圆形的背景,并使用同样的方式绘制进度条的进度部分。 在绘制进度条的进度部分时,我们需要根据当前的进度值来确定进度的角度,并使用Path类的arcTo方法来绘制一个与进度值对应的扇形。同时,我们还可以调用Paint的setShader方法来设置进度条的渐变效果,使得进度从一种颜色平滑过渡到另一种颜色。 除了绘制进度条样式外,我们还可以根据需要为进度条添加一些动画效果。例如,我们可以使用ValueAnimator类来实现进度的平滑过渡,通过不断改变进度值并调用invalidate方法来触发重绘,从而实现进度条的动态效果。 最后,我们还可以根据需要为自定义的半圆形进度条添加一些其他功能,如进度文字显示、进度监听等。这些功能的实现方式与一般的ProgressBar类似,只需在自定义类中添加相应的方法即可。 通过以上的步骤,我们可以实现一个自定义的半圆形进度条,满足我们对进度条样式和功能的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冰冷的希望

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值