iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Android编程使用自定义View实现水波进度效果示例
  • 344
分享到

Android编程使用自定义View实现水波进度效果示例

android自定义view 2023-05-31 14:05:49 344人浏览 薄情痞子
摘要

本文实例讲述了Android编程使用自定义View实现水波进度效果。分享给大家供大家参考,具体如下:首先上效果图:简介:自动适应屏幕大小;2.水波自动横向滚动;3.各种绘制参数可通过修改常量进行控制。代码不多,注释也比较详细,全部贴上:(一

本文实例讲述了Android编程使用自定义View实现水波进度效果。分享给大家供大家参考,具体如下:

首先上效果图:

Android编程使用自定义View实现水波进度效果示例

简介:

自动适应屏幕大小;
2.水波自动横向滚动;
3.各种绘制参数可通过修改常量进行控制。

代码不多,注释也比较详细,全部贴上:

(一)自定义组件:

public class WaterWaveView extends View {  //边框宽度  private int STROKE_WIDTH;  //组件的宽,高  private int width, height;    private float max, progress;    private Paint progressPaint;  //波纹振幅与半径之比。(建议设置:<0.1)  private static final float A = 0.05f;  //绘制文字的画笔  private Paint textPaint;  //绘制边框的画笔  private Paint circlePaint;    private int centerX, centerY;  //内圆所在的矩形  private RectF circleRectF;  public WaterWaveView(Context context) {    super(context);    init();  }  public WaterWaveView(Context context, AttributeSet attrs) {    super(context, attrs);    init();  }  public WaterWaveView(Context context, AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);    init();  }  //初始化  private void init() {    progressPaint = new Paint();    progressPaint.setColor(Color.parseColor("#77cccc88"));    progressPaint.setAntiAlias(true);    textPaint = new Paint();    textPaint.setColor(Color.WHITE);    textPaint.setAntiAlias(true);    circlePaint = new Paint();    circlePaint.setStyle(Paint.Style.STROKE);    circlePaint.setAntiAlias(true);    circlePaint.setColor(Color.parseColor("#33333333"));    autoRefresh();  }  @Override  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {    super.onMeasure(widthMeasureSpec, heightMeasureSpec);    if (width == 0 || height == 0) {      width = getWidth();      height = getHeight();      //计算圆弧半径和圆心点      int circleRadius = Math.min(width, height) >> 1;      STROKE_WIDTH = circleRadius / 10;      circlePaint.setStrokeWidth(STROKE_WIDTH);      centerX = width / 2;      centerY = height / 2;      VALID_RADIUS = circleRadius - STROKE_WIDTH;      RADIANS_PER_X = (float) (Math.PI / VALID_RADIUS);      circleRectF = new RectF(centerX - VALID_RADIUS, centerY - VALID_RADIUS,          centerX + VALID_RADIUS, centerY + VALID_RADIUS);    }  }  private Rect textBounds = new Rect();  //x方向偏移量  private int xOffset;  @Override  protected void onDraw(canvas canvas) {    super.onDraw(canvas);    //绘制圆形边框    canvas.drawCircle(centerX, centerY, VALID_RADIUS + (STROKE_WIDTH >> 1), circlePaint);    //绘制水波曲线    canvas.drawPath(getWavePath(xOffset), progressPaint);    //绘制文字    textPaint.setTextSize(VALID_RADIUS >> 1);    String text1 = String.valueOf(progress);    //测量文字长度    float w1 = textPaint.measureText(text1);    //测量文字高度    textPaint.getTextBounds("8", 0, 1, textBounds);    float h2 = textBounds.height();    float extraW = textPaint.measureText("8") / 3;    canvas.drawText(text1, centerX - w1 / 2 - extraW, centerY + h2 / 2, textPaint);    textPaint.setTextSize(VALID_RADIUS / 6);    textPaint.getTextBounds("M", 0, 1, textBounds);    float h3 = textBounds.height();    canvas.drawText("M", centerX + w1 / 2 - extraW + 5, centerY - (h2 / 2 - h3), textPaint);    String text3 = "共" + String.valueOf(max) + "M";    float w3 = textPaint.measureText(text3, 0, text3.length());    textPaint.getTextBounds("M", 0, 1, textBounds);    float h4 = textBounds.height();    canvas.drawText(text3, centerX - w3 / 2, centerY + (VALID_RADIUS >> 1) + h4 / 2, textPaint);    String text4 = "流量剩余";    float w4 = textPaint.measureText(text4, 0, text4.length());    textPaint.getTextBounds(text4, 0, text4.length(), textBounds);    float h5 = textBounds.height();    canvas.drawText(text4, centerX - w4 / 2, centerY - (VALID_RADIUS >> 1) + h5 / 2, textPaint);  }  //绘制水波的路径  private Path wavePath;  //每一个像素对应的弧度数  private float RADIANS_PER_X;  //去除边框后的半径(即内圆半径)  private int VALID_RADIUS;    private Path getWavePath(int xOffset) {    if (wavePath == null) {      wavePath = new Path();    } else {      wavePath.reset();    }    float[] startPoint = new float[2]; //波浪线起点    float[] endPoint = new float[2]; //波浪线终点    for (int i = 0; i <= VALID_RADIUS * 2; i += 2) {      float x = centerX - VALID_RADIUS + i;      float y = (float) (centerY + VALID_RADIUS * (1.0f + A) * 2 * (0.5f - progress / max)          + VALID_RADIUS * A * Math.sin((xOffset + i) * RADIANS_PER_X));      //只计算内圆内部的点,边框上的忽略      if (calDistance(x, y, centerX, centerY) > VALID_RADIUS) {        if (x < centerX) {          continue; //左边框,继续循环        } else {          break; //右边框,结束循环        }      }      //第1个点      if (wavePath.isEmpty()) {        startPoint[0] = x;        startPoint[1] = y;        wavePath.moveTo(x, y);      } else {        wavePath.lineTo(x, y);      }      endPoint[0] = x;      endPoint[1] = y;    }    if (wavePath.isEmpty()) {      if (progress / max >= 0.5f) {        //满格        wavePath.moveTo(centerX, centerY - VALID_RADIUS);        wavePath.addCircle(centerX, centerY, VALID_RADIUS, Path.Direction.CW);      } else {        //空格        return wavePath;      }    } else {      //添加圆弧部分      float startDegree = calDegreeByPosition(startPoint[0], startPoint[1]); //0~180      float endDegree = calDegreeByPosition(endPoint[0], endPoint[1]); //180~360      wavePath.arcTo(circleRectF, endDegree - 360, startDegree - (endDegree - 360));    }    return wavePath;  }  private float calDistance(float x1, float y1, float x2, float y2) {    return (float) Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));  }  //根据当前位置,计算出进度条已经转过的角度。  private float calDegreeByPosition(float currentX, float currentY) {    float a1 = (float) (Math.atan(1.0f * (centerX - currentX) / (currentY - centerY)) / Math.PI * 180);    if (currentY < centerY) {      a1 += 180;    } else if (currentY > centerY && currentX > centerX) {      a1 += 360;    }    return a1 + 90;  }  public void setMax(int max) {    this.max = max;    invalidate();  }  //直接设置进度值(同步)  public void setProgressSync(float progress) {    this.progress = progress;    invalidate();  }    private void autoRefresh() {    new Thread(new Runnable() {      @Override      public void run() {        while (!detached) {          xOffset += (VALID_RADIUS >> 4);          SystemClock.sleep(100);          postInvalidate();        }      }    }).start();  }  //标记View是否已经销毁  private boolean detached = false;  @Override  protected void onDetachedFromWindow() {    super.onDetachedFromWindow();    detached = true;  }}

--结束END--

本文标题: Android编程使用自定义View实现水波进度效果示例

本文链接: https://www.lsjlt.com/news/226148.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • Android编程使用自定义View实现水波进度效果示例
    本文实例讲述了Android编程使用自定义View实现水波进度效果。分享给大家供大家参考,具体如下:首先上效果图:简介:自动适应屏幕大小;2.水波自动横向滚动;3.各种绘制参数可通过修改常量进行控制。代码不多,注释也比较详细,全部贴上:(一...
    99+
    2023-05-31
    android 自定义 view
  • Android自定义View实现水波纹效果
    介绍:水波纹散开效果的控件在 App 里面还是比较常见的,例如 网易云音乐歌曲识别,附近搜索场景。看下实现的效果:实现思路: 先将最大圆半径与最小圆半径间距分成几等份,从内到外,Paint 透明度依次递减,绘制出同心圆,然后不断的改变这些同...
    99+
    2023-05-30
    android view 水波纹
  • Android自定义View实现水波纹扩散效果
    目录1、创建RippleView.class, 继承与View1.1特殊属性解释 1.2新建attrs.xml文件(res/values)1.3初始化画笔2、开始绘制onD...
    99+
    2024-04-02
  • Android 自定义view实现水波纹动画效果
    在实际的开发中,很多时候还会遇到相对比较复杂的需求,比如产品妹纸或UI妹纸在哪看了个让人兴奋的效果,兴致高昂的来找你,看了之后目的很明确,当然就是希望你能给她;在这样的关键时候,身子板就一定得硬了,可千万别说不行,爷们儿怎么能说不行呢;好了...
    99+
    2023-05-31
    android 水波纹 roi
  • Android 通过自定义view实现水波纹效果案例详解
    在实际的开发中,很多时候还会遇到相对比较复杂的需求,比如产品妹纸或UI妹纸在哪看了个让人兴奋的效果,兴致高昂的来找你,看了之后目的很明确,当然就是希望你能给她; 在这样的关键时候,身...
    99+
    2024-04-02
  • Android自定义view实现圆环进度条效果
    本文实例为大家分享了Android自定义view实现圆环进度条效果的具体代码,供大家参考,具体内容如下 一、实现效果图 二、核心代码 自定义view的属性 <xml vers...
    99+
    2024-04-02
  • Android自定义view实现圆形进度条效果
    Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
    99+
    2024-04-02
  • Android如何自定义View实现横向的双水波纹进度条
    目录思路分析 功能实现 1.绘制圆角背景和圆角矩形边框 2.通过贝塞尔曲线实现双水波 3.设置动画使进度和水波纹变化 结语 网上垂直的水波纹进度条很多,但横向的很少,将垂直的水波纹改...
    99+
    2024-04-02
  • Android怎么自定义View实现横向的双水波纹进度条
    这篇文章将为大家详细讲解有关Android怎么自定义View实现横向的双水波纹进度条,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。思路分析整体效果可分为三个,绘制圆角背景和圆角矩形,绘制第一条和第二条水波...
    99+
    2023-06-25
  • Android怎么自定义View实现圆弧进度效果
    这篇文章主要介绍“Android怎么自定义View实现圆弧进度效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么自定义View实现圆弧进度效果”文章能帮助大家解决问题。技术实现Ar...
    99+
    2023-07-06
  • Android中怎么自定义view实现圆环进度条效果
    这篇文章主要讲解了“Android中怎么自定义view实现圆环进度条效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android中怎么自定义view实现圆环进度条效果”吧!核心代码自定义...
    99+
    2023-06-29
  • Android自定义View实现圆弧进度效果逐步完成过程
    目录技术实现1.继承自View2.Paint初始化3.Canvas绘制4.添加动画效果及数据涉及到的知识Canvas(画布),Paint(画笔),自定义控件等有三种:一个是直接从Vi...
    99+
    2023-05-16
    Android自定义View圆弧进度 Android实现圆弧进度 Android自定义View
  • Android自定义View实现扫描效果
    本文实例为大家分享了Android自定义View实现扫描效果的具体代码,供大家参考,具体内容如下 演示效果如下: 实现内容: 1、控制动画是竖向或者横向 2、控制动画初始是从底部/...
    99+
    2024-04-02
  • Android自定义View实现时钟效果
    本文实例为大家分享了Android自定义View实现时钟效果的具体代码,供大家参考,具体内容如下 自定义时钟 初学自定义View,先画一个不太成熟的时钟(甚至只有秒针) 时钟效果 ...
    99+
    2024-04-02
  • Python编程使用PyQt5库实现动态水波进度条示例
    目录原理介绍代码实操最近做了一个小项目,里面有一个需求需要添加一个动态进度条,进度条的样式就类似于水波来回起伏的那种形状,下面就是最初的展示效果(有一点区别,这里我加了一个进度自动增...
    99+
    2024-04-02
  • Android利用Paint自定义View实现进度条控件方法示例
    前言View的三大流程:测量,布局,绘制,自定义View学的是啥?无非就两种:绘制文字和绘制图像。我们在上一篇文章《Android绘图之Paint的使用》中学习了Paint的基本用法,但是具体的应用我们还没有实践过。从标题中可知,本文是带领...
    99+
    2023-05-30
    paint 自定义view 进度条控件
  • Android自定义View实现圆形进度条
    本文实例为大家分享了Android自定义View实现圆形进度条的具体代码,供大家参考,具体内容如下 原理非常简单,在自定义View的基础上使用Canvas的drawCircle画两个...
    99+
    2024-04-02
  • Android自定义View实现圆形加载进度条效果的方法
    这篇文章将为大家详细讲解有关Android自定义View实现圆形加载进度条效果的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。View仿华为圆形加载进度条效果图实现思路可以看出该View可分为三个部分...
    99+
    2023-05-30
    android view 进度条
  • Android中怎么通过自定义view实现进度条加载效果
    Android中怎么通过自定义view实现进度条加载效果,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。分析图:代码如下:package com.example.d...
    99+
    2023-05-30
    android view
  • Android自定义View实现标签流效果
    本文实例为大家分享了Android自定义View实现标签流效果的具体代码,供大家参考,具体内容如下 一、概述 Android自定义View实现标签流效果,一行放不下时会自动换行,用户...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作