iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Android如何模拟实现华为系统升级进度条
  • 145
分享到

Android如何模拟实现华为系统升级进度条

2023-06-28 06:06:49 145人浏览 八月长安
摘要

这篇文章主要为大家展示了“Android如何模拟实现华为系统升级进度条”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何模拟实现华为系统升级进度条”这篇文章吧。下面开始讲解虚线进度

这篇文章主要为大家展示了“Android如何模拟实现华为系统升级进度条”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何模拟实现华为系统升级进度条”这篇文章吧。

    下面开始讲解虚线进度条的实现方法,首先看一张图:

    Android如何模拟实现华为系统升级进度条

    实现步骤

    大家可以先想想这种进度条是怎么实现的?网上有各种各样的方法,也有人用path的lineTo()方法实现了类似的效果。但是我个人觉得canvas的drawArc方法也是个不错的选择,适合自己的才是最好的。

    canvas.drawArc(rectF, 0, process, false, mPaint);

    阅读了大量文章,最后发现改变paint的样式是最简单好用的方法。给paint设置一个effect就好了。

    1.用DashPathEffect给paint加上虚线效果

    DashPathEffect dashPathEffect = new DashPathEffect(new float[]{8, 6}, 0);mPaintBack.setPathEffect(dashPathEffect);

    build一下项目,看到的结果是这样的:

    Android如何模拟实现华为系统升级进度条

    能实现这个效果就大功告成了,如果看过我前面两篇文章的朋友们就知道,后面的步骤就简单了,加个进度条和动画效果就可以了。

    private void drawBack(Canvas canvas) {        RectF rectF = new RectF(strokeWidth, strokeWidth, getWidth() - strokeWidth, getHeight() - strokeWidth);        PathEffect effects = new DashPathEffect(new float[]{8, 6}, 0);        mPaintBack.setPathEffect(effects);        canvas.drawArc(rectF, 0, 360, false, mPaintBack);    }

    2.画出进度条 

    画进度条和画背景完全一样,只是画笔颜色和小点个数不一样。

    Android如何模拟实现华为系统升级进度条

    代码如下:

     private void drawProgress(Canvas canvas) {        RectF rectF = new RectF(strokeWidth, strokeWidth, getWidth() - strokeWidth, getHeight() - strokeWidth);        PathEffect effects = new DashPathEffect(new float[]{8, 6}, 0);        mPaint.setPathEffect(effects);        canvas.drawArc(rectF, 0, process, false, mPaint);    }

    3.绘制文字 

    接下来是绘制文字,实现文字居中的效果。思路是计算出圆心,调用canvas.drawText的方法就能在canvas上面绘制文字了。这里不需要更新进度文字,所以就更省事了。

    Android如何模拟实现华为系统升级进度条

    EMUI 下面的10.0.0也是一样的方法,只是给Y坐标加一下55,往下移一点就好。

        //绘制文字    private void drawText(Canvas canvas) {        int mTxtWidth = getTextWidth();        int mTxtHeight = getTextHeight();        int x = getWidth() / 2 - mTxtWidth / 2;        int y = getHeight() / 2 + mTxtHeight / 4;        canvas.drawText(getResources().getString(R.string.defaultTextEmui), x, y, mPaintText);    }     //绘制下方文字    private void drawTextBlow(Canvas canvas) {        int mTxtWidth = getTextWidthBlow();        int mTxtHeight = getTextHeight();        int x = getWidth() / 2 - mTxtWidth / 2;        int y = getHeight() / 2 + mTxtHeight / 4 + 55;        canvas.drawText(getResources().getString(R.string.defaultTextBelow), x, y, mPaintTextLevel);    }

    4.加入动画效果

          public void start() {        ValueAnimator valueAnimator = ValueAnimator.ofInt(0, 360);        valueAnimator.setDuration(duration);        valueAnimator.setInterpolator(new LinearInterpolator());        valueAnimator.addUpdateListener(animation -> {            process = (int) animation.getAnimatedValue();            invalidate();        });        valueAnimator.start();    }

    最终效果:

    Android如何模拟实现华为系统升级进度条

    完整代码

    package com.example.floatingwindow.widget; import android.animation.ValueAnimator;import android.content.Context;import android.graphics.Canvas;import android.graphics.DashPathEffect;import android.graphics.Paint;import android.graphics.PathEffect;import android.graphics.RectF;import android.util.AttributeSet;import android.util.TypedValue;import android.view.View;import android.view.animation.LinearInterpolator; import androidx.annotation.Nullable; import com.example.floatingwindow.R; public class DottedLineProgressBar extends View {     private Paint mPaint;    private Paint mPaintBack;    private Paint mPaintText;    private Paint mPaintTextLevel;    private int strokeWidth = 30;    private int textSize = 22;    private int textSizeBlow = 15;    private long duration = 3500;    private int process;     public DottedLineProgressBar(Context context) {        super(context);        init();    }     public DottedLineProgressBar(Context context, @Nullable AttributeSet attrs) {        super(context, attrs);        init();    }     public DottedLineProgressBar(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {        super(context, attrs, defStyleAttr);        init();    }     public void setStrokeWidth(int width) {        strokeWidth = width;    }     public void setTextSize(int textSize) {        this.textSize = textSize;    }     public void setDuration(long duration) {        this.duration = duration;    }     public void setTextSizeBlow(int textSizeBlow) {        this.textSizeBlow = textSizeBlow;    }     //初始化画笔    private void init() {        mPaintBack = new Paint();//圆角矩形        mPaintBack.setColor(getResources().getColor(R.color.gray));//圆角矩形颜色        mPaintBack.setAntiAlias(true);// 抗锯齿效果        mPaintBack.setStyle(Paint.Style.STROKE);//设置画笔样式        mPaintBack.setStrokeWidth(strokeWidth);//设置画笔宽度         mPaint = new Paint();        mPaint.setColor(getResources().getColor(R.color.blue));        mPaint.setAntiAlias(true);        mPaint.setStyle(Paint.Style.STROKE);        mPaint.setStrokeWidth(strokeWidth);         mPaintText = new Paint();        mPaintText.setAntiAlias(true);        mPaintText.setStyle(Paint.Style.FILL);        mPaintText.setColor(getResources().getColor(R.color.blue));        mPaintText.setTextSize(sp2px(textSize));         mPaintTextLevel = new Paint();        mPaintTextLevel.setAntiAlias(true);        mPaintTextLevel.setStyle(Paint.Style.FILL);        mPaintTextLevel.setColor(getResources().getColor(R.color.gray));        mPaintTextLevel.setTextSize(sp2px(textSizeBlow));    }     @Override    protected void onDraw(Canvas canvas) {        super.onDraw(canvas);        drawBack(canvas);        drawProgress(canvas);        drawText(canvas);        drawTextBlow(canvas);    }     private void drawBack(Canvas canvas) {        RectF rectF = new RectF(strokeWidth, strokeWidth, getWidth() - strokeWidth, getHeight() - strokeWidth);        PathEffect effects = new DashPathEffect(new float[]{8, 6}, 0);        mPaintBack.setPathEffect(effects);        canvas.drawArc(rectF, 0, 360, false, mPaintBack);    }     private void drawProgress(Canvas canvas) {        RectF rectF = new RectF(strokeWidth, strokeWidth, getWidth() - strokeWidth, getHeight() - strokeWidth);        PathEffect effects = new DashPathEffect(new float[]{8, 6}, 0);        mPaint.setPathEffect(effects);        canvas.drawArc(rectF, 0, process, false, mPaint);    }     //绘制文字    private void drawText(Canvas canvas) {        int mTxtWidth = getTextWidth();        int mTxtHeight = getTextHeight();        int x = getWidth() / 2 - mTxtWidth / 2;        int y = getHeight() / 2 + mTxtHeight / 4;        canvas.drawText(getResources().getString(R.string.defaultTextEmui), x, y, mPaintText);    }     //绘制下方文字    private void drawTextBlow(Canvas canvas) {        int mTxtWidth = getTextWidthBlow();        int mTxtHeight = getTextHeight();        int x = getWidth() / 2 - mTxtWidth / 2;        int y = getHeight() / 2 + mTxtHeight / 4 + 55;        canvas.drawText(getResources().getString(R.string.defaultTextBelow), x, y, mPaintTextLevel);    }     private int getTextWidth() {        String text = getResources().getString(R.string.defaultTextEmui);        return (int) mPaintText.measureText(text, 0, text.length());    }     private int getTextWidthBlow() {        String text = getResources().getString(R.string.defaultTextBelow);        return (int) mPaintTextLevel.measureText(text, 0, text.length());    }     private int getTextHeight() {        Paint.FontMetrics fm = mPaintText.getFontMetrics();        return (int) Math.ceil(fm.descent - fm.ascent);    }     private int sp2px(int sp) {        return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_SP, sp,                getResources().getDisplayMetrics());    }         public void start() {        ValueAnimator valueAnimator = ValueAnimator.ofInt(0, 360);        valueAnimator.setDuration(duration);        valueAnimator.setInterpolator(new LinearInterpolator());        valueAnimator.addUpdateListener(animation -> {            process = (int) animation.getAnimatedValue();            invalidate();        });        valueAnimator.start();    }}

    Kotlin调用:

    class MainActivity : AppCompatActivity() {    override fun onCreate(savedInstanceState: Bundle?) {        super.onCreate(savedInstanceState)         setContentView(R.layout.activity_main)         dottedLineProgressBar.post {            dottedLineProgressBar.start()        }    }}

    XML:

            <com.example.floatingwindow.widget.DottedLineProgressBar            android:id="@+id/dottedLineProgressBar"            android:layout_width="200dp"            android:layout_height="200dp"            android:layout_gravity="center">        </com.example.floatingwindow.widget.DottedLineProgressBar>

    以上是“Android如何模拟实现华为系统升级进度条”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

    --结束END--

    本文标题: Android如何模拟实现华为系统升级进度条

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

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

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

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

    下载Word文档
    猜你喜欢
    • Android模拟实现华为系统升级进度条
      目录前言实现步骤1.用DashPathEffect给paint加上虚线效果2.画出进度条 3.绘制文字 4.加入动画效果完整代码前言 之前用华为Android系统...
      99+
      2024-04-02
    • Android如何模拟实现华为系统升级进度条
      这篇文章主要为大家展示了“Android如何模拟实现华为系统升级进度条”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何模拟实现华为系统升级进度条”这篇文章吧。下面开始讲解虚线进度...
      99+
      2023-06-28
    • Android ProgressBar 模拟进度条效果的实现
      进度条的使用 圆形进度条 <ProgressBar android:id="@+id/pb" android:layout_...
      99+
      2024-04-02
    • win11系统在线升级进度条不动如何解决
      这篇文章主要讲解了“win11系统在线升级进度条不动如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“win11系统在线升级进度条不动如何解决”吧!方法一: 我们升级win11进度条不动...
      99+
      2023-07-01
    • Android如何实现pk进度条
      要实现Android上的PK进度条,可以使用ProgressBar控件来实现。以下是一个简单的示例:1. 在XML布局文件中添加Pr...
      99+
      2023-08-12
      Android
    • android如何实现圆形进度条
      要实现圆形进度条,可以使用Android的自定义控件来实现。首先,在layout文件中定义一个圆形进度条的布局,例如circle_p...
      99+
      2023-08-20
      android
    • Android Canva如何实现渐变进度条
      本篇内容介绍了“Android Canva如何实现渐变进度条”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言标题说渐变进度条是为...
      99+
      2023-07-02
    • Android如何实现带进度条的WebView
      这篇文章将为大家详细讲解有关Android如何实现带进度条的WebView,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Android 实现带进度条的WebView的实例1. WebView加载网页方法/...
      99+
      2023-05-30
      android webview
    • Android如何实现简单的加载进度条
      这篇文章将为大家详细讲解有关Android如何实现简单的加载进度条,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Android是什么Android是一种基于Linux内核的自由及开放源代码的操作系统,主要...
      99+
      2023-06-14
    • Java如何实现ATM机模拟系统
      这篇“Java如何实现ATM机模拟系统”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java如何实现ATM机模拟系统”文章吧...
      99+
      2023-07-02
    • 详解Android如何自定义view实现圆形进度条
      Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
      99+
      2024-04-02
    • Java如何动态模拟操作系统进程调度算法
      本篇内容主要讲解“Java如何动态模拟操作系统进程调度算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java如何动态模拟操作系统进程调度算法”吧!实验目的通过对进程调度算法的模拟,进一步理解...
      99+
      2023-06-21
    • 如何使用Android实现文件解压带进度条功能
      这篇文章给大家分享的是有关如何使用Android实现文件解压带进度条功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。解压的工具类package com.example.videodemo.zip;&n...
      99+
      2023-05-30
      android
    • Python如何实现模拟豆瓣登录系统
      这篇文章将为大家详细讲解有关Python如何实现模拟豆瓣登录系统,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。大家是不是经常做爬虫类的案例呀今天为大家介绍一个利用Python模拟豆瓣登录系统...
      99+
      2023-06-02
    • 如何在Android应用中利用节点实现一个进度条
      如何在Android应用中利用节点实现一个进度条?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。main.xml<RelativeLayout xmlns:a...
      99+
      2023-05-31
      android 节点 roi
    • Android如何自定义View实现横向的双水波纹进度条
      目录思路分析 功能实现 1.绘制圆角背景和圆角矩形边框 2.通过贝塞尔曲线实现双水波 3.设置动画使进度和水波纹变化 结语 网上垂直的水波纹进度条很多,但横向的很少,将垂直的水波纹改...
      99+
      2024-04-02
    • 如何实现LINUX系统2.4内核升级到2.6内核
      本篇内容介绍了“如何实现LINUX系统2.4内核升级到2.6内核”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一. 在升级前必须对以下的组件...
      99+
      2023-06-10
    • 如何在Python中使用Tqdm模块实现一个进度条功能
      本文章向大家介绍如何在Python中使用Tqdm模块实现一个进度条功能,主要包括如何在Python中使用Tqdm模块实现一个进度条功能的使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Pytho...
      99+
      2023-06-06
    • 如何在Android应用中利用ProgressBar实现一个直线进度条功能
      今天就跟大家聊聊有关如何在Android应用中利用ProgressBar实现一个直线进度条功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java代码:package com.ex...
      99+
      2023-05-31
      android progressbar gr
    • Android开发之如何实现ProgressBar字体随着进度条的加载而滚动
      这篇文章给大家分享的是有关Android开发之如何实现ProgressBar字体随着进度条的加载而滚动的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。先看下最终效果效果图我这里用的是LICEcap软件录制的gif图...
      99+
      2023-05-30
      progressbar android
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作