Android系列之手机多点触摸画圆

本文介绍了一种使用Android系统实现多点触摸绘制动态彩色圆的方法。通过自定义View类和实体类,实现了手指按下时生成随机颜色的圆,并跟踪手指移动更新圆的位置,抬起时移除对应圆的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

静态效果图:(多个手指按下和抬起的状态)



代码实现部分:

1、先写个实体类,设置相关的属性

package com.zking.laci.android19_pointstouch;

import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;

import java.util.Random;

/**
 * Created by Laci on 2017/7/9.
 */

public class MyCircle {
    public float x;
    public float y;
    public int r=100;
    public int pointId;
    int red;
    int green;
    int blue;
    Random random=new Random();

    public MyCircle(float x, float y, int pointId) {
        this.x = x;
        this.y = y;
        this.pointId = pointId;
        red=random.nextInt(255);
        green=random.nextInt(255);
        blue=random.nextInt(255);
    }
    public void drawSelf(Canvas canvas, Paint paint){
        paint.setStyle(Paint.Style.STROKE);
        paint.setColor(Color.rgb(red,green,blue));
        canvas.drawCircle(x,y,r,paint);
    }
}

2、然后我们自己再写个java类,用来画圆的

package com.zking.laci.android19_pointstouch;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

import java.util.ArrayList;
import java.util.List;

/**
 * Created by Laci on 2017/7/9.
 */

public class MyView extends View {

    List<MyCircle> lt=new ArrayList<>();



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

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

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

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

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        Paint paint=new Paint();
        for (MyCircle myCircle : lt) {
            myCircle.drawSelf(canvas,paint);
        }

    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        //获取手指的行为
        int action=event.getAction();
        int action_code=action&0xff;
        //手指的下标
        int pointIndex=action>>8;


        //获取手指的坐标
        float x=event.getX(pointIndex);
        float y=event.getY(pointIndex);



        //获取手指的名字的ID
        int pointId=event.getPointerId(pointIndex);
        if(action_code>=5){
            action_code-=5;
        }

        switch (action_code) {
            case MotionEvent.ACTION_DOWN:
                //实例化园
                MyCircle myCircle=new MyCircle(x,y,pointId);
                //将园添加到集合中
                lt.add(myCircle);
                break;
            case MotionEvent.ACTION_UP:
                lt.remove(get(pointId));
                break;
            case MotionEvent.ACTION_MOVE:
                for (int i = 0; i <event.getPointerCount() ; i++) {
                    int id=event.getPointerId(i);
                    get(id).x=event.getX(i);
                    get(id).y=event.getY(i);
                }
                break;
        }

        //重新调用onDraw 重绘
        invalidate();
        return true;
    }

    public MyCircle get(int pointId){
        for (MyCircle myCircle : lt) {
            if(myCircle.pointId==pointId){
                return myCircle;
            }
        }
        return null;
    }


}

3、最后我们在activity中改一句代码就可以了

setContentView(new MyView(this));

最后打开真机测试就可以啦!




在MATLAB中,多点拟合画圆通常是指通过最小二乘法或其他优化算法来拟合一组数据点形成一个接近真实圆的数学模型。这种做法假设数据点是由一个圆的方程生成的,圆的标准形式可以表示为(x - h)^2 + (y - k)^2 = r^2,其中(h, k)是圆心坐标,r是半径。 以下是使用MATLAB进行这个任务的基本步骤: 1. 准备数据:首先,你需要有一组二维坐标的数据点,这些点理论上应该分布在圆上或近似于圆的区域。 ```matlab % 假设你有如下的数据点 x_data = [x1, x2, ...]; % 横坐标 y_data = [y1, y2, ...]; % 纵坐标 ``` 2. 建立模型:定义一个圆的函数,通常是一个平方误差函数,目标是最小化所有数据点到圆上的垂直距离的总和。 ```matlab function err = circleFit(x, y, center, radius) % 计算每个数据点到圆心的距离的平方 dists = sqrt((x - center(1)).^2 + (y - center(2)).^2); % 返回误差向量 err = dists - radius; end ``` 3. 非线性最小化:使用`fmincon`或`lsqcurvefit`函数求解圆心和半径的最优值,给定数据点作为约束条件。 ```matlab options = optimoptions('fmincon', 'Algorithm', 'interior-point'); % 设置选项 initial_guess = [mean(x_data), mean(y_data), std(x_data)]; % 初始猜测 [xhat, yhat, rhohat] = lsqcurvefit(@circleFit, initial_guess, x_data, y_data, options); ``` 4. 绘制拟合圆:最后,你可以用找到的圆心和半径绘制出拟合的圆形。 ```matlab plot(x_data, y_data, 'o', xhat, yhat, 'b*') % 数据点和拟合圆心 hold on plot(radius, radius, 'k:', 'LineWidth', 2) % 原点到半径的参考线 plot([xhat-radius, xhat+radius], [yhat-radius, yhat+radius], 'b') % 拟合圆的轮廓 hold off ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值