ProgressBar控件入门

2024-05-31 16:18
文章标签 入门 控件 progressbar

本文主要是介绍ProgressBar控件入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        ProgressBar进度条在实际开发中,很是常用,任何耗时操作都会使用进度条来告诉用户,这里会话费一点时间,请耐心等待。

废话不多说,直接上代码。


效果图:



项目下载链接:

       ProgressBar自定义进度圈下载


代码:


1、新建一个普通的java类CircleProgressBar,代码如下:

package com.test.progressbartest;import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;public class CircleProgressBar extends View {private Paint mBackPaint;private Paint mFrontPaint;private Paint mTextPaint;private float mStrokeWidth = 50;private float mHalfStrokeWidth = mStrokeWidth / 2;private float mRadius = 200;// 半径private RectF mRect;//加载的初始值private int mProgress = 0;// 加载的目标值private int mTargetProgress = 88;//最大值private int mMax = 100;private int mWidth;// 宽private int mHeight;// 高// 下面这三个重构方法必须要有,否则报错public CircleProgressBar(Context context) {super(context);init();}public CircleProgressBar(Context context, AttributeSet attrs, int defStyle) {super(context, attrs, defStyle);// TODO Auto-generated constructor stubinit();}public CircleProgressBar(Context context, AttributeSet attrs) {super(context, attrs);// TODO Auto-generated constructor stubinit();// 程序先进入这里}/*** 在Android中需要通过graphics类来显示2D图形。* graphics中包括了Canvas(画布)、Paint(画笔)、Color(颜色)、Bitmap(图像)等常用的类。* graphics具有绘制点、线、颜色、2D几何图形、图像处理等功能。*/private void init() {// TODO Auto-generated method stub//进度圈的背景色,执行完第一次onDraw()方法后,这个蓝色的背景进度圈就已经画好了mBackPaint = new Paint();// 新建一个画笔mBackPaint.setColor(Color.BLUE); // 设置画笔的颜色为蓝色mBackPaint.setAntiAlias(true);// 设置画笔锯齿效果:图像边缘相对清晰一点,锯齿痕迹不那么明显mBackPaint.setStyle(Paint.Style.STROKE); // 设置画笔的风格(空心)mBackPaint.setStrokeWidth(mStrokeWidth);// 设置空心边框的宽度//加载的进度圈,每执行一次onDraw()方法,画一个新的红色的进度圈mFrontPaint = new Paint();// 新建一个画笔mFrontPaint.setColor(Color.RED);// 设置画笔的颜色为红色mFrontPaint.setAntiAlias(true);// 设置画笔锯齿效果:图像边缘相对清晰一点,锯齿痕迹不那么明显mFrontPaint.setStyle(Paint.Style.STROKE); // 设置画笔的风格(空心)mFrontPaint.setStrokeWidth(mStrokeWidth);// 设置空心边框的宽度// 画中间的数字,每执行一次onDraw()方法,重新画一次数字mTextPaint = new Paint();// 新建一个画笔mTextPaint.setColor(Color.GREEN);// 设置画笔的颜色为绿色mTextPaint.setAntiAlias(true);// 设置画笔锯齿效果:图像边缘相对清晰一点,锯齿痕迹不那么明显mTextPaint.setTextSize(80);// 设置字体的尺寸mTextPaint.setTextAlign(Paint.Align.CENTER);// 文本对齐方式}/*** measure(计算)自定义,View在屏幕上绘制出来先要经过measure(计算)和layout(布局). * 问:什么时候调用onMeasure方法?* 答:当子View的父控件要放置该View的时候* ,父控件会传递两个参数给View——widthMeasureSpec和heightMeasureSpec。* 这两个参数是View可以获取的宽高尺寸和模式 混合的int数据。* 可以通过int mode=MeasureSpec.getMode(widthMeasureSpec)得到模式,* 通过int size=MeasureSpec.getSize(widthMeasureSpec)得到尺寸。*/@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {// TODO Auto-generated method stub// 运行完init(),程序进入这里,一共进入两次super.onMeasure(widthMeasureSpec, heightMeasureSpec);mWidth = getRealSize(widthMeasureSpec);mHeight = getRealSize(heightMeasureSpec);setMeasuredDimension(mWidth, mHeight);// 设置当前View的大小}/*** onDraw是在View初化完成之后开始调用*/@Overrideprotected void onDraw(Canvas canvas) {// Canvas(画布)类// TODO Auto-generated method stubinitRect();//执行两次onMeasure()方法后,进入这里float angle = mProgress / (float) mMax * 360;canvas.drawCircle(mWidth / 2, mHeight / 2, mRadius, mBackPaint);// 绘制圆形canvas.drawArc(mRect, -90, angle, false, mFrontPaint);// 绘制圆弧canvas.drawText(mProgress + "%", mWidth / 2 + mHalfStrokeWidth, mHeight/ 2 + mHalfStrokeWidth, mTextPaint);// 绘制字符if (mProgress < mTargetProgress) {mProgress += 1;// 每次递增一invalidate();// 重绘,就是重新调用onDraw方法}}/*** 获得尺寸*/public int getRealSize(int measureSpec) {int result = 1;int mode = MeasureSpec.getMode(measureSpec);// 得到模式int size = MeasureSpec.getSize(measureSpec);// 得到尺寸if (mode == MeasureSpec.AT_MOST || mode == MeasureSpec.UNSPECIFIED) {// 自己计算result = (int) (mRadius * 2 + mStrokeWidth);} else {result = size;}return result;}/*** 画一个矩形 Rect是使用int类型作为数值,RectF是使用float类型作为数值*/private void initRect() {if (mRect == null) {mRect = new RectF();// 新建一个矩形坐标,int viewSize = (int) (mRadius * 2);// 半径*2=直径int left = (mWidth - viewSize) / 2;// 左边的坐标int top = (mHeight - viewSize) / 2;// 上面的坐标int right = left + viewSize;// 右边的坐标int bottom = top + viewSize;// 下面的坐标mRect.set(left, top, right, bottom);// 设置这个矩形的上、下、左、右}}
}

2、在layout下面新建activity_main.xml文件,代码如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><!-- 加载自定义的View --><com.test.progressbartest.CircleProgressBarandroid:layout_width="match_parent"android:layout_height="match_parent" /></LinearLayout>

3、在MainActivity.java中代码如下:

package com.test.progressbartest;import android.app.Activity;
import android.app.ActionBar;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}}











这篇关于ProgressBar控件入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1018421

相关文章

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

WinForms中主要控件的详细使用教程

《WinForms中主要控件的详细使用教程》WinForms(WindowsForms)是Microsoft提供的用于构建Windows桌面应用程序的框架,它提供了丰富的控件集合,可以满足各种UI设计... 目录一、基础控件1. Button (按钮)2. Label (标签)3. TextBox (文本框

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否