iOS中UILabel實現(xiàn)長按復(fù)制功能實例代碼
前言
網(wǎng)上有很多種給Label添加長按復(fù)制功能的方法,而在 UILabel 上實現(xiàn)長按復(fù)制,我用的是 UIMenuController。在 UITextView、UITextField 中,已經(jīng)自帶了這個東西,但是在 UILabel 上需要自定義。
鑒于有的朋友很少接觸 UIMenuController,這里先介紹一些基本知識。
UIMenuController 可以使用系統(tǒng)自帶的方法,也可以自定義。
系統(tǒng)默認支持UITextField、UITextView、UIWebView控件的UIMenuController相關(guān)操作
更多UIMenuController使用請參考這篇文章:http://chabaoo.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ù)制、粘貼、選擇、全選、刪除。使用方法很簡單。
// 比如我在一個 UITextView 里,想增加全選和復(fù)制的方法 // 只要在自定義 UITextView 的時候加入這行代碼即可 - (BOOL)canPerformAction:(SEL)action withSender:(id)sender { if(action == @selector(selectAll:) || action == @selector(copy:)) return YES; return NO; }
細心的朋友可能會發(fā)現(xiàn),最后長按出來的文字都是英文,我們改如何把他改成中文呢?如圖,在 Project -> Info -> Localizations 中添加 Chinese(Simplified) 即可。
自定義方法和使用
回到主題,我們要在 UILabel 上加入長按復(fù)制事件,但是他本身是不支持 UIMenuController 的,所以接下來講講自定義方法。
自定義一個 UILabel,設(shè)置label可以成為第一響應(yīng)者
- (BOOL)canBecomeFirstResponder { return YES; }
設(shè)置長按事件,在初始化的時候調(diào)用這個方法
- (void)setUp { /* 你可以在這里添加一些代碼,比如字體、居中、夜間模式等 */ self.userInteractionEnabled = YES; [self addGestureRecognizer:[[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPress)]]; }
長按事件,在里面新建 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; } // 如果模仿上面的寫以下代碼,點擊后會導(dǎo)致程序崩潰 if(action == @selector(selectAll:) || action == @selector(copy:)) return YES;
方法的具體實現(xiàn)
- (void)copyText:(UIMenuController *)menu { // 沒有文字時結(jié)束方法 if (!self.text) return; // 復(fù)制文字到剪切板 UIPasteboard * paste = [UIPasteboard generalPasteboard]; paste.string = self.text; }
最終效果:
附上 DEMO (本地下載),自定義的 UILabel 可以直接拖走使用
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
iOS開發(fā)實現(xiàn)HTTPS之cer文件的使用詳解
下面小編就為大家分享一篇iOS開發(fā)實現(xiàn)HTTPS之cer文件的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01iOS 9 更新之Safari廣告攔截器(Content Blocker)開發(fā)教程
這篇文章主要介紹了iOS 9 更新之Safari廣告攔截器(Content Blocker)開發(fā)教程的相關(guān)資料,需要的朋友可以參考下2015-08-08