ios開發(fā)-點(diǎn)擊修改頭像

#import"ViewController.h"

@interfaceViewController()

@property(strong,nonatomic)IBOutletUIImageView*myHeadPortrait;

@end

@implementationViewController

- (void)viewDidLoad

{??

[superviewDidLoad];

//? 調(diào)用setHeadPortrait方法

[selfsetHeadPortrait];

}

#pragma mark - 設(shè)置頭像-(void)setHeadPortrait {? ? //? ? //? 把頭像設(shè)置成圓形//? ? self.iconImg.layer.cornerRadius=self.iconImg.frame.size.width/2;//? ? self.iconImg.layer.masksToBounds=YES;? ? //? 給頭像加一個(gè)圓形邊框? ? self.iconImg.layer.borderWidth = 1.5f;? ? self.iconImg.layer.borderColor = [UIColor whiteColor].CGColor;? ? /**? ? *? 添加手勢(shì):也就是當(dāng)用戶點(diǎn)擊頭像了之后梨与,對(duì)這個(gè)操作進(jìn)行反應(yīng)? ? */? ? //允許用戶交互? ? _iconImg.userInteractionEnabled = YES;? ? //初始化一個(gè)手勢(shì)? ? UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc]initWithTarget:self? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? action:@selector(alterHeadPortrait:)];? ? //給imageView添加手勢(shì)? ? [_iconImg addGestureRecognizer:singleTap];? ? }//? 方法:alterHeadPortrait-(void)alterHeadPortrait:(UITapGestureRecognizer *)gesture{? ? /**? ? ? *? 彈出提示框? ? ? */? ? //初始化提示框? ? UIAlertController *alert = [UIAlertController alertControllerWithTitle:nil message:nil preferredStyle:UIAlertControllerStyleActionSheet];? ? //按鈕:從相冊(cè)選擇如贷,類型:UIAlertActionStyleDefault? ? [alert addAction:[UIAlertAction actionWithTitle:@"從相冊(cè)選擇" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {? ? ? ? ? //初始化UIImagePickerController? ? ? ? ? UIImagePickerController *PickerImage = [[UIImagePickerController alloc]init];? ? ? ? ? //獲取方式1:通過相冊(cè)(呈現(xiàn)全部相冊(cè))尚猿,UIImagePickerControllerSourceTypePhotoLibrary? ? ? ? ? //獲取方式2楣富,通過相機(jī)纹蝴,UIImagePickerControllerSourceTypeCamera? ? ? ? ? //獲取方法3塘安,通過相冊(cè)(呈現(xiàn)全部圖片)忍捡,UIImagePickerControllerSourceTypeSavedPhotosAlbum? ? ? ? ? PickerImage.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;? ? ? ? ? //允許編輯砸脊,即放大裁剪? ? ? ? ? PickerImage.allowsEditing = YES;? ? ? ? ? //自代理? ? ? ? ? PickerImage.delegate = self;? ? ? ? ? //頁面跳轉(zhuǎn)? ? ? ? ? [self presentViewController:PickerImage animated:YES completion:nil];? ? }]];? ? //按鈕:拍照,類型:UIAlertActionStyleDefault? ? [alert addAction:[UIAlertAction actionWithTitle:@"拍照" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action){? ? ? ? ? /**? ? ? ? ? 其實(shí)和從相冊(cè)選擇一樣,只是獲取方式不同埃疫,前面是通過相冊(cè)熔恢,而現(xiàn)在臭笆,我們要通過相機(jī)的方式? ? ? ? ? */? ? ? ? ? UIImagePickerController *PickerImage = [[UIImagePickerController alloc]init];? ? ? ? ? //獲取方式:通過相機(jī)? ? ? ? ? PickerImage.sourceType = UIImagePickerControllerSourceTypeCamera;? ? ? ? ? PickerImage.allowsEditing = YES;? ? ? ? ? PickerImage.delegate = self;? ? ? ? ? [self presentViewController:PickerImage animated:YES completion:nil];? ? }]];? ? //按鈕:取消,類型:UIAlertActionStyleCancel? ? [alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];? ? [self presentViewController:alert animated:YES completion:nil];}//PickerImage完成后的代理方法- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary*)info{

//定義一個(gè)newPhoto茵乱,用來存放我們選擇的圖片。

UIImage *newPhoto = [info objectForKey:@"UIImagePickerControllerEditedImage"];

self.iconImg.image = newPhoto;

[self dismissViewControllerAnimated:YES completion:nil];

}

空格自己分開下渠羞。荧恍。屯吊。盒卸。xcode復(fù)制過來就這樣了





大致流程

一般在APP中,修改頭像是最基本的功能之一了糟需。一般是兩種方式的修改:從相冊(cè)選擇圖片或者拍照洲押。那么這里就來講一下如何具體實(shí)現(xiàn)這個(gè)功能杈帐。

Step1:點(diǎn)擊頭像 ->手勢(shì)(UITapGestureRecognizer)

QQ的更換頭像操作

首先挑童,點(diǎn)擊頭像。因?yàn)轭^像是直接放在ImageView中的尽楔,默認(rèn)情況下當(dāng)我們點(diǎn)擊頭像的時(shí)候阔馋,頭像是不會(huì)有任何反應(yīng)的娇掏。因此婴梧,我們需要給頭像的ImageView添加一個(gè)點(diǎn)擊事件塞蹭,方法如下:

/**

*? 添加手勢(shì):也就是當(dāng)用戶點(diǎn)擊頭像了之后竟坛,對(duì)這個(gè)操作進(jìn)行反應(yīng)

*///允許用戶交互_myHeadPortrait.userInteractionEnabled=YES;//初始化一個(gè)手勢(shì)UITapGestureRecognizer*singleTap = [[UITapGestureRecognizeralloc]initWithTarget:selfaction:@selector(alterHeadPortrait:)];//給ImageView添加手勢(shì)[_myHeadPortrait addGestureRecognizer:singleTap];? ? }

Step2:彈出選擇提示->提示框(UIAlertController)

通過添加UITapGestureRecognizer(手勢(shì)),系統(tǒng)就知道了我點(diǎn)擊了頭像洼冻,接著,就可以添加具體的方法來進(jìn)行操作了叔营。在上一步所宰,我為這個(gè)手勢(shì)的action婴谱,selector(選擇)了一個(gè)方法來執(zhí)行躯泰,即alterHeadPortrait:(注意有冒號(hào)的)瘟裸,也就是當(dāng)我們點(diǎn)擊了頭像之后诵竭,會(huì)執(zhí)行alterHeadPortrait:這個(gè)方法:

//? 方法:alterHeadPortrait-(void)alterHeadPortrait:(UITapGestureRecognizer*)gesture{/**

*? 彈出提示框

*///初始化提示框UIAlertController*alert = [UIAlertControlleralertControllerWithTitle:nilmessage:nilpreferredStyle:UIAlertControllerStyleActionSheet];//按鈕:從相冊(cè)選擇超棺,類型:UIAlertActionStyleDefault[alert addAction:[UIAlertActionactionWithTitle:@"從相冊(cè)選擇"style:UIAlertActionStyleDefaulthandler:nil]];//按鈕:拍照件相,類型:UIAlertActionStyleDefault[alert addAction:[UIAlertActionactionWithTitle:@"拍照"style:UIAlertActionStyleDefaulthandler:nil]];//按鈕:取消夜矗,類型:UIAlertActionStyleCancel[alert addAction:[UIAlertActionactionWithTitle:@"取消"style:UIAlertActionStyleCancelhandler:nil]];? ? [selfpresentViewController:alert animated:YEScompletion:nil];}

通過UIAlertController(提示框)這個(gè)類罢荡,我們創(chuàng)建好了一個(gè)提示框对扶,如下:

點(diǎn)擊頭像笼才,彈出提示框

現(xiàn)在昂羡,當(dāng)我們點(diǎn)擊取消(或者點(diǎn)擊按鈕以外的區(qū)域)提示框就會(huì)被自動(dòng)取消掉摔踱,并將提示框收起來赴穗。

Step3:從相冊(cè)選擇或者拍照選擇頭像->UIImagePickerController

好了膀息,繞了這么久潜支,終于開始進(jìn)入主題了,即選擇圖片或者拍照了。那么現(xiàn)在該腫么辦呢裁替?好像毫無頭緒的樣子弱判。开伏。遭商。

這里就需要通過UIImagePickerController巫玻,通過它仍秤,我們就可以讓我們的APP輕松的實(shí)現(xiàn)訪問相冊(cè)或者拍照:

操作UIImagePickerController徒扶,需要實(shí)現(xiàn)兩個(gè)協(xié)議:

進(jìn)行相冊(cè)圖片選擇或者相機(jī)拍照的實(shí)現(xiàn)代碼如下:

//初始化UIImagePickerControllerUIImagePickerController*PickerImage = [[UIImagePickerControlleralloc]init];//獲取方式1:通過相冊(cè)(呈現(xiàn)全部相冊(cè))导坟,UIImagePickerControllerSourceTypePhotoLibrary//獲取方式2圈澈,通過相機(jī)康栈,UIImagePickerControllerSourceTypeCamera//獲取方方式3啥么,通過相冊(cè)(呈現(xiàn)全部圖片)菠秒,UIImagePickerControllerSourceTypeSavedPhotosAlbumPickerImage.sourceType=UIImagePickerControllerSourceTypePhotoLibrary;//方式1//允許編輯氯迂,即放大裁剪PickerImage.allowsEditing=YES;//自代理PickerImage.delegate=self;//頁面跳轉(zhuǎn)[selfpresentViewController:PickerImage animated:YEScompletion:nil];

運(yùn)行效果如圖:


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末禁灼,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子拳芙,更是在濱河造成了極大的恐慌,老刑警劉巖悴务,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件羡疗,死亡現(xiàn)場(chǎng)離奇詭異别洪,居然都是意外死亡挖垛,警方通過查閱死者的電腦和手機(jī)秉颗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來菇怀,“玉大人爱沟,你說我怎么就攤上這事呼伸》浯螅” “怎么了蝶怔?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵澳叉,是天一觀的道長沐悦。 經(jīng)常有香客問我瓶殃,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任冠场,我火速辦了婚禮本砰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘舔株。我一直安慰自己芦昔,他們只是感情好娃肿,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布凭豪。 她就那樣靜靜地躺著嫂伞,像睡著了一般拯钻。 火紅的嫁衣襯著肌膚如雪粪般。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音小作,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛氮块,可吹牛的內(nèi)容都是我干的诡宗。 我是一名探鬼主播塔沃,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼螃概,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼吊洼!你這毒婦竟也來了制肮?” 一聲冷哼從身側(cè)響起豺鼻,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤儒飒,失蹤者是張志新(化名)和其女友劉穎桩了,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡送悔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年荚藻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了洁段。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疾呻。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖叠蝇,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铃慷,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布洲鸠,位于F島的核電站扒腕,受9級(jí)特大地震影響股囊,放射性物質(zhì)發(fā)生泄漏稚疹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望岩灭。 院中可真熱鬧,春花似錦、人聲如沸数初。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春疮胖,著一層夾襖步出監(jiān)牢的瞬間誊役,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留巩梢,地道東北人鞠抑。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓搁拙,卻偏偏與公主長得像箕速,于是被迫代替她去往敵國和親朋譬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子徙赢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容