iOS使用OC語言動態(tài)生成本地圖片驗證碼

????前段時間項目中要做一個本地圖片驗證碼功能,然后寫了個demo 【demo在此,歡迎star】致讥,源碼講解如下:

先來一張效果圖壓壓驚
界面效果.png
輸出的驗證碼.png

一、自定義View,封裝驗證碼方法

1仇味、在KenCodeView.h里面主要是,聲明一些屬性和方法,屬性有:字符數(shù)組,驗證碼字符串和展示驗證碼的label,在這里聲明的改變驗證碼的方法是為了一會兒在Controller中調用的夷家。

#import <UIKit/UIKit.h>

@interface KenCodeView : UIView

@property (nonatomic, retain) NSArray *changeArray;//驗證碼需要的字符組成數(shù)組
@property (nonatomic, retain) NSMutableString *changeString;//展示的驗證碼字符串
@property (nonatomic, retain) UILabel *codeLabel;//展示驗證碼字符串的label

//改變驗證碼的方法,controller中調用
-(void)changeCode;

@end

2抽高、KenCodeView.m中初始化時調用的方法,設置了隨機的背景顏色,并調用組成驗證碼字符方法。

//初始化時調用
- (id)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
        float red = arc4random() % 100 / 100.0;
        float green = arc4random() % 100 / 100.0;
        float blue = arc4random() % 100 / 100.0;
        UIColor *color = [UIColor colorWithRed:red green:green blue:blue alpha:0.2];
        //隨機背景顏色
        self.backgroundColor = color;
        //調用組成字符的方法
        [self change];
    }
    return self;
}

3、這是生成驗證碼的方法,當中調用生成驗證碼的字符方法,setNeedsDisplay是調用drawRect方法,所以Controller中只需要調用這個方法就可以重新生成驗證碼鞭呕。

//Controller中調用此方法可更換驗證碼
-(void)changeCode{
    //調用組成字符的方法
    [self change];
    //顯示
    [self setNeedsDisplay];
}

4、這是生成驗證碼的字符方法,根據(jù)你的需求進行素材組合和字符控制,我這兒是4個字符的例子,用self.changString進行接收這個驗證碼字符宛官。

//組成驗證碼字符的方法
- (void)change
{
    //驗證碼字符素材
    self.changeArray = [[NSArray alloc] initWithObjects:@"0",@"1",@"2",@"3",@"4",@"5",@"6",@"7",@"8",@"9",@"A",@"B",@"C",@"D",@"E",@"F",@"G",@"H",@"I",@"J",@"K",@"L",@"M",@"N",@"O",@"P",@"Q",@"R",@"S",@"T",@"U",@"V",@"W",@"X",@"Y",@"Z",@"a",@"b",@"c",@"d",@"e",@"f",@"g",@"h",@"i",@"j",@"k",@"l",@"m",@"n",@"o",@"p",@"q",@"r",@"s",@"t",@"u",@"v",@"w",@"x",@"y",@"z",nil];
    
    NSMutableString *getStr = [[NSMutableString alloc] initWithCapacity:5];
    
    self.changeString = [[NSMutableString alloc] initWithCapacity:6];
    
    //隨機從數(shù)組中選取需要個數(shù)的字符串(我選的4)葫松,拼接為驗證碼字符,最終的字符串用self.changeString接收
    for(NSInteger i = 0; i < 4; i++)
    {
        NSInteger index = arc4random() % ([self.changeArray count] - 1);
        getStr = [self.changeArray objectAtIndex:index];
        //這是隨機的驗證碼字符串
        self.changeString = (NSMutableString *)[self.changeString stringByAppendingString:getStr];
    }
}

5底洗、好!關鍵的方法來了,這個方法是通過setNeedsDisplay來調用的,是繪制方法.我這里面主要代碼都有注釋,請詳細觀看!

//繪制
- (void)drawRect:(CGRect)rect {
    [super drawRect:rect];
    
    float red = arc4random() % 100 / 100.0;
    float green = arc4random() % 100 / 100.0;
    float blue = arc4random() % 100 / 100.0;
    
    UIColor *color = [UIColor colorWithRed:red green:green blue:blue alpha:0.5];
    //隨機背景顏色腋么,因為重新更換驗證碼也要走這個方法,所以設置背景顏色
    [self setBackgroundColor:color];
    
    //根據(jù)要顯示的驗證碼字符串亥揖,根據(jù)長度珊擂,計算每個字符串顯示的位置
    NSString *text = [NSString stringWithFormat:@"%@",self.changeString];
    CGSize cSize = [@"S" sizeWithFont:[UIFont systemFontOfSize:20]];
    int width = rect.size.width / text.length - cSize.width;
    int height = rect.size.height - cSize.height;
    CGPoint point;
    //依次繪制每一個字符,可以設置顯示的每個字符的字體大小、顏色未玻、樣式等
    float pX, pY;
    for (int i = 0; i < text.length; i++)
    {
        pX = arc4random() % width + rect.size.width / text.length * i;
        pY = arc4random() % height;
        point = CGPointMake(pX, pY);
        unichar c = [text characterAtIndex:i];
        NSString *textC = [NSString stringWithFormat:@"%C", c];
        [textC drawAtPoint:point withFont:[UIFont systemFontOfSize:20]];
    }
    
    //調用drawRect之前灾而,系統(tǒng)會向棧中壓入一個CGContextRef,調用UIGraphicsGetCurrentContext()會取棧頂?shù)腃GContextRef
    CGContextRef context = UIGraphicsGetCurrentContext();
    //設置線條的寬度
    CGContextSetLineWidth(context, 1.0);
    //繪制干擾線
    for(int cout = 0; cout < 10; cout++)
    {
        red = arc4random() % 100 / 100.0;
        green = arc4random() % 100 / 100.0;
        blue = arc4random() % 100 / 100.0;
        color = [UIColor colorWithRed:red green:green blue:blue alpha:0.2];
        //設置線條填充色
        CGContextSetStrokeColorWithColor(context, [color CGColor]);
        //設置線的起點
        pX = arc4random() % (int)rect.size.width;
        pY = arc4random() % (int)rect.size.height;
        CGContextMoveToPoint(context, pX, pY);
        //設置線的終點
        pX = arc4random() % (int)rect.size.width;
        pY = arc4random() % (int)rect.size.height;
        CGContextAddLineToPoint(context, pX, pY);
        //畫線
        CGContextStrokePath(context);
    }
}

二扳剿、Controller中調用代碼

1旁趟、在ViewController.m里面首先導入KenCodeView,并在ViewDidLoad中初始化庇绽;

//初始化剛剛封裝過的KenCodeView
_KenCodeView = [[KenCodeView alloc] initWithFrame:CGRectMake(50, 100, 82, 32)];

//創(chuàng)建輕擊手勢
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapClick:)];
[_KenCodeView addGestureRecognizer:tap];

[self.view addSubview:_KenCodeView];

2锡搜、實現(xiàn)輕擊手勢事件,點擊調用更換驗證碼的方法

//輕擊手勢事件
- (void)tapClick:(UITapGestureRecognizer*)tap{
    //調用更換驗證碼的方法
    [_KenCodeView changeCode];
    //輸出目前驗證碼的字符
    NSLog(@"%@",_KenCodeView.changeString);
}
以上是該demo源碼詳解瞧掺,到此結束 【歡迎star】耕餐。
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市辟狈,隨后出現(xiàn)的幾起案子肠缔,更是在濱河造成了極大的恐慌,老刑警劉巖哼转,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件明未,死亡現(xiàn)場離奇詭異,居然都是意外死亡壹蔓,警方通過查閱死者的電腦和手機趟妥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來佣蓉,“玉大人披摄,你說我怎么就攤上這事∮缕荆” “怎么了疚膊?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長套像。 經(jīng)常有香客問我酿联,道長,這世上最難降的妖魔是什么夺巩? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任贞让,我火速辦了婚禮,結果婚禮上柳譬,老公的妹妹穿的比我還像新娘喳张。我一直安慰自己,他們只是感情好美澳,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布销部。 她就那樣靜靜地躺著摸航,像睡著了一般。 火紅的嫁衣襯著肌膚如雪舅桩。 梳的紋絲不亂的頭發(fā)上酱虎,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音擂涛,去河邊找鬼读串。 笑死,一個胖子當著我的面吹牛撒妈,可吹牛的內容都是我干的恢暖。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼狰右,長吁一口氣:“原來是場噩夢啊……” “哼杰捂!你這毒婦竟也來了?” 一聲冷哼從身側響起棋蚌,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤嫁佳,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后附鸽,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體脱拼,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年坷备,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片情臭。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡省撑,死狀恐怖,靈堂內的尸體忽然破棺而出俯在,到底是詐尸還是另有隱情竟秫,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布跷乐,位于F島的核電站肥败,受9級特大地震影響,放射性物質發(fā)生泄漏愕提。R本人自食惡果不足惜馒稍,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望浅侨。 院中可真熱鬧纽谒,春花似錦、人聲如沸如输。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 我被黑心中介騙來泰國打工井濒, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人慎陵。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓眼虱,卻偏偏與公主長得像,于是被迫代替她去往敵國和親席纽。 傳聞我的和親對象是個殘疾皇子捏悬,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355