布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@android:color/background_light"
android:layout_gravity="center"
android:orientation="vertical" >
<com.czf.CircleMenu.bean.TextProgressBar
android:id="@+id/pgsBar"
android:max="100"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
style="?android:attr/progressBarStyleHorizontal"
android:visibility="visible"
/>
</LinearLayout>
自定义进度条:
package com.czf.CircleMenu.bean;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.widget.ProgressBar;
public class TextProgressBar extends ProgressBar {
private String text;
private Paint mPaint;
public TextProgressBar(Context context) {
super(context);
initText();
}
public TextProgressBar(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
initText();
}
public TextProgressBar(Context context, AttributeSet attrs) {
super(context, attrs);
initText();
}
@Override
public void setProgress(int progress) {
setText(progress);
super.setProgress(progress);
}
@Override
protected synchronized void onDraw(Canvas canvas) {
super.onDraw(canvas);
Rect rect = new Rect();
this.mPaint.getTextBounds(this.text, 0, this.text.length(), rect);
int x = (getWidth() / 2) - rect.centerX();
int y = (getHeight() / 2) - rect.centerY();
canvas.drawText(this.text, x, y, this.mPaint);
}
// 初始化,画笔
private void initText() {
this.mPaint = new Paint();
this.mPaint.setAntiAlias(true);
this.mPaint.setColor(Color.WHITE);
}
// 设置文字内容
private void setText(int progress) {
int i = (int) ((progress * 1.0f / this.getMax()) * 100);
this.text = String.valueOf(i) + "%";
}
}
源码地址:http://download.csdn.net/detail/fei900724/8707029