Android 仿信号格子强度动画效果实现

news2024/9/19 10:33:54

效果图
信号强度动画

在 Android 中,如果你想要绘制一个圆角矩形并使其居中显示,你可以使用 Canvas 类 drawRoundRect
方法。要使圆角矩形居中,你需要计算矩形的位置,这通常涉及到确定矩形左上角的位置(x, y),这样矩形就可以在其容器中水平和垂直居中。

以下是一个基本的步骤指南:

确定容器的尺寸:首先,你需要知道绘制圆角矩形的容器的宽度和高度。这通常是视图的宽度和高度。
计算圆角矩形的尺寸:确定你想要绘制的圆角矩形的宽度和高度。
计算圆角矩形的位置:为了居中矩形,你需要计算其左上角的 x 和 y坐标。这可以通过从容器宽度和高度中减去矩形宽度和高度,然后除以 2 来实现。例如,x = (containerWidth - rectWidth) / 2 和 y = (containerHeight - rectHeight) / 2。
绘制圆角矩形:使用 Canvas 的 drawRoundRect 方法,传递计算出的 x、y 坐标,矩形的宽度和高度,以及圆角的半径。

View源码

package com.android.circlescalebar.view;

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;
import androidx.annotation.Nullable;

public class SignalGridView extends View {
    private Paint mPaint = new Paint();
    private int mStrength;

    public SignalGridView(Context context) {
        super(context);
    }

    public SignalGridView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public SignalGridView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);

        mPaint.setColor(Color.GRAY); // 设置文字颜色
        mPaint.setTextSize(40); // 设置文字大小
        mPaint.setAntiAlias(true); // 设置抗锯齿
        String text = "信号"; // 要绘制的文字
        float x = 20; // 文字开始的 x 坐标
        float y = 55; // 文字开始的 y 坐标
        canvas.drawText(text, x, y, mPaint); // 在指定位置绘制文

        // 绘制 5 个带弧度的矩形
        float left = 110;
        float top = 22;
        float right = 120;
        float bottom = 60;
        float radius = 5; // 圆角半径

        for (int i = 0; i < 5; i++) {
            RectF rect = new RectF(left, top, right, bottom);
            mPaint.setColor(mStrength <= i ? Color.GRAY : Color.GREEN); // 设置画笔颜色
            canvas.drawRoundRect(rect, radius, radius, mPaint);
            left += 23; // 调整下一个矩形的位置
            right += 23;
        }
    }

    public void updateSignalStrength(int strength) {
        // Invalidate the view to trigger a redraw
        mStrength = strength;
        invalidate();
    }
}

调用实现

    private Handler handler = new Handler();  
    private Runnable runnable;  
    private SignalGridView signalGridView;

    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        //..

        signalGridView = findViewById(R.id.signalGridView);

        runnable = new Runnable() {  
                private Random random = new Random();  
    
                @Override  
                public void run() {  
                    int randomNumber = random.nextInt(5); // 生成0到4之间的随机数  
                    signalGridView.updateSignalStrength(randomNumber);
                    handler.postDelayed(this, 200); // 每200毫秒执行一次  
                }  
            };  
    
        handler.post(runnable); // 开始执行   

    }
   

    @Override  
    protected void onDestroy() {  
        super.onDestroy();  
        handler.removeCallbacks(runnable); // 停止执行  
    }  

布局

    <com.android.circlescalebar.view.SignalGridView
        android:id="@+id/signalGridView"
        android:layout_width="85dp"
        android:layout_height="35dp"/>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1465162.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【kubernetes】二进制部署k8s集群之cni网络插件flannel和calico工作原理(中)

↑↑↑↑接上一篇继续部署↑↑↑↑ 目录 一、k8s集群的三种接口 二、k8s的三种网络模式 1、pod内容器之间的通信 2、同一个node节点中pod之间通信 3、不同的node节点的pod之间通信 Overlay Network VXLAN 三、flannel网络插件 1、flannel插件模式之UDP模式&#xff0…

计算机视觉学习指南(划分为20个大类)

计算机视觉的知识领域广泛而庞杂&#xff0c;涵盖了众多重要的方向和技术。为了更好地组织这些知识&#xff0c;我们需要遵循无交叉无重复&#xff08;Mutually Exclusive Collectively Exhaustive&#xff0c;MECE&#xff09;的原则&#xff0c;并采用循序渐进的方式进行分类…

数据库增删改查

DDL: 数据定义语言&#xff0c;用来定义数据库对象&#xff08;数据库、表、字段&#xff09;DML: 数据操作语言&#xff0c;用来对数据库表中的数据进行增删改DQL: 数据查询语言&#xff0c;用来查询数据库中表的记录DCL: 数据控制语言&#xff0c;用来创建数据库用户、控制数…

智能运维服务指的是哪些?智能运维阶段有哪些

智能运维服务通常包含哪些关键组成部分&#xff1f;它们在IT管理中的作用和重要性&#xff1f;智能运维的发展可以分为哪些主要阶段&#xff1f;每个阶段的核心技术或实践有哪些&#xff0c;它们是如何推动运维工作向更高水平的自动化和智能化发展的&#xff1f; 智能运维服务…

8.CSS层叠继承规则总结

CSS 层叠继承规则总结 经典真题 请简述一下 CSS 中的层叠规则 CSS 中的层叠继承规则 在前面《CSS属性的计算过程》中&#xff0c;我们介绍了每一个元素都有都有所有的属性&#xff0c;每一个属性都会通过一系列的计算过程得到最终的值。 这里来回顾一下计算过程&#xff0…

K8S—Pod详解

目录 一 Pod基础概念 1.1 Pod是什么 1.2 为什么要使用Pod&#xff1f;Pod在K8S集群中的使用方式&#xff1f; 1.3 基础容器pause 二 Pod的分类 2.1 自主式Pod和控制器管理的Pod 2.2 容器的分类 2.2.1 基础容器&#xff08;infrastructure container&#xff09; 2.2.2…

【Linux】Vagrant搭建Linux环境

Vagrant Vagrant是一个基于Ruby的工具&#xff0c;用于创建和部署虚拟化开发环境。它使用Oracle的开源VirtualBox虚拟化系统&#xff0c;使用 Chef创建自动化虚拟环境。 安装Vagrant 从Vagrant官网下载安装包&#xff0c;执行安装。 安装VirtualBox 从官网下载VirtualBo…

企业品牌软文发布在媒体上,有啥用呢

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 通常企业都会建立自己的媒体矩阵&#xff0c;在公众号&#xff0c;视频号&#xff0c;抖音&#xff0c;网易号&#xff0c;搜狐号等企业品牌矩阵中发布软文&#xff0c;公司动态&#xf…

智慧城市|SHARE 孪影F2 PRO 在数字化城市平台中的应用。

在数字化时代背景下&#xff0c;乌审旗政府积极响应实景三维中国建设工作&#xff0c;以数字乌审作为全旗智慧城市总框架、总平台&#xff0c;致力提升城市治理现代化水平&#xff0c;结合互联网、云计算、人工智能等信息技术建设新型智慧城市&#xff0c;推进城市发展新理念。…

现货黄金怎么交易

现货黄金是投资者广泛关注的一种黄金交易方式。与期货黄金相比&#xff0c;现货黄金交易更加简单、灵活&#xff0c;同时也更容易掌握。本文将介绍现货黄金交易的基本知识&#xff0c;以及投资者应该如何进行现货黄金交易。 一、现货黄金交易基础知识 什么是现货黄金&#xf…

ES6内置对象 - Set

Set&#xff08;es6提供的一种数据结构&#xff0c;类似数组&#xff0c;是一个集合&#xff0c;可以存储任何类型的元素且唯一、不重复&#xff0c;so,多用于元素去重&#xff09; 如上图&#xff0c;Set数据结构自带一些方法 1.Set对象创建 let a new Set([1,2,3,3,1,2,4,…

4个为数据程序员量身打造的PyCharm插件

SonarLint 插件可以帮助开发人员在编码过程中发现潜在的代码问题&#xff0c;提高代码质量。可在实时编码过程中发现并修复代码问题&#xff0c;类似于拼写检查器。它不仅仅是一个代码检查工具&#xff0c;更像是代码质量助手。 PyCharm 是一款由 JetBrains 公司推出的强大的 …

Ubuntu系统本地部署Inis博客结合内网穿透实现远程访问本地站点

文章目录 前言1. Inis博客网站搭建1.1. Inis博客网站下载和安装1.2 Inis博客网站测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2 Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3.Cpolar稳定隧道&#xff08;本地设置&#xff09; 3. 公网访问测试总…

超级实用的python代码片段汇总和详细解析(16个)

目录 1. 生成随机文本 2. 计算文本文件中的字数 3. 替换文件文件中的字串 4. 多文件名的批量替换 5. 从网站提取数据 6. 批量下载图片 7.批量删除空文件夹 8.Excel表格读写 9.合并Excel表格工作簿 10.数据库SQL查询 11. 系统进程查杀 12.图像尺寸调整和裁剪 13.图…

蓝桥杯STM32G431RBT6实现按键的单击、双击、长按的识别

阅读引言&#xff1a; 是这样&#xff0c; 我也参加了这个第十五届的蓝桥杯&#xff0c;查看竞赛提纲的时候发现有按键的双击识别&#xff0c; 接着我就自己实现了一个按键双击的识别&#xff0c;但是识别效果不是特别理想&#xff0c;偶尔会出现识别不准确的情况&#xff0c;接…

测试环境搭建整套大数据系统(六:搭建sqoop)

一&#xff1a;下载安装包 https://archive.apache.org/dist/sqoop/ 二&#xff1a;解压修改配置。 tar -zxvf sqoop-1.4.7.bin__hadoop-2.6.0.tar.gz -C /opt cd /opt mv sqoop-1.4.7.bin__hadoop-2.6.0/ sqoop-1.4.7修改环境变量 vi /etc/profile#SQOOP_HOME export SQOOP_…

outlook邮箱后缀怎么设置?邮箱后缀问题?

outlook邮箱后缀如何修改&#xff1f;微软有哪些后缀的邮箱&#xff1f; Outlook不仅提供了稳定的邮件收发服务&#xff0c;还允许用户根据个人喜好和需求自定义邮箱后缀。那么&#xff0c;Outlook邮箱后缀究竟该如何设置呢&#xff1f;下面&#xff0c;蜂邮EDM将一步步指导您…

【FPGA】VHDL:小型出勤系统设计

附源代码&#xff0c;一定能实现&#xff01; 目录 EDA设计练习题&#xff1a; 实验要求如下&#xff1a; 思路分析&#xff1a; 代码 99进制计数器 码转换 顶层文件 特别注意 测试 编译通过 结果展示 RTL视图 技术映射视图 软件&#xff1a;Quartus II 13.0 (64…

软件测试需要学习什么?好就业吗?

目前来说的话&#xff0c;整个it 都不太好&#xff01;但是既然你问了&#xff0c;我也就告诉你吧&#xff01; 1功能测试 &#xff1a;前端和后端&#xff0c;前端就是简单的页面&#xff0c;你需要考虑的是&#xff1a;必填项&#xff0c;边界值&#xff0c;组合&#xff0c…

深度学习介绍与环境搭建

深度学习介绍与环境搭建 慕课大学人工智能学习笔记&#xff0c;自己学习记录用的。&#xff08;赋上连接&#xff09; https://www.icourse163.org/learn/ZUCC-1206146808?tid1471365447#/learn/content?typedetail&id1256424053&cid1289366515人工智能、机器学习与…