iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >android九宫格锁屏控件使用详解
  • 426
分享到

android九宫格锁屏控件使用详解

2024-04-02 19:04:59 426人浏览 八月长安
摘要

本文实例为大家分享了Android九宫格锁屏控件的具体代码,供大家参考,具体内容如下 代码: public class LockView extends View {     //

本文实例为大家分享了Android九宫格屏控件的具体代码,供大家参考,具体内容如下

代码:

public class LockView extends View {
    //半径
    private int radius;
    //中心小圆半径
    private int smallRadius;
    //一行个数
    private int column;
    //选中颜色
    private int selectColor;
    //未选中颜色
    private int nORMalColor;
    //阴影颜色
    private int shaderColor;
    //连线的颜色
    private int lineColor;
    //圆线宽
    private int circleStrokeWidth;
    //连线的线宽
    private int lineStrokeWidth;

    private Paint normalPaint;
    private Paint selectPaint;
    private Paint linePaint;
    private Paint centerPaint;
    private int width;
    //每个圆宽度
    private int everyWidth;
    //是否是选中绘制
    private boolean isSelect;
    //所有圆信息
    private List<Point> allCircleList = new ArrayList<>();
    //选中圆的标志
    private List<Integer> selectList = new ArrayList<>();
    //是否是重置
    private boolean isReSet;
    private LockViewFinishListener lockViewFinishListener;

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

    public LockViewFinishListener getLockViewFinishListener() {
        return lockViewFinishListener;
    }

    public void setLockViewFinishListener(LockViewFinishListener lockViewFinishListener) {
        this.lockViewFinishListener = lockViewFinishListener;
    }

    private void init(Context context, AttributeSet attrs) {
        TypedArray typedArray = context.obtainStyledAttributes(attrs,R.styleable.LockView);
        radius = typedArray.getInteger(R.styleable.LockView_lock_radius,100);
        smallRadius = typedArray.getInteger(R.styleable.LockView_smallRadius,30);
        column = typedArray.getInteger(R.styleable.LockView_column,3);
        selectColor =typedArray.getColor(R.styleable.LockView_selectColor,Color.RED);
        normalColor = typedArray.getColor(R.styleable.LockView_lock_normalColor,Color.GRAY);
        shaderColor = typedArray.getColor(R.styleable.LockView_shaderColor,Color.argb(80, 0xff, 0x00, 0x00));
        lineColor = typedArray.getColor(R.styleable.LockView_lineColor,Color.RED);
        circleStrokeWidth = typedArray.getInteger(R.styleable.LockView_circleStrokeWidth,5);
        lineStrokeWidth = typedArray.getInteger(R.styleable.LockView_lineStrokeWidth,15);

        normalPaint = new Paint();
        normalPaint.setColor(normalColor);
        normalPaint.setAntiAlias(false);//设置为无锯齿
        normalPaint.setStrokeWidth(circleStrokeWidth);//线宽
        normalPaint.setStyle(Paint.Style.STROKE);

        selectPaint = new Paint();
        selectPaint.setColor(selectColor);
        selectPaint.setAntiAlias(false);
        selectPaint.setStrokeWidth(circleStrokeWidth);
        selectPaint.setStyle(Paint.Style.STROKE);

        centerPaint = new Paint();
        centerPaint.setColor(selectColor);
        centerPaint.setAntiAlias(false);
        centerPaint.setStrokeWidth(radius - smallRadius);
        centerPaint.setStyle(Paint.Style.FILL_AND_STROKE);

        linePaint = new Paint();
        linePaint.setColor(lineColor);
        linePaint.setAntiAlias(false);//设置为无锯齿
        linePaint.setStrokeWidth(lineStrokeWidth);//线宽
        linePaint.setAlpha(150);
        linePaint.setStyle(Paint.Style.STROKE);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        width = measureWidth(widthMeasureSpec);
        setMeasuredDimension(width, width);
        everyWidth = (width - getPaddingLeft() - getPaddingRight()) / column;
        allCircleList.clear();
        for (int i = 0; i < column; i++) {
            for (int j = 0; j < column; j++) {
                float cx = getPaddingLeft() + everyWidth / 2 * (2 * j + 1);
                float cy = getPaddingTop() + everyWidth / 2 * (2 * i + 1);
                Point point = new Point();
                point.cx = cx;
                point.cy = cy;
                allCircleList.add(point);
            }
        }
    }

    @Override
    protected void onDraw(canvas canvas) {
        super.onDraw(canvas);
        for (int i = 0; i < allCircleList.size(); i++) {
            Point point = allCircleList.get(i);
            canvas.drawCircle(point.cx, point.cy, radius, normalPaint);
        }
        if (isReSet) {//重置
            isReSet = false;
            postInvalidate();
        } else {
            if (isSelect) {
                for (int i = 0; i < selectList.size(); i++) {
                    int index = selectList.get(i);
                    Point point = allCircleList.get(index);
                    canvas.drawCircle(point.cx, point.cy, radius, selectPaint);
                    Shader mShader = new RadialGradient(point.cx, point.cy, smallRadius, new int[]{selectColor, shaderColor},
                            new float[]{0.9f, 1f}, Shader.TileMode.CLAMP);
                    centerPaint.setShader(mShader);
                    canvas.drawCircle(point.cx, point.cy, smallRadius, centerPaint);
                    if (i >= 1) {
                        int lastIndex = selectList.get(i - 1);
                        Point lastPoint = allCircleList.get(lastIndex);
                        canvas.drawLine(lastPoint.cx, lastPoint.cy, point.cx, point.cy, linePaint);
                    }
                }
            }
        }
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                isReSet = true;
                selectList.clear();

                int index = calculateWhich(event.getX(), event.getY());
                if (index != -1) {
                    selectList.add(index);
                    isSelect = true;
                }
                break;
            case MotionEvent.ACTION_MOVE:
                index = calculateWhich(event.getX(), event.getY());
                if (index != -1) {
                    if (!selectList.contains(index)) {
                        selectList.add(index);
                    }
                }
                break;
            case MotionEvent.ACTION_UP:
                if (lockViewFinishListener != null) {
                    StringBuffer result = new StringBuffer();
                    for (int i = 0; i < selectList.size(); i++) {
                        result.append(selectList.get(i));
                    }
                    lockViewFinishListener.onSuccess(result + "");
                }
                break;
        }
        postInvalidate();
        return true;
    }

    
    private int measureWidth(int widthMeasureSpec) {
        int result;
        int specSize = MeasureSpec.getSize(widthMeasureSpec);
        int specMode = MeasureSpec.getMode(widthMeasureSpec);
        if (specMode == MeasureSpec.EXACTLY) {
            result = specSize;
        } else {
            result = getPaddingLeft() + getPaddingRight() + radius * 2 * column ;
            if (specMode == MeasureSpec.AT_MOST) {
                result = Math.min(result, specSize);
            }
        }
        return result;
    }

    
    private int calculateWhich(float lx, float ly) {
        for (int i = 0; i < allCircleList.size(); i++) {
            Point point = allCircleList.get(i);
            if (lx > point.cx - radius && lx < point.cx + radius) {
                if (ly > point.cy - radius && ly < point.cy + radius) {
                    return i;
                }
            }
        }
        return -1;
    }

    public interface LockViewFinishListener {
        void onSuccess(String result);
    }

    private class Point {
        private float cx;
        private float cy;
    }

}
<!--九宫格锁屏控件-->
    <declare-styleable name="LockView">
        <!--大圆半径-->
        <attr name="lock_radius" format="integer"/>
        <!--小圆半径-->
        <attr name="smallRadius" format="integer"/>
        <!--一行个数-->
        <attr name="column" format="integer"/>
        <!--选中颜色-->
        <attr name="selectColor" format="color"/>
        <!--未选中颜色-->
        <attr name="lock_normalColor" format="color"/>
        <!--阴影颜色-->
        <attr name="shaderColor" format="color"/>
        <!--连线的颜色-->
        <attr name="lineColor" format="color"/>
        <!--圆线宽-->
        <attr name="circleStrokeWidth" format="integer"/>
        <!--连线的线宽-->
        <attr name="lineStrokeWidth" format="integer"/>
</declare-styleable>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: android九宫格锁屏控件使用详解

本文链接: https://www.lsjlt.com/news/152807.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • android九宫格锁屏控件使用详解
    本文实例为大家分享了android九宫格锁屏控件的具体代码,供大家参考,具体内容如下 代码: public class LockView extends View {     //...
    99+
    2024-04-02
  • Android自制九宫格解锁控件
    本文实例为大家分享了Android自制九宫格解锁控件的具体代码,供大家参考,具体内容如下 前两天从网上学习了下如何自定义一个九宫格解锁的控件,于是自己根据逻辑写了一遍,自定义控件的代...
    99+
    2024-04-02
  • Android怎么绘制九宫格解锁控件
    这篇“Android怎么绘制九宫格解锁控件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android怎么绘制九宫格解锁控件...
    99+
    2023-06-29
  • Android自定义控件实现九宫格解锁
    关于九宫格解锁,我看了不少博客,但是都感觉很复杂,可能我的功夫还不到,所以很多东西我不了解,但是我还是打算写一个自己的九宫格。我相信我的九宫格大家都能很快的理解,当然如果需要实现更复...
    99+
    2024-04-02
  • Android自定义控件实现九宫格解锁功能
    最终Android九宫格解锁效果如下进行定义实体point点public class Point { private float x; private float y; //正常模式 public static final int NORM...
    99+
    2023-05-31
    android 九宫格 解锁
  • Android自定义view实现滑动解锁九宫格控件
    目录前言需求效果图前言 上一篇文章用贝塞尔曲线画了一个看起来不错的小红点功能,技术上没什么难度,主要就是数学上的计算。这篇文章也差不多,模仿了一个常用的滑动解锁的九宫格控件。 需求 ...
    99+
    2023-02-09
    Android滑动解锁九宫格 Android滑动解锁 Android九宫格控件
  • Android怎么实现九宫格解锁
    这篇文章主要介绍Android怎么实现九宫格解锁,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先理清一下逻辑,我们要做NxN的九宫格 下图是3x3的简单图例// -(--)-(--)-(--)-// -(--)-(...
    99+
    2023-05-30
    android
  • Android实现九宫格图案解锁
    本文实例为大家分享了Android实现九宫格图案解锁的具体代码,供大家参考,具体内容如下 前言:自定义了一个九宫格的VIew来绘制九宫格图案,实现了绘制图案解锁的功能。 效果图如下:...
    99+
    2024-04-02
  • Android怎么实现九宫格图案解锁
    今天小编给大家分享一下Android怎么实现九宫格图案解锁的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。效果图如下: 第一步...
    99+
    2023-07-02
  • Android自定义ViewGroup实现朋友圈九宫格控件
    目录一、简介 1.1、效果图如下1.2、主要功能如下二、使用 2.1、自定义属性如下2.2、布局中使用自定义NineImageLayout2.3、Adapter方式绑定数据和UI2....
    99+
    2024-04-02
  • Android自定义View实现九宫格图形解锁(Kotlin版)
    本文实例为大家分享了Android自定义View实现九宫格图形解锁的具体代码,供大家参考,具体内容如下 效果: 代码: package com.example.kotlin_t...
    99+
    2024-04-02
  • Android如何自定义ViewGroup实现朋友圈九宫格控件
    本篇内容介绍了“Android如何自定义ViewGroup实现朋友圈九宫格控件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录一、简介1、...
    99+
    2023-06-20
  • 怎么在Android 应用中实现一个九宫格手势锁
    怎么在Android 应用中实现一个九宫格手势锁?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。主要的方法是重写View.onTouchEvent( Motion...
    99+
    2023-05-31
    android roi
  • Android表格自定义控件使用详解
    近期公司要做报表功能,在网上搜索下表格的样式后便自己写了一个自定义的表格控件,该表格控件能根据设置的数据中数据的最大值自动设置左侧信息栏显示的值,使得条形图能尽量的充满控件,条形图部...
    99+
    2024-04-02
  • Android自定义滑动解锁控件使用详解
    最近的项目里用到了,在网上找不到合适的,于是自己写了个简单的,带回弹效果:可以自定义的属性有:<!-- 滑动解锁控件 xml配置属性 --><declare-styleable name="SlideToUnlockVie...
    99+
    2023-05-30
    android 滑动解锁 roi
  • Android控件AppWidgetProvider使用方法详解
    介绍AppWidgetProvider是Android中提供的用于实现桌面小工具的类,其本质是一个广播,即BroadcastReceiver,在实际的使用中,把AppWidgetProvider当成一个BroadcastReceiver即可...
    99+
    2023-05-30
    android appwidgetprovider pp
  • Android形状图形与状态列表图形及九宫格图片超详细讲解
    目录一、图形Drawable二、形状图形三、九宫格图片四、状态列表图形一、图形Drawable Drawable类型表达了各种各样的图形,包括图片、色块、画板、背景等。 包含图片在内...
    99+
    2024-04-02
  • android表格控件怎么使用
    在Android中,可以使用RecyclerView和GridView来实现表格控件的效果。 使用RecyclerView: ...
    99+
    2023-10-26
    android
  • Android常用控件Spinner的使用(详解)
    一、Spinner介绍 在Android开发过程中,Spinner下拉控件是比较常用的控件,它可以以下拉框和dialog的方式进行展示。默认是下拉框方式。 Spinner效果 上图可以看出实现Spi...
    99+
    2023-08-31
    android java android studio
  • Swing拆分窗格控件JSplitPane使用详解
    本文实例为大家分享了Swing拆分窗格控件JSplitPane的使用方法,供大家参考,具体内容如下package day1115;import javax.swing.*;import java.awt.Color;public class...
    99+
    2023-05-30
    swing jsplitpane
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作