我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android自定义扇形倒计时实例代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android自定义扇形倒计时实例代码

一.概述

严格来说,我是Android小白,写的目的只是想作为知识储备而已….但是想到别人或许会不小心搜到我的这篇,如果我只是简单的描述,别人有可能看不懂,说不定还被吐槽,那岂不是很冤吗?

所以,我还是把问题及过程描述清楚,这也是对自己的一个交代,同时,这也是我的第一篇,我应该做好它;

先说一下需求: 最近工作中需要做一个倒计时,是那种一个圆,慢慢的被吃掉的动画倒计时,由于自己知识不是很足,只知道要用Canvas来画,在网上搜了一圈,发现要么是静态的画了一个扇形,要么是不能控制控件的位置大小….总之,找了一圈感觉学了不少Canvas的知识,但是由于自己也是Android小白,所以并不能从中总结出我想要的那种动画的扇形倒计时(这里说一下,因为我是第一次用这玩意,对一些编辑不熟,所以就不上效果图了,但是这里的代码非常简单,需要的朋友可以直接拿过去运行一下看看是否是你需要的效果);

最后我不得不请教我的一个朋友,现在他倒是也谈不上大神,但是比我厉害多了…..这里说白了我只是把他的逻辑更多的挪过来…好惭愧…因为我更多的只是想作为一个知识储备…

二.正文

刚才也说到用到Canvas,所以我们先来自定义一个控件,直接继承View的自定义控件;

SweepView.java:


public class SweepView extends View {
  private static final int DEFAULT_WIDTH = 100;
  private static final int DEFAULT_HEIGHT = 100;
  private int mWidth;   //这里并没卵用
  private int mHeight;  //这个也没卵用
  private RectF rectF;
  private Paint paint;
  private int mColor = Color.RED;//默认颜色为红色
  private float mSweep = 0;  //扇形角度
  public SweepView(Context context) {
    super(context);
    init();
  }
  public SweepView(Context context, AttributeSet attrs) {
    super(context, attrs);
    init();
  }
  public SweepView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    init();
  }
  private void init() {
    paint = new Paint();
    paint.setColor(mColor); //画笔颜色
    paint.setStyle(Paint.Style.FILL);  //填充
    paint.setAntiAlias(true);  //是否抗锯齿
  }
  
  public void setColor(int color) {
    this.mColor = color;
    paint.setColor(mColor);
    //调用onDraw重绘
    invalidate();
  }
  
  public void setSweep(float mSweep) {
    this.mSweep = mSweep;
    //调用onDraw重绘
    invalidate();
  }
  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    int resultWidth = measureWidth(widthMeasureSpec);
    int resultHeight = measureHeight(heightMeasureSpec);
    setMeasuredDimension(resultWidth, resultHeight);
  }
  
  private int measureWidth(int widthMeasureSpec) {
    int size = MeasureSpec.getSize(widthMeasureSpec);
    int mode = MeasureSpec.getMode(widthMeasureSpec);
    int result;
    if (mode == MeasureSpec.EXACTLY) {
      result = size;
    } else {
      result = DEFAULT_WIDTH;
      if (mode == MeasureSpec.AT_MOST) {
        result = Math.min(size, DEFAULT_WIDTH);
      }
    }
    return result;
  }
  
  private int measureHeight(int heightMeasureSpec) {
    int size = MeasureSpec.getSize(heightMeasureSpec);
    int mode = MeasureSpec.getMode(heightMeasureSpec);
    int result;
    if (mode == MeasureSpec.EXACTLY) {
      result = size;
    } else {
      result = DEFAULT_HEIGHT;
      if (mode == MeasureSpec.AT_MOST) {
        result = Math.min(size, DEFAULT_HEIGHT);
      }
    }
    return result;
  }
  @Override
  protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    this.mHeight = h;
    this.mWidth = w;
    rectF = new RectF(0, 0, w, h);
    super.onSizeChanged(w, h, oldw, oldh);
  }
  @Override
  protected void onDraw(Canvas canvas) {
    //画扇形
    canvas.drawArc(rectF, -90, mSweep, true, paint);
  }
}

写好自定义的View,显然我们要用它,所以布局文件中声明:(不过有一点要注意的是,如果想要控制它的位置及大小,这里要用ViewGroup来包裹,通过设置ViewGroup的位置及大小来控制它,至于为什么,我也很想知道0.0)

MainActivity.xml


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/activity_main"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.example.meijun.myapplication.MainActivity">
  <RelativeLayout
    android:layout_centerInParent="true"
    android:layout_width="20dp"
    android:background="#00f"
    android:layout_height="20dp">
    <com.example.meijun.myapplication.SweepView
      android:layout_width="wrap_content"
      android:id="@+id/sweepView"
      android:layout_height="wrap_content" />
  </RelativeLayout>
</RelativeLayout>

最后就是在代码里来绘制动画形态的,圆形扇形倒计时了:

MainActivity.java:


public class MainActivity extends AppCompatActivity {
  private SweepView sweepView;
  float angle = 0;//绘制的角度
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    sweepView = (SweepView) findViewById(R.id.sweepView);
    sweepView.setColor(Color.WHITE);  //设置画笔颜色
    sweepView.setSweep(0); //初始绘制0度
    new Thread(new Runnable() {
      @Override
      public void run() {
        while (angle <= 360) { //这里相当于绘制一个完整的圆,结合下面的3.6及50,也就是5秒钟的倒计时
          angle += 3.6;
          runOnUiThread(new Runnable() {
            @Override
            public void run() {
              sweepView.setSweep(angle);
            }
          });
          try {
            Thread.sleep(50);
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
        }
      }
    }).start();
  }
}

三.总结

在自定义view中,我有很多地方还不是很明白的,因为自己本身对自定义的一些方法认知是缺乏的,不过我想我以后会慢慢弄懂其中一些方法的含义;当然如果朋友你不小心能看到这篇文章,还望你能对我解惑,不胜感激.

您可能感兴趣的文章:android自定义倒计时控件示例Android自定义圆形倒计时进度条Android自定义照相机倒计时拍照Android 自定义闪屏页广告倒计时view效果Android自定义View获取注册验证码倒计时按钮Android 自定义View之倒计时实例代码Android自定义Chronometer实现短信验证码秒表倒计时功能Android自定义控件实现验证码倒计时Android自定义View倒计时圆Android使用属性动画如何自定义倒计时控件详解


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android自定义扇形倒计时实例代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android自定义扇形倒计时实例代码

一.概述 严格来说,我是Android小白,写的目的只是想作为知识储备而已….但是想到别人或许会不小心搜到我的这篇,如果我只是简单的描述,别人有可能看不懂,说不定还被吐槽,那岂不是很冤吗 所以,我还是把问题及过程描述清楚,这也是对自己的一个
2022-06-06

Android 自定义View之倒计时实例代码

Android 自定义View之倒计时实例代码 需求:大多数app在注册的时候,都有一个获取验证码的按钮,点击后,访问接口,最终用户会收到短信验证码。为了不多次写这个获取验证码的接口,下面将它自定义成一个view,方便使用。 分析一下,这是
2022-06-06

Android自定义View——扇形统计图的实现代码

Android 扇形统计图 先看看效果: 看上去如果觉得还行就继续往下看吧!自定义View 定义成员变量private int mHeight, mWidth;//宽高private Paint mPaint;//扇形的画笔private
2022-06-06

Android自定义圆形倒计时进度条

本文实例为大家分享了Android倒计时进度条展示的具体代码,供大家参考,具体内容如下 效果预览源代码传送门:https://github.com/yanzhenjie/CircleTextProgressbar 实现与原理 这个文字圆形的
2022-06-06

android自定义倒计时控件示例

自定义TextView控件TimeTextView代码:代码如下:import android.content.Context;import android.content.res.TypedArray;import android.gra
2022-06-06

Android自定义控件实现验证码倒计时

今天给大家带来一个新的控件——验证码倒计时,先看下效果图 1 效果演示2 使用方式
2022-06-06

Android自定义View倒计时圆

本文实例为大家分享了Android自定义View倒计时圆的具体代码,供大家参考,具体内容如下 创建attr
2023-05-30

Android自定义TimeButton实现倒计时按钮

项目需要要实现一个带有倒计时功能的按钮,其效果类似发送验证码之后在按钮上显示倒计时并且将按钮设置为不可用的功能。 为了项目中其他地方能够调用到,便重写了一个继承于Button的TimeButton来实现倒计时功能,并方便调用。 老规矩,上效
2022-06-06

android自定义短信倒计时view

android自定义短信倒计时view 倒计时实现有三种方式 而这个自定义view是通过handler实现的。为了保证activity销毁的同时倒计时线程依然进行同时重新创建销毁又不会导致内存泄漏,我使用了handler的弱引用将handl
2022-06-06

Android自定义popupwindow实例代码

先来看看效果图:一、布局 Android自定义popupwindow实例代码
2022-06-06

Android 实现自定义圆形进度条的实例代码

Android 自定义圆形进度条 今天无意中发现一个圆形进度,想想自己实现一个,如下图:基本思路是这样的: 1.首先绘制一个实心圆 2.绘制一个白色实心的正方形,遮住实心圆 3.在圆的中心动态绘制当前进度的百分比字符 4.绘制一个与之前实心
2022-06-06

Android中自定义ScrollView代码实例

Android中的ScrollView其实是很简陋的,竟然没有和ListView一样的可以设置一个OnScrollListener,不过没有关系,我们可以继承自ScrollView来自定义一个。废话不多说,直接上代码:代码如下: publi
2022-06-06

Android自定义照相机倒计时拍照

自定义拍照会用到SurfaceView控件显示照片的预览区域,以下是布局文件:两个TextView是用来显示提示信息和倒计时的秒数的相关教程:Android开发从相机或相册获取图片裁剪 Android启动相机拍照并返回图片
2022-06-06

Android 自定义View 密码框实例代码

暴露您view中所有影响可见外观的属性或者行为。通过XML添加和设置样式通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器详细步骤见:Android 自定义View步骤效果图展示:支持的样式可以通过XML定义影响外边和行为的属
2022-06-06

Android如何实现一个倒计时自定义控件

这篇“Android如何实现一个倒计时自定义控件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android如何实现一个倒计
2023-06-29

Android 自定义状态栏实例代码

一、目标:Android5.0以上 二、步骤 1、在res-values-colors.xml下新建一个RGB颜色 2022-06-06

Android自定义Chronometer实现短信验证码秒表倒计时功能

本文实例为大家分享了Chronometer实现倒计时功能,Android提供了实现按照秒计时的API,供大家参考,具体内容如下 一、自定义ChronometerView 继续自TextView主要原理:先设置一个基准倒计时时间mBaseSe
2022-06-06

android实现倒计时功能代码

效果图,每隔1秒,变换一下时间 xml: 代码如下: 2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录