android练习 九宫格解锁

本文介绍了一个Android自定义View实现九宫格解锁的实践过程,包括思路、样式实现、响应事件处理和画线画点效果。讨论了如何处理点击事件、判断点在圆内以及状态变化,以及在实现过程中遇到的问题和解决方案。
摘要由CSDN通过智能技术生成

思路

主界面:
设置密码、验证密码、修改密码
fragment

实现方式,自定义View。
如何自定义View?自定义什么View?自定义View需要什么样子的功能?能否让它更加有可修改性?

参考资料:
Android 自定义控件实现九宫格解锁

样式实现

实践 - 先画一个圆

自定义View的样式实现
获取界面大小,获取中心坐标,获取每个半径的大小

    @Override
    protected void onDraw(Canvas canvas) {
   
//        super.onDraw(canvas);
        drawDefaultCircle(canvas);

    }

    private void drawDefaultCircle(Canvas canvas) {
   
        if (viewHeight == 0) {
    //获取view的长和宽。之后绘制圆形
            Log.d(TAG, "必须在onDraw中,才能获得view的大小");
            viewHeight = getMeasuredHeight();
            viewWidth = getMeasuredWidth();
        }
        float minLength = Math.min(viewHeight, viewWidth); //画正方形式的九宫格
        center_x = (getRight() - getLeft()) / 2;
        center_y = (getBottom() - getTop()) / 2; //获得绘制的中心点

        int pointNumber = getResources().getInteger(R.integer.point_number);
        int rowNumber = (int) Math.sqrt(pointNumber); //画几排?每排几个?因为是正方形所以是排数和行数相同
        circleRadius_default = minLength / rowNumber * 2 + rowNumber + 1; //2n个半径,每个圆相隔1个半径(带系统边界) = n+1

        canvas.drawCircle(center_x, center_y, 
        		circleRadius_default, paint_default); //先画一个看看
    }

在这里插入图片描述

实践反馈

  1. 画笔粗一点
  2. 为什么半径大小不对?
    算术优先级- -。 circleRadius_default = minLength / (rowNumber * 2 + rowNumber + 1);

初步实现样式

    private void init() {
   
        paint_default = new Paint(Paint.ANTI_ALIAS_FLAG);
        paint_default.setStyle(Paint.Style.STROKE);  //描边画笔
        paint_default.setColor(getContext().getColor(R.color.Color8328_1)); //画笔颜色
        paint_default.setStrokeWidth(5);
        //这个时候用getMeasuredHeight()是不是还不会显示的哇。因为View还没有初始化
        viewHeight = getMeasuredHeight();
        viewWidth = getMeasuredWidth();
    }

    @Override
    protected void onDraw(Canvas canvas) {
   
//        super.onDraw(canvas);
        drawDefaultCircle(canvas);

    }

    private void drawDefaultCircle(Canvas canvas) {
   
        if (viewHeight == 0) {
    //获取view的长和宽。之后绘制圆形
            Log.d(TAG, "必须在onDraw中,才能获得view的大小");
            viewHeight = getMeasuredHeight();
            viewWidth = getMeasuredWidth();
        }
        float minLength = Math.min(viewHeight, viewWidth); //画正方形式的九宫格
//        Log.d(TAG, "view的长度为:");
        center_x = (getRight() - getLeft()) / 2;
        center_y = (getBottom() - getTop()) / 2; //获得绘制的中心点

        int pointNumber = getResources().getInteger(R.integer.point_number);
        //画几排?每排几个?因为是正方形所以是排数和行数相同
        int rowNumber = (int) Math.sqrt(pointNumber); 
        Log.d(TAG, "行列数 " + rowNumber);
        //2n个半径,每个圆相隔1个半径(带系统边界) = n+1
        circleRadius_default = minLength / (rowNumber * 2 + rowNumber + 1); 

        for (int i = 0; i < rowNumber; i++) {
   
            //一排,修改y坐标
            float point_y = center_y - (1 - i) * 3 * circleRadius_default;
            for (int j = 0; j < rowNumber; j++) {
   
                //修改x坐标
                float point_x = center_x - (1 - j) * 3 * circleRadius_default;
                canvas
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值