【手把手教】Android 利用Canvas标点画线,并加入位移动画

2023-10-22 21:30

本文主要是介绍【手把手教】Android 利用Canvas标点画线,并加入位移动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.背景

最近由于公司业务需要,需要自己实现一个点画线,移动的需求,这自然就想到了利用Canvas进行描点,画线连线。

过程比较简单,查阅了网上文章,发现写的都特别片面,很多人也会遇到类似需求,这里把整个实现过程讲一下,并且在实现过程遇到的一些小坑讲给大家。

先看效果图

关于上传不了视频这件事,我再好好研究研究。。。

其实点击检索,小人可以按照画好的路线进行移动。

具体代码:

Canvas画点连线

class DrawView extends View {private Boolean bool=false;private String num;public DrawView(Context context) {super(context);}public void setBool(Boolean isdraw,String number){this.bool=isdraw;this.num=number;Log.e("leo","bool:"+bool);}public void DrawLines(Canvas canvas){Log.e("leo","yayyaya"+bool);Paint mPaint3 = new Paint();mPaint3.setAntiAlias(true);mPaint3.setColor(Color.GREEN);mPaint3.setTextSize(36);mPaint3.setStrokeWidth(20);float[] points3=new float[]{450,100,480,350,480,350,330,500,330,500,510,650,510,650,780,800,780,800,450,900,450,900,450,1200,450,1200,550,1400,550,1400,600,1500};canvas.drawLines(points3,mPaint3);}@Overridepublic void onDraw(Canvas canvas) {super.onDraw(canvas);/** 方法 说明 drawRect 绘制矩形 drawCircle 绘制圆形 drawOval 绘制椭圆 drawPath 绘制任意多边形* drawLine 绘制直线 drawPoin 绘制点*/// 创建画笔Paint mPaint = new Paint();mPaint.setStrokeWidth(20);mPaint.setColor(Color.RED);// 设置红色//绘制Cap为BUTT的点Paint mPaint2 = new Paint();mPaint2.setStrokeWidth(40);mPaint2.setColor(Color.BLUE);// 设置红色mPaint2.setStrokeCap(Paint.Cap.ROUND);Paint mPaint3 = new Paint();mPaint3.setAntiAlias(true);mPaint3.setColor(Color.GREEN);mPaint3.setTextSize(36);mPaint3.setStrokeWidth(20);canvas.drawPoints(new float[]{20,100,100,350,150,430,200,510,250,560,350,650,550,730,670,890,750,1000}, mPaint2);canvas.drawPoints(new float[]{170,100,170,200,170,400,170,510,170,730,170,850}, mPaint2);canvas.drawPoints(new float[]{450,100,480,350,330,500,510,650,780,800,450,900,450,1200,550,1400,600,1500}, mPaint2);canvas.drawPoints(new float[]{140,1200,230,1250,370,1140,500,1220,570,1310,680,1280,750,1300,850,1260}, mPaint2);mPaint.setAntiAlias(true);mPaint.setColor(Color.RED);mPaint.setTextSize(36);float[] points=new float[]{20,100,100,350,100,350,150,430,150,430,200,510,200,510,250,560,250,560,350,650,350,650,550,730,550,730,670,890,670,890,750,1000};//至少4个值,即能够绘制一条直线float[] points2=new float[]{170,100,170,200,170,200,170,400,170,400,170,510,170,510,170,730,170,730,170,850};//至少4个值,即能够绘制一条直线//   至少4个值,即能够绘制一条直线canvas.drawLines(points,mPaint);canvas.drawLines(points2,mPaint);float[] points4=new float[]{140,1200,230,1250,230,1250,370,1140,370,1140,500,1220,500,1220,570,1310,570,1310,680,1280,680,1280,750,1300,750,1300,850,1260};//至少4个值,即能够绘制一条直线canvas.drawLines(points4,mPaint);float[] points3=new float[]{450,100,480,350,480,350,330,500,330,500,510,650,510,650,780,800,780,800,450,900,450,900,450,1200,450,1200,550,1400,550,1400,600,1500};canvas.drawLines(points3,mPaint);if (bool==true){if (num.equals("1")){DrawLines(canvas);}else  if (num.equals("2")){//     float[] points=new float[]{20,100,100,350,100,350,150,430,150,430,200,510,200,510,250,560,250,560,350,650,350,650,550,730,550,730,670,890,670,890,750,1000};//至少4个值,即能够绘制一条直线canvas.drawLines(points2,mPaint3);}else if (num.equals("3")){//  float[] points2=new float[]{170,100,170,200,170,200,170,400,170,400,170,510,170,510,170,730,170,730,170,850};//至少4个值,即能够绘制一条直线canvas.drawLines(points,mPaint3);}else if (num.equals("4")){//  float[] points4=new float[]{140,1200,230,1250,230,1250,370,1140,370,1140,500,1220,500,1220,570,1310,570,1310,680,1280,680,1280,750,1300,750,1300,850,1260};//至少4个值,即能够绘制一条直线canvas.drawLines(points4,mPaint3);}}}
}

简单说明一下,就是自定义View,继承View,利用Canvas画点,然后再利用Canvas画线,只要坐标点相同,其实就可以达到连接标记点画线的效果。

MainActivity进行调用

public class MainActivity extends AppCompatActivity {private EditText mEdiet;private Button  mButton;private ImageView mtv;ObjectAnimator  objectAnimatorX,objectAnimatorY;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initView();}private void initView() {RelativeLayout layout=(RelativeLayout) findViewById(R.id.root);DrawView views=new DrawView(this);views.setMinimumHeight(500);views.setMinimumWidth(300);//通知view组件重绘views.invalidate();layout.addView(views);}

利用平移动画沿线移动

        mEdiet=findViewById(R.id.qd);mButton=findViewById(R.id.qd2);mtv=findViewById(R.id.dw);mButton.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {String number=mEdiet.getText().toString();Log.e("leo","数字:"+number);if (number.equals("1")){float [] x= {450,480,330, 510,780,450,450,550,600};float [] y= {100,350,500,650,800,900,1200,1400,1500};startPopsAnimTrans(mtv,x,y);//  float[] points2=new float[]{170,100,170,200,170,200,170,400,170,400,170,510,170,510,170,730,170,730,170,850};//至少4个值,即能够绘制一条直线}else if (number.equals("2")){Log.e("leo","aiaiiai:");float [] x= {170,170,170, 170,170,170};float [] y= {100,200,400,510,730,850};startPopsAnimTrans(mtv,x,y);}//   startPopsAnimTrans(mtv,x,y);TimerTask task = new TimerTask() {@Overridepublic void run() {views.setBool(true,number);views.invalidate();}};Timer timer = new Timer();timer.schedule(task, 18000);}});
//        mtv.setOnClickListener(new View.OnClickListener() {
//            @Override
//            public void onClick(View view) {
//                startPopsAnimTrans(mtv);
//            }
//        });}private void startPopsAnimTrans(ImageView b,float [] x,float [] y){//  if(objectAnimatorX == null){Log.e("leo","执行否:"+x.length);//  float [] x= {450,480,330, 510,780,450,450,550,600};//  float [] y= {100,350,500,650,800,900,1200,1400,1500};objectAnimatorX = ObjectAnimator.ofFloat(b,"translationX", x);objectAnimatorX.setDuration(20000);objectAnimatorY = ObjectAnimator.ofFloat(b,"translationY", y);objectAnimatorY.setDuration(20000);//   }objectAnimatorX.start();objectAnimatorY.start();}

这里的Float数组肯定是与那些标记点的(就是画线所经过的点的位置信息)是一致的,小人才能沿着线移动。

这篇关于【手把手教】Android 利用Canvas标点画线,并加入位移动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/263692

相关文章

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤