广告
返回顶部
首页 > 资讯 > 精选 >如何在Android中实现一个滑块拼图验证码功能
  • 510
分享到

如何在Android中实现一个滑块拼图验证码功能

2023-06-06 12:06:20 510人浏览 独家记忆
摘要

本篇文章给大家分享的是有关如何在Android中实现一个滑块拼图验证码功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、实现步骤:定义自定义属性; 2、确认目标位置,这里使

本篇文章给大家分享的是有关如何在Android中实现一个滑块拼图验证码功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

一、实现步骤:

定义自定义属性; 2、确认目标位置,这里使用的是阴影图片来遮盖背景图片; 3、创建与目标位置相结合的滑块图片; 4、设置目标阴影图片和滑块图片可以随机旋转,并保持一致; 5、创建拖拽条,使滑块随着拖拽条的拖拽而移动; 6、判断是否验证成功。

二、实现流程:

定义自定义属性 创建一个attr文件来定义一些自定义属性

   <declare-styleable name="ImageAuthenticationView">    <!--滑块的高度-->    <attr name="unitHeight" fORMat="dimension" />    <!--滑块的宽度-->    <attr name="unitWidth" format="dimension" />    <!--滑块占图片高度的比例-->    <attr name="unitHeightScale" format="integer" />    <!--滑块占图片宽度的比例-->    <attr name="unitWidthScale" format="integer" />    <!--滑块边框的图片资源-->    <attr name="unitShadeSrc" format="reference" />    <!--阴影部分的图片资源-->    <attr name="unitShowSrc" format="reference" />    <!--是否需要旋转-->    <attr name="needRotate" format="boolean" />    <!--验证时的误差值-->    <attr name="deviate" format="integer" />  </declare-styleable>

确认目标位置,这里使用的是阴影图片来遮盖背景图片

   private Bitmap drawTargetBitmap() {    // 绘制图片    Bitmap showB;    if (null != mShowBp) {      showB = handleBitmap(mShowBp, mUintWidth, mUintHeight);    } else {      showB = handleBitmap(BitmapFactory.decodeResource(getResources(), R.mipmap.puzzle_show), mUintWidth, mUintHeight);    }    // 如果需要旋转图片,进行旋转,旋转后为了保持和滑块大小一致,需要重新缩放比例    if (needRotate) {      showB = handleBitmap(rotateBitmap(rotate, showB), mUintWidth, mUintHeight);    }    return showB;  }

创建与目标位置相结合的滑块图片

   private Bitmap drawResultBitmap(Bitmap bp) {    // 绘制图片    Bitmap shadeB;    if (null != mShadeBp) {      shadeB = handleBitmap(mShadeBp, mUintWidth, mUintHeight);    } else {      shadeB = handleBitmap(BitmapFactory.decodeResource(getResources(), R.mipmap.puzzle_shade), mUintWidth, mUintHeight);    }    // 如果需要旋转图片,进行旋转,旋转后为了和画布大小保持一致,避免出现图像显示不全,需要重新缩放比例    if (needRotate) {      shadeB = handleBitmap(rotateBitmap(rotate, shadeB), mUintWidth, mUintHeight);    }    Bitmap resultBmp = Bitmap.createBitmap(mUintWidth, mUintHeight,        Bitmap.Config.ARGB_8888);    Paint paint = new Paint();    paint.setAntiAlias(true);    canvas canvas = new Canvas(resultBmp);    canvas.drawBitmap(shadeB, new Rect(0, 0, mUintWidth, mUintHeight),        new Rect(0, 0, mUintWidth, mUintHeight), paint);    // 选择交集去上层图片    paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.MULTIPLY));    canvas.drawBitmap(bp, new Rect(0, 0, mUintWidth, mUintHeight),        new Rect(0, 0, mUintWidth, mUintHeight), paint);    return resultBmp;  }

设置目标阴影图片和滑块图片可以随机旋转,并保持一致

   public Bitmap rotateBitmap(int degree, Bitmap bitmap) {    Matrix matrix = new Matrix();    matrix.postRotate(degree);    Bitmap bm = Bitmap.createBitmap(bitmap, 0, 0, bitmap.getWidth(),        bitmap.getHeight(), matrix, true);    return bm;  }

创建拖拽条,使滑块随着拖拽条的拖拽而移动

  //滑块监听    mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {      @Override      public void onProgressChanged(SeekBar seekBar, int i, boolean b) {        //设置滑块移动距离        mDY.setUnitMoveDistance(mDY.getAverageDistance(seekBar.getMax()) * i);      }      @Override      public void onStartTrackingTouch(SeekBar seekBar) {      }      @Override      public void onStopTrackingTouch(SeekBar seekBar) {        //验证是否拼接成功        mDY.testPuzzle();      }    });

判断是否验证成功

  public void testPuzzle() {    if (Math.abs(mUnitMoveDistance - mUnitRandomX) <= DEFAULT_DEVIATE) {      if (null != mlistener) {        mlistener.onSuccess();      }    } else {      if (null != mlistener) {        mlistener.onFail();      }    }  }

三、完整代码

自定义控件内容太多这里就不放出来了,完整Demo源码会放在文章后面;

代码逻辑

public class MainActivity extends Activity {  //滑块  private SeekBar mSeekBar;  //自定义的控件  private ImageAuthenticationView mDY;  private Button btn;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    initView();    initListener();  }  private void initView() {    mDY = findViewById(R.id.dy_v);    mSeekBar = findViewById(R.id.sb_dy);    btn = findViewById(R.id.btn);  }  private void initListener() {    //滑块监听    mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {      @Override      public void onProgressChanged(SeekBar seekBar, int i, boolean b) {        //设置滑块移动距离        mDY.setUnitMoveDistance(mDY.getAverageDistance(seekBar.getMax()) * i);      }      @Override      public void onStartTrackingTouch(SeekBar seekBar) {      }      @Override      public void onStopTrackingTouch(SeekBar seekBar) {        //验证是否拼接成功        mDY.testPuzzle();      }    });    //控件监听    mDY.setPuzzleListener(new ImageAuthenticationView.onPuzzleListener() {      @Override      public void onSuccess() {        //mSeekBar.setEnabled(false);//禁止滑动        Toast.makeText(MainActivity.this, "验证成功", Toast.LENGTH_SHORT).show();      }      @Override      public void onFail() {        Toast.makeText(MainActivity.this, "验证失败", Toast.LENGTH_SHORT).show();        mSeekBar.setProgress(0);      }    });    //重置    btn.setOnClickListener(new View.OnClickListener() {      @Override      public void onClick(View v) {        //mSeekBar.setEnabled(true);        mSeekBar.setProgress(0);        mDY.reSet();      }    });  }}

布局文件

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android"  xmlns:dy="http://schemas.android.com/apk/res-auto"  xmlns:tools="http://schemas.android.com/tools"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:gravity="center"  android:orientation="vertical"  android:paddingLeft="10dp"  android:paddingTop="10dp"  android:paddingRight="10dp"  android:paddingBottom="10dp"  tools:context=".MainActivity">  <com.sjl.keeplive.slideImg.ImageAuthenticationView    android:id="@+id/dy_v"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:scaleType="centerCrop"    android:layout_marginBottom="10dp"    android:src="@mipmap/test"    dy:needRotate="true"    dy:unitHeight="60dp"    dy:unitShadeSrc="@mipmap/puzzle_shade"    dy:unitShowSrc="@mipmap/puzzle_show"    dy:unitWidth="80dp" />  <SeekBar    android:id="@+id/sb_dy"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:background="@drawable/bg_seekbar"    android:max="100" />  <Button    android:id="@+id/btn"    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:text="重置"/></LinearLayout>

以上就是如何在Android中实现一个滑块拼图验证码功能,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网精选频道。

--结束END--

本文标题: 如何在Android中实现一个滑块拼图验证码功能

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

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

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

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

下载Word文档
猜你喜欢
  • 如何在Android中实现一个滑块拼图验证码功能
    本篇文章给大家分享的是有关如何在Android中实现一个滑块拼图验证码功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、实现步骤:定义自定义属性; 2、确认目标位置,这里使...
    99+
    2023-06-06
  • Android 如何实现滑块拼图验证码功能
    本篇内容主要讲解“Android 如何实现滑块拼图验证码功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android 如何实现滑块拼图验证码功能”吧!本篇主要从两方面进行介绍:使用依赖库实现...
    99+
    2023-06-14
  • Android 简单的实现滑块拼图验证码功能
    目录实现过程:接下来我们对这个库进行介绍:实现滑块拼图验证码功能之前已经写过一篇了,上一篇使用的是自定义控件的方式实现这个功能,主要还是想让童鞋们知其然更知其所以然,还没看的童鞋可以...
    99+
    2022-11-11
  • JavaScript实现拼图式滑块验证功能
    目录演示前戏源码介绍主页样式设计滑块验证部分img_ver内部演示 前戏 滑块验证码是在网站、APP等应用中常见的一种验证方式,通过按照一定规则滑动滑块到指定位置完成验证,才可以进...
    99+
    2022-11-13
  • JavaScript如何实现拼图式滑块验证功能
    这篇文章主要介绍“JavaScript如何实现拼图式滑块验证功能”,在日常操作中,相信很多人在JavaScript如何实现拼图式滑块验证功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript如...
    99+
    2023-07-02
  • C#滑动验证码拼图验证功能实现(SlideCaptcha)
    目录使用背景:实现分析:后端代码:准备:使用:前端代码:结语:使用背景: 关于滑动验证码的使用场所还是非常多的,如:调取短信接口之前,和 注册请求之前 或者 频繁会调用的接口都需要加...
    99+
    2022-11-13
  • JavaScript实现拖动滑块拼图验证功能(html5、canvas)
    引言: 滑块拖动验证现在很多地方都用到,周末就琢磨着写了一个,放上来,看看有没有人用得上! 效果: 实现思路:  用一张画布绘制源图,再绘制一个填充的方形,这样就可以达到...
    99+
    2022-11-11
  • 使用python 怎么实现一个滑块验证码识别功能
    今天就跟大家聊聊有关使用python 怎么实现一个滑块验证码识别功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。普通滑动验证import timefrom se...
    99+
    2023-06-14
  • android实现一个图片验证码倒计时功能
    1.如图所示,要实现一个验证码的倒计时的效果                &n...
    99+
    2023-05-30
    android 验证码 倒计时
  • js canvas如何实现滑块验证功能
    本篇内容主要讲解“js canvas如何实现滑块验证功能 ”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js canvas如何实现滑块验证功能 ”吧!滑块验证内容如下话不多说先上代码想用的小伙伴...
    99+
    2023-06-14
  • 如何使用JavaScript实现滑块验证功能
    这篇文章将为大家详细讲解有关如何使用JavaScript实现滑块验证功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下<!DOCTYPE html><html&nb...
    99+
    2023-06-26
  • 如何在Android应用中实现一个侧滑功能
    本篇文章给大家分享的是有关如何在Android应用中实现一个侧滑功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。实现说明:通过自定义布局实现:SlidingLayout继承于...
    99+
    2023-05-31
    android roi
  • vue如何实现左滑图片验证功能
    这篇“vue如何实现左滑图片验证功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue如何实现左滑图片验证功能”文章吧。一...
    99+
    2023-07-05
  • php中怎么实现一个验证码功能
    php中怎么实现一个验证码功能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。新建一个captcha.php:php     /...
    99+
    2023-06-17
  • 怎么在Android应用中实现一个信验证码倒计时功能
    这篇文章将为大家详细讲解有关怎么在Android应用中实现一个信验证码倒计时功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。实现步骤:一个关键类:CountDownTimer(Androi...
    99+
    2023-05-31
    android roi
  • 使用.Net Core实现的一个图形验证码功能
    SimpleCaptcha是一个使用简单,基于.Net Standard 2.0的图形验证码模块。它的灵感来源于Edi.Wang的这篇文章https://edi.wang/post/...
    99+
    2022-11-12
  • 使用canvas怎么实现一个图形验证码功能
    本篇文章给大家分享的是有关使用canvas怎么实现一个图形验证码功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。<!DOCTYPE html><h...
    99+
    2023-06-09
  • Android应用中怎么实现一个验证码倒计时功能
    Android应用中怎么实现一个验证码倒计时功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。实现发送验证码的时候一般都会有一个按钮,点击之后便会给你输入的手机发送一条验证码,...
    99+
    2023-05-31
    android roi
  • 如何在Java中利用patchca实现一个验证码生成功能
    本篇文章为大家展示了如何在Java中利用patchca实现一个验证码生成功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。代码如下: @RequestMapping(value = {"...
    99+
    2023-05-31
    java patchca ava
  • 怎么在Android中利用控件实现一个验证码倒计时功能
    这期内容当中小编将会给大家带来有关怎么在Android中利用控件实现一个验证码倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用方式<com.landptf.view.CountDownM...
    99+
    2023-05-31
    android roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作