当前位置:主页 > android教程 > Android标点画线加入位移动画

Android利用Canvas标点画线并加入位移动画(1)

发布:2023-03-09 11:00:01 59


给网友朋友们带来一篇相关的编程文章,网友廖品韵根据主题投稿了本篇教程内容,涉及到Android标点画线、Android位移动画、Android、Canvas画线、Android标点画线加入位移动画相关内容,已被893网友关注,下面的电子资料对本篇知识点有更加详尽的解释。

Android标点画线加入位移动画

本文实例为大家分享了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);
    }
 
    @Override
    public 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;
 
    @Override
    protected 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() {
            @Override
            public 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() {
                    @Override
                    public 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 Dispatchers.IO线程池深入刨析

    发布:2023-03-03

    这篇文章主要为大家介绍了Android Kotlin线程池Dispatchers.IO原理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步


  • Android对话框使用方法详解

    发布:2023-03-12

    这篇文章主要介绍了Android对话框使用方法,包括提示对话框、单选对话框、复选对话框、列表对话框等,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Android中PopupWindow弹出式窗口使用方法详解

    发布:2023-03-11

    这篇文章主要为大家详细介绍了Android中PopupWindow弹出式窗口的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Android Framework如何实现Binder

    发布:2023-03-09

    这篇文章主要介绍了Android Framework如何实现Binder,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下


  • Android App实现闪屏页广告图的全屏显示实例

    发布:2023-03-04

    这篇文章主要为大家介绍了Android App实现闪屏页广告图的全屏显示实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • Android Flutter实现上拉加载组件的示例代码

    发布:2023-03-03

    既然列表有下拉刷新外当然还有上拉加载更多操作了,本次就为大家详细介绍如何利用Flutter实现为列表增加上拉加载更多的交互,感兴趣的可以了解一下


  • Android ViewBinding使用介绍

    发布:2023-03-06

    最近这段时间在学习Kotlin,突然发现谷歌已经把kotlin-android-extensions插件废弃,目前推荐使用ViewBinding来进行替代,接下来通过本文给大家分享Android使用ViewBinding的详细步骤,感兴趣的朋友一起学习吧


  • Android启动初始化方案App StartUp的应用详解

    发布:2023-03-06

    这篇文章主要介绍了Android启动初始化方案App StartUp的使用方法,StartUp是为了App的启动提供的一套简单、高效的初始化方案,下面我们来详细了解


网友讨论