android 扫描照片功能,Android自定义View- 雷达扫描图

首先来看看效果图:CSDN博客地址

3ca743d90cf5

这里写图片描述

这里我使用了两种实现方式:

继承 view 实现。

继承 surfaceview 实现。

为什么会有两种实现方式呢?

主要是因为我在继续加入一些自定义功能的时候,如果是继承 view ,出现了卡顿的现象,也就是说在 UI 线程中做的逻辑操作太多了,导致 UI 线程失帧,最终导致了卡顿现象。又考虑到有些童鞋还没有学习 surfaceview ,所以会用两种方式去实现。文章末尾会贴出 GitHub 地址,所以这里只会贴出核心内容。

先简要说一下这里需要涉及到的知识点:

surfaceview

ValueAnimator (可选)

高中三角函数 Math.sin() Math.cos()。

绘制思路

绘制一个圆,颜色围绕圆心渐变。

让这个圆围绕圆心不断旋转,就有了扫描的效果。

根据半径生成随机的红点,当数量超过 5 个的时候,去掉最后一个点,让数量一直保持5个。

第一步:绘制一个渐变圆

ok,先看效果图:

3ca743d90cf5

这里写图片描述

初始化成员变量:

private int radius;//圆半径

private String TAG = "zoneLog";//Log 日志的 tag

private Matrix matrix;//view 的矩阵参数,用于旋转圆形

private float sweepAngle;//

private boolean isStart;//是否开始 valueanimator

private int value1;//valueanimator 的渐变值

private int x;//红点的 x 坐标值

private int y;//红点的 y 坐标值

private int totalAngle;//总旋转角度

private Paint redPointPaint;//红点画笔

private Paint sweepPaint;//圆形画笔,绘制圆角渐变

private Paint strokeWhitePaint;//描边白色画笔,用于绘制空心圆圈

private List pointList;//记录红点的坐标

private void init() {

matrix = new Matrix();

post(runnable);//用于实现圆形的不断旋转

handler.sendEmptyMessageDelayed(0, 1000);

isStart = true;

pointList = new ArrayList<>();

radius = 300;

sweepAngle = 8;//旋转角度

redPointPaint = new Paint();

redPointPaint.setAntiAlias(true);

redPointPaint.setColor(Color.RED);

redPointPaint.setStyle(Paint.Style.FILL_AND_STROKE);

sweepPaint = new Paint();

sweepPaint.setAntiAlias(true);

sweepPaint.setStyle(Paint.Style.FILL_AND_STROKE);

SweepGradient sweepGradient = new SweepGradient(0, 0, new int[]{0X10000000, Color.WHITE}, null);//角度渐变,由透明变为白色

sweepPaint.setShader(sweepGradient);//设置 shader

strokeWhitePaint = new Paint();

strokeWhitePaint.setAntiAlias(true);

strokeWhitePaint.setColor(Color.WHITE);

strokeWhitePaint.setStyle(Paint.Style.STROKE);

strokeWhitePaint.setStrokeWidth(1);

}

用于记录小红点:

class MyPoint {//用于记录小红点的圆心

int x;

int y;

float angle;

public MyPoint(int x, int y, float angle) {

this.x = x;

this.y = y;

this.angle = angle;

}

}

初始化完成后即可进行相关的绘制工作了:

canvas.drawColor(getResources().getColor(R.color.huaweiClockView));//绘制背景颜色

canvas.save();//在另外一个图层来绘制圆形,否则会影响到后续操作

canvas.concat(matrix);//获取 view 的矩阵参数

canvas.translate(getWidth() / 2, getHeight() / 2);//将原点移动至中心

canvas.drawCircle(0, 0, radius, sweepPaint);//绘制渐变圆

canvas.drawCircle(0, 0, radius + 80, strokeWhitePaint);//以下是绘制描边圆圈

canvas.drawCircle(0, 0, radius - 80, strokeWhitePaint);//

canvas.drawCircle(0, 0, radius - 160, strokeWhitePaint);//

canvas.drawCircle(0, 0, radius - 240, strokeWhitePaint);//

canvas.restore();//合并之前的操作,相当于 photoshop 中的图层合并

第二步:让圆转动起来

这里通过修改 view 的矩阵参数,让其实现旋转,我们肉眼看起来,也就实现了扫描的效果。先看效果:

3ca743d90cf5

这里写图片描述

private Runnable runnable = new Runnable() {

@Override

public void run() {

totalAngle += sweepAngle;//统计总的旋转角度

matrix.postRotate(sweepAngle, getWidth() / 2, getHeight() / 2);//旋转矩阵,旋转 8 度。

postInvalidate();//刷新

postDelayed(runnable, 200);//调用自身,实现不断循环

}

};

第三步:生成小红点

这里通过 handler 来不断生成小红点,而且让小红点有一定的停留时间。且跟随扫描的脚步去生成。

来看 一下效果图:

3ca743d90cf5

这里写图片描述

private Handler handler = new Handler() {

@Override

public void handleMessage(Message msg) {

super.handleMessage(msg);

if (msg.what == 0) {

int currentAngle = totalAngle % 360;//计算出一个圆范围内的旋转角度

int currentRadius = (int) (radius * Math.random()) + 50;//随机取得一个半径

x = (int) (currentRadius * Math.cos(currentAngle));//通过三角函数,计算出 x y 坐标值

y = (int) (currentRadius * Math.sin(currentAngle));

if (currentAngle > 0 && currentAngle < 90) {//计算出各个象限的情况

x = Math.abs(x);

y = Math.abs(y);

} else if (currentAngle > 90 && currentAngle < 180) {

x = -Math.abs(x);

y = Math.abs(y);

} else if (currentAngle > 180 && currentAngle < 270) {

x = -Math.abs(x);

y = -Math.abs(y);

} else if (currentAngle > 270 && currentAngle < 360) {

y = -Math.abs(y);

x = Math.abs(x);

} else if (currentAngle == 0 || currentAngle == 360) {

y = 0;

x = Math.abs(x);

} else if (currentAngle == 90) {

x = 0;

y = Math.abs(y);

} else if (currentAngle == 180) {

y = 0;

x = -Math.abs(x);

} else if (currentAngle == 270) {

x = 0;

y = -Math.abs(y);

}

pointList.add(0, new MyPoint(x, y, totalAngle));

if (pointList.size() > 5) {//超过 5 个数据时,抹掉最后一个数据

pointList.remove(pointList.size() - 1);

}

handler.sendEmptyMessageDelayed(0, 1000);//发送 message 实现不断循环

}

}

};

在 ondraw() 中追加以下代码,绘制小红点:

canvas.translate(getWidth() / 2, getHeight() / 2);

for (int i = 0; i < pointList.size(); i++) {

canvas.drawCircle(pointList.get(i).x, pointList.get(i).y, 30, redPointPaint);

}

canvas.restore();

好的,我们一步一步完成了雷达扫描图的绘制,路下来可能还有点懵逼,那么就看看整一段的代码吧。

view实现

surfaceview实现

如果文中有什么知识点是错误的或者更好的实现方法,请及时联系我进行修改,以免误导别人。谢谢。

最后还有一种效果是这样的,这里就不过多讲解了,可以进源码看看,哈哈。

3ca743d90cf5

这里写图片描述

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

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

相关文章

SmartSVN for Mac 使用说明

文章目录连接 SVN 服务器签出&#xff08;Check Out&#xff09;导出&#xff08;Export&#xff09;打开工作副本&#xff08;Open Working Copy&#xff09;打开和管理项目移除工作副本&#xff08;Remove Working Copy&#xff09;项目及工作副本目录导航窗口查看和配置被忽…

bldc 原理 方波控制_【百问百答】ST 电机控制实战问答合辑 | 连载之一

点击下方链接可以直接观看电机直播及直播答疑电堂​wx18257eb0e8c82435.h5.xiaoe-tech.com电堂​wx18257eb0e8c82435.h5.xiaoe-tech.com本次实战问答只讨论同步电机&#xff0c;不对步进电机做特别的讨论&#xff0c;希望有助于大家进行电机开发或者是电机应用。Q1&#xff1a;…

android动画编辑软件,ALM视频动画编辑

ALM视频动画编辑app手机端中最为专业,强大的视频编辑工具,丰富的功能堪比pc级别,并且实用流畅不卡顿,操作简单明了,上手容易,视频效果出色,更多丰富素材内容使用&#xff01;下载ALM视频动画编辑app开始体验吧&#xff01;ALM视频动画编辑介绍ALM视频动画编辑神器为你提供非常高…

openhub_介绍OpenHub框架

openhub本文介绍OpenHub框架 -基于Apache Camel的新的开源集成解决方案。 本文回答了一些问题&#xff0c;为什么您应该关心另一个集成框架&#xff0c;强弱属性以及如何使用OpenHub启动新项目。 OpenHub框架是Apache Camel&#xff0c;但经过改进…… 当然&#xff0c;您只能…

spring 导出csv_Spring批处理CSV处理

spring 导出csv总览 我们将讨论的主题包括使用Spring Batch进行批处理的基本概念&#xff0c;以及如何将数据从CSV导入数据库。 0 – Spring Batch CSV处理示例应用程序 我们正在构建一个应用程序&#xff0c;演示用于处理CSV文件的Spring Batch的基础。 我们的演示应用程序将…

python强制结束函数_为什么Python没有 main 函数?终于有人给出了正确答案!

毫无疑问&#xff0c;Python中没有所谓的 main 入口函数&#xff0c;但在网上经常有文章提到“Python中的main函数”和“建议编写main函数”等。他们的目的可能是模仿真实的 main 函数&#xff0c;但是经常有很多人被误导&#xff08;或误解&#xff09;并编写非常繁琐的代码。…

MacOS 如何显示/隐藏文件

文章目录显示/隐藏文件快捷键修改“访达”属性修改文件隐藏属性设置特殊文件名实现隐藏使用命令设置文件隐藏属性显示/隐藏文件 快捷键 按下 Shift Command . 可以显示隐藏型的文件&#xff0c;再按下 Shift Command . 则不显示隐藏型的文件 修改“访达”属性 defaults…

不相关子查询的工作方式是_课题组工作|Nucleic Acids Research|基于表达密度谱的特征子空间分离及相关单细胞转录组分群新算法...

大家好&#xff01;为大家分享本课题组近期发表在Nucleic Acids Research的文章&#xff0c;题目为 “Entropy subspace separation-based clustering for noise reduction (ENCORE) of scRNA-seq data”&#xff0c;文章提出了一种基于表达密度谱的特征选择方法&#xff0c;能…

java 9 module_Java 9:欢迎来到Module World

java 9 moduleJava 9已于9月21日正式发布&#xff0c;Eclipse从Eclipse Oxygen.1a&#xff08;4.7.1a&#xff09;支持Java 9&#xff0c;让我们进入模块世界。 从此处下载Java 9&#xff0c;并将其添加到Eclipse Installed JRE中&#xff0c;如下所示 就是这样&#xff0c;…

Mac OS 通过配置窗口来连接远程主机

点击连接后&#xff0c;就跳到命令终端窗口中&#xff0c;输入远程主机 root 用户的登录密码&#xff0c;则完成连接。

温度补偿计算公式_一种工业用温度测量模块的设计与实现

一种工业用温度测量模块的设计与实现罗伯特侯0 引言温度是工业生产中最重要的参数之一&#xff0c;因此温度测量设备在工业领域不可或缺。热电偶是工业场合中应用最广泛的温度传感器,它的主要特点是测温范围宽,价格低&#xff0c;同时结构简单,坚固耐用。笔者采用高集成度、高精…

微博如何发订阅消息_微信订阅号或将大变天,微博8年前就这么干了...

近日&#xff0c;微信又偷偷的做了一个大胆的尝试&#xff0c;将公众号消息排序改版&#xff0c;不再按照一直以来的“时间轴展示”&#xff0c;而是学起了微博&#xff0c;变成了“智能排序”。微信的“阅读效率优化”排序不过可能是为了独树一帜&#xff0c;微信管这种排序方…

indesign如何画弧线_彩铅画入门教程,如何给独角兽设计一款好发型

戳这里 → 查看“爱蜜干货文章目录”本次综合训练的目的1&#xff0e;挖掘你的绘画感和想象力&#xff0c;彩色鬃毛色彩大家可以自由发挥哦&#xff01;2.练习彩铅的长线条&#xff0c;现在练习的长条还是比较简单的&#xff0c;下次综合训练我们还会练习更加复杂的3.彩铅这种画…

微型计算机作为载体的部件是,大工11秋《计算机应用基础》辅导资料二

计算机应用基础辅导资料二主题&#xff1a;计算机基础知识的辅导资料学习时间&#xff1a;2011年10月10日&#xff0d;10月16日内容&#xff1a;这周我们主要学习课件&#xff0e;&#xff0e;第二章计算机的基础知识&#xff0c;本章的学习要求及需要掌握的重点内容如下&#…

markdown如何设置图片大小_Gitee(码云)实现免费 Markdown 图床

“阅读本文大概需要 6 分钟前言Markdown是一种易于上手的轻量级标记语言&#xff0c;由于其目的在于注重文字内容而不是排版&#xff0c;目前很受大家欢迎&#xff0c;写完一篇文档可以直接复制到其他各大平台上&#xff0c;不用担心格式字体等混乱问题但是文章中如果引用了某个…

适合利用计算机模拟的是,计算机模拟在数学建模中的应用

计算机模拟在数学建模中的应用计算机模拟是按时间来划分的&#xff0c;因为计算机模拟实质上是系统随时间变化而变化的动态写照&#xff0c;以下是小编搜集整理的一篇探究计算机模拟在数学建模应用的论文范文&#xff0c;供大家阅读参考。【摘要】本文主要阐述了如何利用计算机…

噪音声压和声功率的区别_南昌汽车隔音,深入了解汽车噪音的来源、危害以及解决方案...

汽车噪音带来的危害&#xff1a;汽车噪音对人体健康的影响是多方面的。噪音作用于人的中枢神经系统&#xff0c;使人们大脑皮层的兴奋与抑制平衡失调&#xff0c;导致条件反射异常&#xff0c;使脑血管张力遭到损害。这些生理上的变化&#xff0c;在早期能够恢复原状&#xff0…

lua加密教程_我们相信加密! 教程

lua加密教程许多人认为加密是一个复杂的主题&#xff0c;这很难理解。 可以实现其某些方面&#xff0c;但是每个人都可以理解它在更高层次上的工作方式。 这就是我要处理的这篇文章。 用简单的术语解释它是如何工作的&#xff0c;然后使用一些代码。 是的&#xff0c;我们信任…

生产用计算机软件管理台账,计算机台账管理系统

计算机台账管理系统计算机台账管理系统是什么&#xff1f;什么是计算机台账管理系统&#xff1f;对于设备管理而言&#xff0c;设备台账是其重要的组成部分&#xff0c;计算机台账管理系统对设备的编号、适用规格、年限、使用部门等具体信息进行管理&#xff0c;方便设备资产的…

fcpx怎么合成延时摄影_延时摄影合成终极后期教程

原来常见的延时摄影&#xff0c;一般都是软件生成或视频加速实现&#xff0c;这种方法简单快捷&#xff0c;但是后期处理空间小&#xff0c;画质差。现在追求高画质都会采用拍摄照片&#xff0c;后期合成&#xff0c;索尼等相机型号&#xff0c;自带有间隔拍摄功能&#xff0c;…