iOS手势密码的实现方法

 更新时间:2017年01月15日 10:09:22   作者:CUG  
这篇文章主要为大家详细介绍了iOS手势密码的实现方法,教会大家如何实现手势密码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本次讲的手势密码,是在九个按键上实现的,这里讲的是手势密码的基本实现和效果

同样先上效果图

其实就是对画图功能的一个实现,再加上手势操作结合起来。

屏幕宽度高度,方便下面操作,不做解释

#define ScreenHeight [[UIScreen mainScreen] bounds].size.height
#define ScreenWidth [[UIScreen mainScreen] bounds].size.width

控制器.m文件

这里的imageView是用来装手势画图之后的image,看后面就清楚了

@property (nonatomic,strong)NSMutableArray *buttonArr;//全部手势按键的数组
@property (nonatomic,strong)NSMutableArray *selectorArr;//选中手势按键的数组
@property (nonatomic,assign)CGPoint startPoint;//记录开始选中的按键坐标
@property (nonatomic,assign)CGPoint endPoint;//记录结束时的手势坐标
@property (nonatomic,strong)UIImageView *imageView;//画图所需
-(NSMutableArray *)selectorArr
{
  if (!_selectorArr) {
    _selectorArr = [[NSMutableArray alloc]init];
  }
  return _selectorArr;
}

添加九个按键,设置状态图片,实际开发中一般有三种状态,即默认,选中正确和选择错误,错误一般指的是我们要记录下用户的手势密码,需要用户。

画出两次相同的手势密码才能保存,若两次输入不一致,就是错误状态的一种,当然还包括其它的,不多说了。

这里要强调

 btn.userInteractionEnabled = NO;

这句的重要性,如果不关闭按键的用户交互,下面的UITouch则无法在按键中触发,所以这里必须关闭

- (void)viewDidLoad {
  [super viewDidLoad];
  self.view.backgroundColor = [UIColor whiteColor];

  
  if (!_buttonArr) {
    _buttonArr = [[NSMutableArray alloc]initWithCapacity:9];
  }
  
  self.imageView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, ScreenWidth, ScreenHeight)];
  [self.view addSubview:self.imageView];

  for (int i=0; i<3; i++) {
    for (int j=0; j<3; j++) {
      UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
      btn.frame = CGRectMake(ScreenWidth/12+ScreenWidth/3*j, ScreenHeight/3+ScreenWidth/3*i, ScreenWidth/6, ScreenWidth/6);
      [btn setImage:[UIImage imageNamed:@"pbg"] forState:UIControlStateNormal];
      [btn setImage:[UIImage imageNamed:@"pbg01"] forState:UIControlStateHighlighted];
      btn.userInteractionEnabled = NO;
      [self.buttonArr addObject:btn];
      [self.imageView addSubview:btn];
    }
    
  }
}

这个方法就是实现画图的方法

-(UIImage *)drawLine{
  UIImage *image = nil;
  
  UIColor *col = [UIColor colorWithRed:1 green:0 blue:0 alpha:1];
  UIGraphicsBeginImageContext(self.imageView.frame.size);//设置画图的大小为imageview的大小
  CGContextRef context = UIGraphicsGetCurrentContext();
  CGContextSetLineWidth(context, 5);
  CGContextSetStrokeColorWithColor(context, col.CGColor);
  
  CGContextMoveToPoint(context, self.startPoint.x, self.startPoint.y);//设置画线起点

  //从起点画线到选中的按键中心,并切换画线的起点
  for (UIButton *btn in self.selectorArr) {
    CGPoint btnPo = btn.center;
    CGContextAddLineToPoint(context, btnPo.x, btnPo.y);
    CGContextMoveToPoint(context, btnPo.x, btnPo.y);
  }
  //画移动中的最后一条线
  CGContextAddLineToPoint(context, self.endPoint.x, self.endPoint.y);
  
  CGContextStrokePath(context);
  
  image = UIGraphicsGetImageFromCurrentImageContext();//画图输出
  UIGraphicsEndImageContext();//结束画线
  return image;
}

最后部分是手势,每次在屏幕上点击的时候都会调用的方法

//开始手势
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
  UITouch *touch = [touches anyObject];//保存所有触摸事件
  if (touch) {
    
    
    for (UIButton *btn in self.buttonArr) {
      
      CGPoint po = [touch locationInView:btn];//记录按键坐标
      
      if ([btn pointInside:po withEvent:nil]) {//判断按键坐标是否在手势开始范围内,是则为选中的开始按键
        
        [self.selectorArr addObject:btn];
        btn.highlighted = YES;
        self.startPoint = btn.center;//保存起始坐标
      }
    
    }
    
  }
  
}

//移动中触发,画线过程中会一直调用画线方法
-(void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
  UITouch *touch = [touches anyObject];
  if (touch) {
    
    self.endPoint = [touch locationInView:self.imageView];
    for (UIButton *btn in self.buttonArr) {
      CGPoint po = [touch locationInView:btn];
      if ([btn pointInside:po withEvent:nil]) {
        
        BOOL isAdd = YES;//记录是否为重复按键
        for (UIButton *seBtn in self.selectorArr) {
          if (seBtn == btn) {
            isAdd = NO;//已经是选中过的按键,不再重复添加
            break;
          }
        }
        if (isAdd) {//未添加的选中按键,添加并修改状态
          [self.selectorArr addObject:btn];
          btn.highlighted = YES;
        }
        
      }
    }
  }
  self.imageView.image = [self drawLine];//每次移动过程中都要调用这个方法,把画出的图输出显示
  
}
//手势结束触发
-(void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
  self.imageView.image = nil;
  self.selectorArr = nil;
  for (UIButton *btn in self.buttonArr) {
    btn.highlighted = NO;
  }
}

开发中有时需要在最后时把画出的手势密码图显示保留一秒时,不能直接使用上面的画图image输出多一次,因为输出的连最后一条线都画出来了,如果要实现这个保留效果,可以在画线方法里添加一个是否画最后一条线的判断,加个bool传参,在画线结束时再调用这个方法和参数,禁止最后一条线画出来就行了,当然不能在画的过程禁止,而是在结束的时候,不然一条线都画不出的,最后把图片展示多次就行了。

需要的把btn和密码相关联,方法也有很多种,例如给btn设置tag值,把tag对应作为密码保存和验证就行了。

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

相关文章

  • 简单掌握iOS应用开发中sandbox沙盒的使用

    简单掌握iOS应用开发中sandbox沙盒的使用

    这篇文章主要介绍了iOS应用开发中sandbox沙盒的使用,即将应用的存储区域单独隔离开来,开发时经常可以用到,需要的朋友可以参考下
    2016-01-01
  • 仿iOS图标抖动

    仿iOS图标抖动

    最近闲来无聊,研究了一下IPhone桌面图标的抖动,网上有一个类似的事例,但是我看来效果实在不佳,自己也来写一个玩玩,有需要的小伙伴可以参考下。
    2015-05-05
  • ios触屏事件指南

    ios触屏事件指南

    这篇文章主要给大家总结介绍了2种实现ios触屏事件的方法,简单实用,有需要的小伙伴可以参考下。
    2015-05-05
  • iOS视频添加背景音乐同时保留原音

    iOS视频添加背景音乐同时保留原音

    本文主要介绍了iOS视频添加背景音乐同时保留原音的实现方法。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03
  • iOS开发中UIImageView控件的常用操作整理

    iOS开发中UIImageView控件的常用操作整理

    这篇文章主要介绍了iOS开发中UIImageView控件的常用操作整理,代码基于传统的Objective-C,需要的朋友可以参考下
    2016-01-01
  • iOS中遍历的方法总结

    iOS中遍历的方法总结

    本篇文章主要介绍了iOS中遍历的方法总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • iOS用UITextField切换明文/密文显示时末尾空白的问题解决

    iOS用UITextField切换明文/密文显示时末尾空白的问题解决

    最近在工作中遇到一个问题,利用UITextField切换明文/密文显示时发现字符串后面会出现一段空白,所以下面这篇文章主要给大家介绍了iOS用UITextField切换明文/密文显示时末尾空白问题的解决方法,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-05-05
  • ios 11和iphone x的相关适配问题及解决方法

    ios 11和iphone x的相关适配问题及解决方法

    这篇文章主要介绍了ios 11和iphone x的相关适配,文中给大家提到了在ios 11中,tableView会莫名偏移问题的解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-11-11
  • iOS开发项目- 基于WebSocket的聊天通讯(1)

    iOS开发项目- 基于WebSocket的聊天通讯(1)

    这篇文章主要介绍了iOS开发项目- 基于WebSocket的聊天通讯,WebSocket是web通信方式的一种,有需要的可以了解一下。
    2016-11-11
  • iOS利用MJRefresh实现自定义刷新动画效果

    iOS利用MJRefresh实现自定义刷新动画效果

    本文主要介绍iOS 利用MJRefresh实现自定义动画的上拉刷新下拉加载效果,要想实现此功能,首先得有一套load的图片数组。接下来通过本文给大家详解介绍实现过程
    2017-02-02

最新评论