【手把手教】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

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使