iOS中UILabel實(shí)現(xiàn)長(zhǎng)按復(fù)制功能實(shí)例代碼
前言
網(wǎng)上有很多種給Label添加長(zhǎng)按復(fù)制功能的方法,而在 UILabel 上實(shí)現(xiàn)長(zhǎng)按復(fù)制,我用的是 UIMenuController。在 UITextView、UITextField 中,已經(jīng)自帶了這個(gè)東西,但是在 UILabel 上需要自定義。
鑒于有的朋友很少接觸 UIMenuController,這里先介紹一些基本知識(shí)。
UIMenuController 可以使用系統(tǒng)自帶的方法,也可以自定義。
系統(tǒng)默認(rèn)支持UITextField、UITextView、UIWebView控件的UIMenuController相關(guān)操作
更多UIMenuController使用請(qǐng)參考這篇文章:http://www.dbjr.com.cn/article/87000.htm
常見的系統(tǒng)方法和使用
- (void)cut:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)copy:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)paste:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)select:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)selectAll:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)delete:(nullable id)sender NS_AVAILABLE_IOS(3_2);
從字面意思就能看出,他們是剪切、復(fù)制、粘貼、選擇、全選、刪除。使用方法很簡(jiǎn)單。
// 比如我在一個(gè) UITextView 里,想增加全選和復(fù)制的方法 // 只要在自定義 UITextView 的時(shí)候加入這行代碼即可 - (BOOL)canPerformAction:(SEL)action withSender:(id)sender { if(action == @selector(selectAll:) || action == @selector(copy:)) return YES; return NO; }
細(xì)心的朋友可能會(huì)發(fā)現(xiàn),最后長(zhǎng)按出來的文字都是英文,我們改如何把他改成中文呢?如圖,在 Project -> Info -> Localizations 中添加 Chinese(Simplified) 即可。
自定義方法和使用
回到主題,我們要在 UILabel 上加入長(zhǎng)按復(fù)制事件,但是他本身是不支持 UIMenuController 的,所以接下來講講自定義方法。
自定義一個(gè) UILabel,設(shè)置label可以成為第一響應(yīng)者
- (BOOL)canBecomeFirstResponder { return YES; }
設(shè)置長(zhǎng)按事件,在初始化的時(shí)候調(diào)用這個(gè)方法
- (void)setUp { /* 你可以在這里添加一些代碼,比如字體、居中、夜間模式等 */ self.userInteractionEnabled = YES; [self addGestureRecognizer:[[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPress)]]; }
長(zhǎng)按事件,在里面新建 UIMenuController
- (void)longPress { // 設(shè)置label為第一響應(yīng)者 [self becomeFirstResponder]; // 自定義 UIMenuController UIMenuController * menu = [UIMenuController sharedMenuController]; UIMenuItem * item1 = [[UIMenuItem alloc]initWithTitle:@"復(fù)制" action:@selector(copyText:)]; menu.menuItems = @[item1]; [menu setTargetRect:self.bounds inView:self]; [menu setMenuVisible:YES animated:YES]; }
設(shè)置label能夠執(zhí)行那些
- (BOOL)canPerformAction:(SEL)action withSender:(id)sender { if(action == @selector(copyText:)) return YES; return NO; } // 如果模仿上面的寫以下代碼,點(diǎn)擊后會(huì)導(dǎo)致程序崩潰 if(action == @selector(selectAll:) || action == @selector(copy:)) return YES;
方法的具體實(shí)現(xiàn)
- (void)copyText:(UIMenuController *)menu { // 沒有文字時(shí)結(jié)束方法 if (!self.text) return; // 復(fù)制文字到剪切板 UIPasteboard * paste = [UIPasteboard generalPasteboard]; paste.string = self.text; }
最終效果:
附上 DEMO (本地下載),自定義的 UILabel 可以直接拖走使用
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- iOS基于 UILabel實(shí)現(xiàn)文字添加描邊功能
- iOS如何封裝帶復(fù)制功能的UILabel示例代碼
- iOS開發(fā)總結(jié)之UILabel常用屬性介紹
- iOS中UILabel設(shè)置居上對(duì)齊、居中對(duì)齊、居下對(duì)齊及文字置頂顯示
- iOS動(dòng)態(tài)調(diào)整UILabel高度的幾種方法
- iOS UILabel 設(shè)置內(nèi)容的間距及高度的計(jì)算示例
- IOS 開發(fā)之UILabel 或者 UIButton加下劃線鏈接
- iOS UILabel根據(jù)內(nèi)容自動(dòng)調(diào)整高度
- iOS兩丫技術(shù)之UILabel性能不夠的解決方法
相關(guān)文章
iOS輕松實(shí)現(xiàn)導(dǎo)航欄透明漸變
這篇文章主要為大家詳細(xì)介紹了iOS輕松實(shí)現(xiàn)導(dǎo)航欄透明漸變效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01iOS開發(fā)實(shí)現(xiàn)HTTPS之cer文件的使用詳解
下面小編就為大家分享一篇iOS開發(fā)實(shí)現(xiàn)HTTPS之cer文件的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01iOS 9 更新之Safari廣告攔截器(Content Blocker)開發(fā)教程
這篇文章主要介紹了iOS 9 更新之Safari廣告攔截器(Content Blocker)開發(fā)教程的相關(guān)資料,需要的朋友可以參考下2015-08-08