随笔 - 1357  文章 - 0  评论 - 1104  阅读 - 1941万

Android控件之ProgressBar探究

    ProgressBar位于android.widget包下,其继承于View,主要用于显示一些操作的进度。应用程序可以修改其长度表示当前后台操作的完成情况。因为进度条会移动,所以长时间加载某些资源或者执行某些耗时的操作时,不会使用户界面失去响应。ProgressBar类的使用非常简单,只需将其显示到前台,然后启动一个后台线程定时更改表示进度的数值即可。

以下ProgressBar跟Handle结合,模拟进度条的使用,当进度条完成时会跳转到TestActivity

main.xml布局文件

复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation
="vertical"
android:layout_width
="fill_parent"
android:layout_height
="fill_parent">
<!-- 长方形进度条,一开始不可见,直到点击按钮时才出现进度条 -->
<ProgressBar android:id="@+id/progressBar"
style
="?android:attr/progressBarStyleHorizontal"
mce_style
="?android:attr/progressBarStyleHorizontal"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"
android:visibility
="gone"
android:max
="100" />
<!-- 圆形进度条 -->
<!--<ProgressBar android:id="@+id/progressBar"
style
="?android:attr/progressBarStyleLarge"
mce_style
="?android:attr/progressBarStyleLarge"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content" />-->
<Button android:id="@+id/start"
android:text
="启动进度条"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content" />
<Button android:id="@+id/stop"
android:text
="停止进度条"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content" />
</LinearLayout>
复制代码

PbActivity类

复制代码
package com.ljq.pb;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.view.View;
import android.widget.Button;
import android.widget.ProgressBar;

public class PbActivity extends Activity {
private ProgressBar progressBar = null;
private Button start = null, stop = null;
// 定义Handler对象
private Handler handler = new Handler();


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

progressBar
= (ProgressBar) findViewById(R.id.progressBar);
progressBar.setProgress(
0);

start
= (Button) findViewById(R.id.start);
start.setOnClickListener(
new View.OnClickListener() {

public void onClick(View v) {
handler.post(runnable);
//开始执行
}

});
stop
=(Button)findViewById(R.id.stop);
stop.setOnClickListener(
new View.OnClickListener() {

public void onClick(View v) {
handler.removeCallbacks(runnable);
//停止执行
progressBar.setProgress(0);
}

});
}

int pro=0;
Runnable runnable
=new Runnable(){
public void run() {
progressBar.setVisibility(View.VISIBLE);
pro
=progressBar.getProgress()+10;
progressBar.setProgress(pro);
//如果进度小于100,,则延迟1000毫秒后重复执行runnable
if(pro<100){
handler.postDelayed(runnable,
1000);
}
else{
progressBar.setVisibility(View.GONE);
startActivity(
new Intent(PbActivity.this, TestActivity.class));
handler.removeCallbacks(runnable);
progressBar.setProgress(
0);
}
}
};
}
复制代码

运行结果

  

posted on   Ruthless  阅读(8326)  评论(1编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
< 2011年2月 >
30 31 1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 1 2 3 4 5
6 7 8 9 10 11 12

点击右上角即可分享
微信分享提示