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

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显