出现这种情况的原因可能是在UI线程中执行了耗时操作,导致进度条的可见性设置不起作用。为了解决这个问题,可以将耗时操作放在子线程中执行,并使用Handler来更新UI。
以下是一个示例代码,演示如何在子线程中执行耗时操作并更新进度条的可见性:
public class MainActivity extends AppCompatActivity {
private ProgressBar progressBar;
private Handler handler = new Handler();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
progressBar = findViewById(R.id.progressBar);
Button button = findViewById(R.id.button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 显示进度条
progressBar.setVisibility(View.VISIBLE);
// 在子线程中执行耗时操作
new Thread(new Runnable() {
@Override
public void run() {
// 模拟耗时操作
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// 更新UI,隐藏进度条
handler.post(new Runnable() {
@Override
public void run() {
progressBar.setVisibility(View.GONE);
}
});
}
}).start();
}
});
}
}
在上面的示例中,我们首先获取了一个ProgressBar的实例,并在点击Button时将其可见性设置为View.VISIBLE
。然后,在子线程中执行了一个模拟的耗时操作,通过Thread.sleep()
方法模拟了一个需要3秒钟的操作。最后,使用Handler
的post()
方法在UI线程中更新UI,将ProgressBar的可见性设置为View.GONE
,从而隐藏进度条。
通过将耗时操作放在子线程中执行,并使用Handler来更新UI,我们可以确保进度条的可见性设置正确地起作用。