Android手势密码--设置和校验功能的实现代码

效果图如下,大家感觉不错请参考实现代码

具体代码如下所示:

private void setGesturePassword() {
 toggleMore.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
  @Override
  public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
   if (isChecked) {
//     UIUtils.toast("开启了手势密码", false);
//     sp.edit().putBoolean("isOpen", true).commit();
    String inputCode = sp.getString("inputCode", "");
    if (TextUtils.isEmpty(inputCode)) {//之前没有设置过
     new AlertDialog.Builder(MoreFragment.this.getActivity())
       .setTitle("设置手势密码")
       .setMessage("是否现在设置手势密码")
       .setPositiveButton("确定", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
         UIUtils.toast("现在设置手势密码", false);
         sp.edit().putBoolean("isOpen", true).commit();
//           toggleMore.setChecked(true);
         //开启新的activity:
         ((BaseActivity) MoreFragment.this.getActivity()).goToActivity(GestureEditActivity.class, null);
        }
       })
       .setNegativeButton("取消", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
         UIUtils.toast("取消了现在设置手势密码", false);
         sp.edit().putBoolean("isOpen", false).commit();
         toggleMore.setChecked(false);
        }
       })
       .show();
    } else {
     UIUtils.toast("开启手势密码", false);
     sp.edit().putBoolean("isOpen", true).commit();
//      toggleMore.setChecked(true);
    }
   } else {
    UIUtils.toast("关闭了手势密码", false);
    sp.edit().putBoolean("isOpen", false).commit();
//     toggleMore.setChecked(false);
   }
  }
 });
}
private void resetGesture() {
 tvMoreReset.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
   boolean checked = toggleMore.isChecked();
   if (checked) {
    ((BaseActivity) MoreFragment.this.getActivity()).goToActivity(GestureEditActivity.class, null);
   } else {
    UIUtils.toast("手势密码操作已关闭,请开启后再设置", false);
   }
  }
 });
}

GestureEditActivity:

import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.text.Html;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.FrameLayout;
import android.widget.TextView;
import android.widget.Toast;
import com.atguigu.gesturelock.widget.GestureContentView;
import com.atguigu.gesturelock.widget.GestureDrawline;
import com.atguigu.gesturelock.widget.LockIndicator;
import com.atguigu.p2pinvest0828.R;
public class GestureEditActivity extends Activity implements View.OnClickListener {
 /**
  * 手机号码
  */
 public static final String PARAM_PHONE_NUMBER = "PARAM_PHONE_NUMBER";
 /**
  * 意图
  */
 public static final String PARAM_INTENT_CODE = "PARAM_INTENT_CODE";
 /**
  * 首次提示绘制手势密码,可以选择跳过
  */
 public static final String PARAM_IS_FIRST_ADVICE = "PARAM_IS_FIRST_ADVICE";
 private TextView mTextTitle;
 private TextView mTextCancel;
 private LockIndicator mLockIndicator;
 private TextView mTextTip;
 private FrameLayout mGestureContainer;
 private GestureContentView mGestureContentView;
 private TextView mTextReset;
 private String mParamSetUpcode = null;
 private String mParamPhoneNumber;
 private boolean mIsFirstInput = true;
 private String mFirstPassword = null;
 private String mConfirmPassword = null;
 private int mParamIntentCode;
 private SharedPreferences mSharedPreferences = null;
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_gesture_edit);
  setUpViews();
  setUpListeners();
 }
 private void setUpViews() {
  mTextTitle = (TextView) findViewById(R.id.text_title);
  mTextCancel = (TextView) findViewById(R.id.text_cancel);
  mTextReset = (TextView) findViewById(R.id.text_reset);
  mTextReset.setClickable(false);
  mLockIndicator = (LockIndicator) findViewById(R.id.lock_indicator);
  mTextTip = (TextView) findViewById(R.id.text_tip);
  mGestureContainer = (FrameLayout) findViewById(R.id.gesture_container);
  mSharedPreferences = this.getSharedPreferences("secret_protect", Context.MODE_PRIVATE);
  // 初始化一个显示各个点的viewGroup
  mGestureContentView = new GestureContentView(this, false, "", new GestureDrawline.GestureCallBack() {
   @Override
   public void onGestureCodeInput(String inputCode) {
    if (!isInputPassValidate(inputCode)) {
     mTextTip.setText(Html.fromHtml("<font color='#c70c1e'>最少链接4个点, 请重新输入</font>"));
     mGestureContentView.clearDrawlineState(0L);
     return;
    }
    if (mIsFirstInput) {
     mFirstPassword = inputCode;
     updateCodeList(inputCode);
     mGestureContentView.clearDrawlineState(0L);
     mTextReset.setClickable(true);
     mTextReset.setText(getString(R.string.reset_gesture_code));
    } else {
     if (inputCode.equals(mFirstPassword)) {
      Toast.makeText(GestureEditActivity.this, "设置成功", Toast.LENGTH_SHORT).show();
      mGestureContentView.clearDrawlineState(0L);
      GestureEditActivity.this.finish();
     } else {
      mTextTip.setText(Html.fromHtml("<font color='#c70c1e'>与上一次绘制不一致,请重新绘制</font>"));
      // 左右移动动画
      Animation shakeAnimation = AnimationUtils.loadAnimation(GestureEditActivity.this, R.anim.shake);
      mTextTip.startAnimation(shakeAnimation);
      // 保持绘制的线,1.5秒后清除
      mGestureContentView.clearDrawlineState(1300L);
     }
    }
    mIsFirstInput = false;
   }
   @Override
   public void checkedSuccess() {
   }
   @Override
   public void checkedFail() {
   }
  });
  // 设置手势解锁显示到哪个布局里面
  mGestureContentView.setParentView(mGestureContainer);
  updateCodeList("");
 }
 private void setUpListeners() {
  mTextCancel.setOnClickListener(this);
  mTextReset.setOnClickListener(this);
 }
 private void updateCodeList(String inputCode) {
  // 更新选择的图案
  mLockIndicator.setPath(inputCode);
  mSharedPreferences.edit().putString("inputCode",inputCode).commit();
  Log.e("TAG", "inputCode = " + inputCode);
 }
 @Override
 public void onClick(View v) {
  switch (v.getId()) {
   case R.id.text_cancel:
    this.finish();
    break;
   case R.id.text_reset:
    mIsFirstInput = true;
    updateCodeList("");
    mTextTip.setText(getString(R.string.set_gesture_pattern));
    break;
   default:
    break;
  }
 }
 private boolean isInputPassValidate(String inputPassword) {
  if (TextUtils.isEmpty(inputPassword) || inputPassword.length() < 4) {
   return false;
  }
  return true;
 }
}

我的界面中:

//判断一下,是否开启了手势密码。如果开启:先输入手势密码
SharedPreferences sp = this.getActivity().getSharedPreferences("secret_protect", Context.MODE_PRIVATE);
boolean isOpen = sp.getBoolean("isOpen", false);
if(isOpen){
 ((BaseActivity)this.getActivity()).goToActivity(GestureVerifyActivity.class,null);
 return;
}

GestureVerifyActivity:

import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.text.Html;
import android.text.TextUtils;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.FrameLayout;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;
import android.widget.Toast;
import com.atguigu.gesturelock.widget.GestureContentView;
import com.atguigu.gesturelock.widget.GestureDrawline;
import com.atguigu.p2pinvest0828.R;
public class GestureVerifyActivity extends Activity implements View.OnClickListener {
 /** 手机号码*/
 public static final String PARAM_PHONE_NUMBER = "PARAM_PHONE_NUMBER";
 /** 意图 */
 public static final String PARAM_INTENT_CODE = "PARAM_INTENT_CODE";
 private RelativeLayout mTopLayout;
 private TextView mTextTitle;
 private TextView mTextCancel;
 private ImageView mImgUserLogo;
 private TextView mTextPhoneNumber;
 private TextView mTextTip;
 private FrameLayout mGestureContainer;
 private GestureContentView mGestureContentView;
 private TextView mTextForget;
 private TextView mTextOther;
 private String mParamPhoneNumber;
 private long mExitTime = 0;
 private int mParamIntentCode;
 private SharedPreferences mSharedPreferences;
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_gesture_verify);
  ObtainExtraData();
  setUpViews();
  setUpListeners();
 }
 private void ObtainExtraData() {
  mParamPhoneNumber = getIntent().getStringExtra(PARAM_PHONE_NUMBER);
  mParamIntentCode = getIntent().getIntExtra(PARAM_INTENT_CODE, 0);
  mSharedPreferences = this.getSharedPreferences("secret_protect", Context.MODE_PRIVATE);
 }
 private void setUpViews() {
  mTopLayout = (RelativeLayout) findViewById(R.id.top_layout);
  mTextTitle = (TextView) findViewById(R.id.text_title);
  mTextCancel = (TextView) findViewById(R.id.text_cancel);
  mImgUserLogo = (ImageView) findViewById(R.id.user_logo);
  mTextPhoneNumber = (TextView) findViewById(R.id.text_phone_number);
  mTextTip = (TextView) findViewById(R.id.text_tip);
  mGestureContainer = (FrameLayout) findViewById(R.id.gesture_container);
  mTextForget = (TextView) findViewById(R.id.text_forget_gesture);
  mTextOther = (TextView) findViewById(R.id.text_other_account);
  String inputCode = mSharedPreferences.getString("inputCode","1235789");
  // 初始化一个显示各个点的viewGroup
  mGestureContentView = new GestureContentView(this, true, inputCode,
    new GestureDrawline.GestureCallBack() {
     @Override
     public void onGestureCodeInput(String inputCode) {
     }
     @Override
     public void checkedSuccess() {
      mGestureContentView.clearDrawlineState(0L);
      Toast.makeText(GestureVerifyActivity.this, "密码正确", Toast.LENGTH_SHORT).show();
      GestureVerifyActivity.this.finish();
     }
     @Override
     public void checkedFail() {
      mGestureContentView.clearDrawlineState(1300L);
      mTextTip.setVisibility(View.VISIBLE);
      mTextTip.setText(Html.fromHtml("<font color='#c70c1e'>密码错误</font>"));
      // 左右移动动画
      Animation shakeAnimation = AnimationUtils.loadAnimation(GestureVerifyActivity.this, R.anim.shake);
      mTextTip.startAnimation(shakeAnimation);
     }
    });
  // 设置手势解锁显示到哪个布局里面
  mGestureContentView.setParentView(mGestureContainer);
 }
 private void setUpListeners() {
  mTextCancel.setOnClickListener(this);
  mTextForget.setOnClickListener(this);
  mTextOther.setOnClickListener(this);
 }
 private String getProtectedMobile(String phoneNumber) {
  if (TextUtils.isEmpty(phoneNumber) || phoneNumber.length() < 11) {
   return "";
  }
  StringBuilder builder = new StringBuilder();
  builder.append(phoneNumber.subSequence(0,3));
  builder.append("****");
  builder.append(phoneNumber.subSequence(7,11));
  return builder.toString();
 }
 @Override
 public void onClick(View v) {
  switch (v.getId()) {
   case R.id.text_cancel:
    this.finish();
    break;
   default:
    break;
  }
 }
}

总结

以上所述是小编给大家介绍的Android手势密码--设置和校验功能的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • Android手势密码的实现

    一.大致界面介绍: 图1 图2 图3 图4 图1:手势密码绘制界面 [主要是绘制上方的9个提示图标和9个宫格密码图标] 图2:设置手势密码 [监听手势的输入,TouchEvent的事件处理,获取输入的手势密码,同时显示在上方的提示区域] 图3:再绘制一次,两次密码不一致提示界面 [这里在实现的时候,错误提示文字加了"左右晃动的动画",错误路径颜色标记为红色] 图4:校验手势密码,输入的密码错误,给予红色路径+错误文字提示 二.实现思路: 1. 正上方的提示区域,用一个类(LockInd

  • Android自定义控件实现手势密码

    Android手势解锁密码效果图 首先呢想写这个手势密码的想法呢,完全是凭空而来的,然后笔者就花了一天时间弄出来了.本以为这个东西很简单,实际上手的时候发现,还有很多逻辑需要处理,稍不注意就容易乱套.写个UI效果图大约只花了3个小时,但是处理逻辑就处理了2个小时!废话不多说,下面开始讲解.      楼主呢,自己比较自定义控件,什么东西都掌握在自己的手里感觉那是相当不错(对于赶工期的小伙瓣儿们还是别手贱了,非常容易掉坑),一有了这个目标,我就开始构思实现方式.      1.整个自定义控件是继承

  • Android手势密码实现实例代码

    一.效果实现 二.实现思路: 1. 正上方的提示区域,用一个类(LockIndicator.java)来实现,自定义view来绘制9个提示图标: 2. 手势密码绘制区域,用一个类(GestureContentView.java)来实现,它继承自ViewGroup里面, 添加9个ImageView来表示图标, 在onLayout()方法中设置它们的位置: 3. 手势路径绘制, 用一个类(GestureDrawline.java)来实现,复写onTouchEvent()方法,在这个方法里面监听Tou

  • Android自定义UI手势密码简单版

    先看看效果图: ImageLockActivity package com.example.imagelock; import com.example.view.NinePointLineView; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.View; public class ImageLockActivity extends Acti

  • Android 简易手势密码开源库详解

    简介 本文介绍一个Android手势密码开源库的使用及实现的详细过程,该开源库主要实现以下几个功能: 支持手势密码的绘制,并支持密码保存功能,解锁时自动比对密码给出结果 封装了绘制密码的方法,比对两次密码是否一致,可以快捷地进行手势密码的设置 可以设置密码输入错误后的重试次数上限 可以自定义不同状态下手势密码图案的颜色 可以自定义手势密码的触摸点数量(n*n) 最近需要用到手势密码解锁功能,找了一些demo感觉用起来都有点麻烦,于是参考一些文章自己造了下轮子,封装了相关的一些方法,使用起来比较便

  • Android九宫格手势密码代码设计

    最近因为项目需要用到九宫格密码(也叫手势轨迹密码),特地去学习了一下九宫格密码的实现原来.可能有人认为九宫格密码事例网上到处都有,很多甚至直接拷贝过来就可以运行为什么还要学习呢.还特地写到网上有必要吗?其实写这个目的是为了增强和锻炼自己的语言组织能力.其实如果只是既然是学习就不光是要知道答案(完成效果)更重要的是知道他什么实现. 好了题外话就不多说了,要实现九宫格密码要解决的问题有: 1.给九宫格密码界面布局九个点,即确定每个节点的位置.每个点到上下左右的距离都是相同的.即九个点刚好围成一个正方

  • Android仿支付宝手势密码解锁功能

    Starting 创建手势密码可以查看 CreateGestureActivity.java 文件. 登陆验证手势密码可以看 GestureLoginActivity.java 文件. Features 使用了 JakeWharton/butterknife butterknife 使用了 ACache 来存储手势密码 /** * 保存手势密码 */ private void saveChosenPattern(List<LockPatternView.Cell> cells) { byte[

  • Android自定义UI手势密码改进版源码下载

    在之前文章的铺垫下,再为大家分享一篇:Android手势密码,附源码下载,不要错过. 源码下载:http://xiazai.jb51.net/201610/yuanma/androidLock(jb51.net).rar 先看第一张图片的布局文件 activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://sc

  • Android自定义UI手势密码终结版

    之前写过3篇手势密码的demo,不过没有集成到真实的企业项目中,这几天正好领到一个手势密码项目,昨天刚好弄完,今天抽空整理下,目前还没有完善,有一些地方需要更改,不过基本的流程都可以跑通了. 源码下载地址:http://xiazai.jb51.net/201610/yuanma/AndroidGestureLock(jb51.net).rar 先看主界面的入口把.里面有2个button(一个是设置手势密码.一个是校验手势密码) activity_main.xml <RelativeLayout

  • Android手势密码--设置和校验功能的实现代码

    效果图如下,大家感觉不错请参考实现代码 具体代码如下所示: private void setGesturePassword() { toggleMore.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (isChecke

  • Android手势密码view学习笔记(一)

    刚接触Android的时候看到别人写的手势密码view,然后当时就在想,我什么时候才能写出如此高端的东西?? 没关系,不要怕哈,说出这样话的人不是你技术不咋地而是你不愿意花时间去研究它,其实也没有那么难哦(世上无难事,只怕有心人!),下面我们就一步一步实现一个手势密码view. 想必都看过手势密码view,但我们还是看看我们今天要实现的效果吧: 上面是一个手势view的提示view,下面是一个手势view. 用法: <com.leo.library.view.GestureContentView

  • Android手势密码view学习笔记(二)

    我们还是接着我们上一篇博客中的内容往下讲哈,上一节 Android手势密码view笔记(一)我们已经实现了我们的IndicatorView指示器view了: 下面我们来实现下我们的手势密码view: 实现思路: 1.我们照样需要拿到用户需要显示的一些属性(行.列.选中的图片.未选中的图片.错误显示的图片.连接线的宽度跟颜色......). 2.我们需要根据手势的变换然后需要判断当前手指位置是不是在某个点中,在的话就把该点设置为选中状态,然后每移动到两个点(也就是一个线段)就记录该两个点. 3.最

  • Android微信右滑退出功能的实现代码

    先给大家展示下效果图,如果大家感觉效果不错,请参考实例代码, act2是Main2Activity,act3是Main3Activity 原理 滚动 首先我们知道每个Activity展示的内容一般都是DecorView去承载的,不知道的看下图,其中状态栏背景也包括在内: DecorView 所以我们第一步,只需要滚动DecorView内容或者平移DecorView就行了. 使上一个Activity可见 上面的Activity不可见其实是因为被当前Activity给挡住了.那问题来了. Q:为什么

  • Android Filterable实现Recyclerview筛选功能的示例代码

    原先碰到筛选这种功能时,后端的接口都会让上传一个字段,根据字段来返回相应的数据.后来一次和别人对接时,接口直接返回全部数据,而且还要实现筛选功能.我...我说不就是一条sql语句的事,改接口多方便,我苦心劝导,然后被怼回来,切,不就是筛选嘛,求人不如自己搞. 1. 效果图 2. 思路 既然是筛选,那就少不了比较.也没有什么好的办法,无非就是循环对比,然后将适配器进行数据更新.页面刷新即可.但筛选的调用要方便,怎么比较才方便我们调用呢?偶然间看到了Filterable,使Adapter继承自该接口

  • Android 实现文件夹排序功能的实例代码

    按文件名排序 /** * 按文件名排序 * @param filePath */ public static ArrayList<String> orderByName(String filePath) { ArrayList<String> FileNameList = new ArrayList<String>(); File file = new File(filePath); File[] files = file.listFiles(); List fileL

  • Android 实现自定义圆形listview功能的实例代码

    最近遇到一个需求需要圆形listview作为悬浮窗,费了九牛二虎之力终于开发出来了,特别有成就感,下面分享下案例,项目原因,只能分享一部分供大家参考 1.有图有真相 下面就来讲解下代码: 1.自定义listview import android.content.Context; import android.content.res.TypedArray; import android.graphics.Bitmap; import android.graphics.BitmapFactory;

  • Android使用AlarmManager设置闹钟功能

    本文实例为大家分享了Android使用AlarmManager设置闹钟的具体代码,供大家参考,具体内容如下 一.首先创建设置闹钟的布局页面activity_alarm_manager.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"     xm

随机推荐