首页 > 其他分享 >Android开发笔记[13]-图案密码

Android开发笔记[13]-图案密码

时间:2024-03-17 20:44:28浏览次数:37  
标签:13 compose androidx 笔记 图案 密码 import Android com

摘要

输入图案密码123跳转到关于页面.

关键信息

  • Android Studio:Iguana | 2023.2.1
  • Gradle:distributionUrl=https://services.gradle.org/distributions/gradle-8.4-bin.zip
  • jvmTarget = '1.8'
  • minSdk 21
  • targetSdk 34
  • compileSdk 34
  • 开发语言:Kotlin,Java
  • ndkVersion = '21.1.6352462'
  • kotlin版本:1.9.20
  • kotlinCompilerExtensionVersion '1.5.4'
  • com.android.library:8.3

原理简介

图案密码

[https://gitcode.com/aritraroy/patternlockview/overview]
[https://github.com/aritraroy/PatternLockView]
[https://blog.csdn.net/shenggaofei/article/details/100054501]
[https://blog.csdn.net/qq_36243942/article/details/104186126]
[https://blog.csdn.net/Joson_Wang/article/details/49929775]
[https://blog.csdn.net/octopusflying/article/details/80157204]
Android 的图案密码解锁,通过手势连接 3 * 3 的点矩阵绘制图案表示解锁密码,对应一定顺序的数字序列。
图案方式比较直观,具有易于记忆的特点。
图案密码的工作原理是将设备的屏幕划分为一系列的点或区域,用户需要按照特定的顺序在这些点或区域内滑动手指,从而形成一种独特的图案。这种图案就像一个密码一样,只有知道正确的图案才能解锁设备。
图案密码具有较高的安全性,因为它们可以组合成大量的不同图案。同时,由于图案密码直观易用,因此也受到了许多用户的欢迎。

图案密码示例

实现

核心代码

  1. 修改build.gradle
/* start 图案密码库相关 */
implementation 'com.andrognito.patternlockview:patternlockview:1.0.0'
implementation 'com.andrognito.patternlockview:patternlockview-reactive:1.0.0'
implementation 'io.reactivex.rxjava3:rxandroid:3.0.0'
implementation 'io.reactivex.rxjava3:rxjava:3.1.4'
/* end 图案密码库相关 */
  1. 添加PatternLockActivity页面
    AndroidManifest.xml
<!-- 图案密码页 -->
<activity
    android:name=".PatternLockViewActivity"
    android:exported="false"
    android:label="@string/title_activity_pattern_lock_view"
    android:theme="@style/Theme.AppCompat.DayNight.NoActionBar" />

activity_pattern_lock.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/matisse_capture_icon_color"
    android:theme="@style/Theme.MaterialComponents.DayNight.NoActionBar"
    android:orientation="vertical">

    <ImageView
        android:id="@+id/profile_image"
        android:layout_width="84dp"
        android:layout_height="84dp"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="50dp"
        android:src="@drawable/weekend_android_logo"/>

    <TextView
        android:id="@+id/profile_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="36dp"
        android:fontFamily="sans-serif-thin"
        android:gravity="center"
        android:maxLines="1"
        android:text="请输入页面跳转码(试一试123)"
        android:textColor="@color/white"
        android:textSize="20sp"/>

    <com.andrognito.patternlockview.PatternLockView
        android:id="@+id/pattern_lock_view"
        android:layout_width="280dp"
        android:layout_height="280dp"
        android:layout_gravity="center_horizontal"
        android:layout_marginTop="16dp"
        app:aspectRatio="square"
        app:aspectRatioEnabled="true"
        app:dotAnimationDuration="150"
        app:dotCount="3"
        app:normalStateColor="@color/white"
        app:correctStateColor="@color/macaron_raspberry_cheesecake"
        app:wrongStateColor="@color/pomegranate"
        app:dotSelectedSize="50dp"
        />

    <!--    自定义属性-->
    <!--     app:dotCount="3"                                        // 更改行(或列)-->
    <!--    app:dotNormalSize="12dp"                                // 更改正常状态-->
    <!--    app:dotSelectedSize="24dp"                              // 更改选定状态-->
    <!--    app:pathWidth="4dp"                                     // 更改路径-->
    <!--    app:aspectRatioEnabled="true"                           // 设置视图是否应该遵循自定义宽高比-->
    <!--    app:aspectRatio="square"                                // 设置在“square”,“width_bias”,“height_bias”-->
    <!--    app:normalStateColor="@color/white"                     // 设置正常状态下图案视图的颜色-->
    <!--    app:correctStateColor="@color/primary"                  // 将图案视图的颜色设置为正确状态-->
    <!--    app:wrongStateColor="@color/pomegranate"                // 设置错误状态-->
    <!--    app:dotAnimationDuration="200"                          // 更改动画点-->
    <!--    app:pathEndAnimationDuration="100"                      // 更改路径结束动画的持续时间-->

</LinearLayout>

PatternLockActivity.kt

package cn.qsbye.weekend_android

import android.app.Activity
import android.content.Intent
import android.os.Bundle
import android.text.TextUtils
import android.util.Log
import android.view.LayoutInflater
import android.widget.TextView
import android.widget.Toast
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Surface
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.viewinterop.AndroidView
import cn.qsbye.weekend_android.AboutPageClass.MyViewModel
import cn.qsbye.weekend_android.ui.theme.WeekendAndroidTheme
import io.noties.markwon.Markwon
import com.andrognito.patternlockview.PatternLockView
import com.andrognito.patternlockview.listener.PatternLockViewListener
import com.andrognito.patternlockview.utils.PatternLockUtils
import com.andrognito.patternlockview.utils.ResourceUtils
import com.andrognito.rxpatternlockview.RxPatternLockView
import com.andrognito.rxpatternlockview.events.PatternLockCompleteEvent
import com.andrognito.rxpatternlockview.events.PatternLockCompoundEvent
import io.reactivex.rxjava3.core.Observable
import io.reactivex.rxjava3.functions.Consumer

class PatternLockViewActivity : ComponentActivity() {

    // 图案密码
    private lateinit var myPatternLock: MyPatternLock

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            WeekendAndroidTheme {
                // A surface container using the 'background' color from the theme
                Surface(
                    modifier = Modifier.fillMaxSize(),
                    color = MaterialTheme.colorScheme.background
                ) {
                    // 显示图案密码
                    myPatternLock = MyPatternLock(this@PatternLockViewActivity)
                    myPatternLock.initPatternLockView()
                }
            }
        }
    } // end onCreate

}

/* start 页面布局 */

class MyPatternLock(private val context: Activity) {
    // 图案密码
    private lateinit var mPatternLockView: PatternLockView

    @Composable
    fun initPatternLockView() {
        Column(
            Modifier
                .fillMaxSize()
                .background(Color.White)
        ) {

            /* start XML布局 */
            AndroidView(
                modifier = Modifier
                    .fillMaxWidth()
                    .padding(8.dp),
                factory = { ctx ->
                    val layout_from_xml =
                        LayoutInflater.from(ctx).inflate(R.layout.activity_pattern_lock, null)
                    mPatternLockView = layout_from_xml.findViewById(R.id.pattern_lock_view)
                    // 绑定图案密码回调
                    mPatternLockView.addPatternLockListener(mPatternLockViewListener)
                    layout_from_xml // Return the TextView instance
                },
            )

            /* end XML布局 */
        }
    }

    /* start 回调监听事件 */
    private val mPatternLockViewListener = object : PatternLockViewListener {
        override fun onStarted() {
            Log.d(context::class.simpleName, "Pattern drawing started")
        }

        override fun onProgress(progressPattern: List<PatternLockView.Dot>) {
            Log.d(
                context::class.simpleName, "Pattern progress: " +
                        PatternLockUtils.patternToString(mPatternLockView, progressPattern)
            )
        }

        override fun onComplete(pattern: List<PatternLockView.Dot>) {
            Log.d(
                context::class.simpleName, "Pattern complete: " +
                        PatternLockUtils.patternToString(mPatternLockView, pattern)
            )
            val password_to_about_activity = "123"
            val patternToString = PatternLockUtils.patternToString(mPatternLockView, pattern)
            if (!TextUtils.isEmpty(patternToString)) {
                if (patternToString == password_to_about_activity) {
                    Toast.makeText(
                        context, "您绘制的密码是:$patternToString\n" +
                                "密码正确,正在进入关于页...", Toast.LENGTH_SHORT
                    ).show()
                    val intent = Intent(context, AboutActivity::class.java)
                    context.startActivity(intent)
                    context.finish()
                } else {
                    Toast.makeText(
                        context, "您绘制的密码是:$patternToString\n" +
                                "密码错误,请重新绘制", Toast.LENGTH_SHORT
                    ).show()
                }
            }
        }

        override fun onCleared() {
            Log.d(context::class.simpleName, "Pattern has been cleared")
        }
    }
    /* end 回调监听事件 */
}
/* end 页面布局 */

效果

输入图案密码进入相应页面

标签:13,compose,androidx,笔记,图案,密码,import,Android,com
From: https://www.cnblogs.com/qsbye/p/18079130

相关文章

  • ESP32学习笔记-读取SD卡并显示到屏幕上
    硬件FireBeetle2ESP32-E开发板1.54"240x240 IPS 广视角TFT显示屏硬件接线测试代码//加载库#include"Arduino.h"#include"FS.h"#include"SD.h"#include"SPI.h"#include"DFRobot_GDL.h"//定义显示屏针脚#defineTFT_DCD2#......
  • 【VC++学习笔记】控件及按钮的设置和使用
    1:按钮的使能与禁止用ClassWizard的MemberVariables为按钮定义变量,如:m_Button1;则m_Button1.EnableWindow(true);使按钮处于允许状态m_Button1.EnableWindow(false);使按钮被禁止,并变灰显示2:控件的隐藏与显示用CWnd类的函数BOOLShowWindow(intnCmdShow)可以隐藏或显示......
  • 数据结构知识总结笔记------第四章:串(1)串的定义、存储结构、基本操作
    1、串的定义串是由零个或者多个字符组成的有限序列。串中字符的个数称为串的长度,含有零个元素的串叫空串。在C语言中,可以用以下语句定义一个名为str的串。charstr[]="abcdef";说明:串通常用一个字符数组来表示。从这个角度来讲,数组str内存储的字符为’a’、‘b’、‘c’......
  • 硕芯科技SX1308DCDC升压方案
    数据手册特征大致如下升压型DCDC2~24V电压输入4A开关电流限制SOT23-6超小封装最高28V输出电压典型应用电路图如下:输出电压与反馈电阻关系如下 VREF为0.6V,如下电路为输出5V时的电路配置其中EN为该芯片的转换使能引脚,注意此处是转换而不是输出,所以当该引脚为低电平时,......
  • 深度学习入门基于python的理论与实现-第五章误差反向传播法(个人向笔记)
    目录计算图链式法则反向传播加法结点的反向传播乘法结点的反向传播计算图计算图是一种图形化表示计算过程的方法,通常用于机器学习和深度学习中。在计算图中,节点代表操作(例如加法、乘法等),边代表数据流动(即操作的输入和输出)。通过计算图,可以清晰地展示计算过程中各个操作之间的依......
  • 滴水逆向笔记系列-win32总结8-59.枚举窗口_鼠标键盘事件函数-60.加密壳项目
    第五十九课win32枚举窗口_鼠标键盘事件函数1.查找指定窗口::FindWindow()函数获取窗口句柄,再通过句柄控制窗口,函数的参数可以通过vs的spy++工具获得TCHARszTitle[MAX_PATH]={0}; HWNDhwnd=::FindWindow(TEXT("#32770"),TEXT("飞鸽传书IPMessenger")); ......
  • 滴水逆向笔记系列-win32总结9-61.CE使用-62.ShellCode_远程线程注入
    第六十一课CE使用下载完CE后用ce自带的小作业练练1.第二题先打开进程Firstscan搜索100,发现有很多100,我们先让右边程序Hitme,然后Nextscan搜索96,发现已经搜出来了,正常数据会很多,就需要继续改继续搜,最后点击下面value修改为1000即可2.第三题先NewScan搜索小于500的,点击......
  • Java学习笔记:字符串
    目录Java学习笔记:字符串String创建String对象内存模型String比较Scanner验证键入的字符串本质是new出来的练习案例:判断账户和密码是否一致遍历字符串统计字符次数字符串反转StringBuilderStringBuilder构造方法链式编程拼接字符串StringJoiner总结必须学习使用JDKAPI帮助文档​......
  • MySQL数据库基础笔记
    MySQL数据库sql语句分类分类全称说明DDL数据库定义语言,用来定义数据库(数据库,表,字段)DML数据操作语言,用来对数据表中的数据进行增删改DQL数据查询语言,用来查询数据库中的表的记录DCL数据控制语言,用来创建数据库、控制数据库的访问权限DDL语句DDL......
  • 滴水逆向笔记系列-win32总结10-63.IAT HOOK-64.Inline HOOK
    第六十三课IATHOOK这节课得把前面PE部分的IAT表复习好,再来做就简单多了1.IATHOOK是什么其实就是找到IAT表的位置再换成自己定义的函数,只是我们替换的函数需要和原函数的结构保持一直,比如我们要HOOKMessagebox函数,那么我们需要定义一个MyMessagebox函数,他的结构应该与Messa......