UIPasteboard

在iOS中,UITextField、UITextView和UIWebView等都有复制粘贴等功能。而其她控件却没有集成这些方便操作的功能。下面我将通过对粘贴板UIPasteboard这个类来详细说明在iOS中粘贴板的使用方法。

1、剪切板管理类UIPasteboard详解

UIPasteboard类有3个初始化方法,如下:

//获取系统级别的剪切板

+ (UIPasteboard *)generalPasteboard;

//获取一个自定义的剪切板 name参数为此剪切板的名称 create参数用于设置当这个剪切板不存在时 是否进行创建

+ (nullable UIPasteboard *)pasteboardWithName:(NSString *)pasteboardName create:(BOOL)create;

//获取一个应用内可用的剪切板

+ (UIPasteboard *)pasteboardWithUniqueName;

上面3个初始化方法,分别获取或创建3个级别不同的剪切板,下面我们详解一下在什么情况下用哪种初始化方法

+ (UIPasteboard *)generalPasteboard;系统级别的剪切板在整个设备中共享,即是应用程序被删掉,其向系统级的剪切板中写入的数据依然在。

+ (nullable UIPasteboard *)pasteboardWithName:(NSString *)pasteboardName create:(BOOL)create;自定义的剪切板通过一个特定的名称字符串进行创建,它在应用程序内或者同一开发者开发的其他应用程序中可以进行数据共享。举个例子:比如你开发了多款应用,用户全部下载了,在A应用中用户拷贝了一些数据(为了数据安全,不用系统级别的Pasteboard),在打开B应用时就会自动识别,提高用户体验。

+ (UIPasteboard *)pasteboardWithUniqueName;第3个方法创建的剪切板等价为使用第2个方法创建的剪切板,只是其名称字符串为nil,它通常用于当前应用内部。(当然也可以跨应用使用,但必须Bundle Identifier 例com.maoshaoqian.** 星号前部一样)

注意:使用第3个方法创建的剪切板默认是不进行数据持久化的,及当应用程序退出后,剪切板中内容将别抹去。若要实现持久化,需要设置persistent属性为YES。

下面我们来看一下UIPasteboard的常用属性

//剪切板的名称

@property(readonly,nonatomic) NSString *name;

//根据名称删除一个剪切板

+ (void)removePasteboardWithName:(NSString *)pasteboardName;

//是否进行持久化

@property(getter=isPersistent,nonatomic) BOOL persistent;

//此剪切板的改变次数 系统级别的剪切板只有当设备重新启动时 这个值才会清零

@property(readonly,nonatomic) NSInteger changeCount;

UIPasteboard数据类型判断及其存取

//获取剪切板中最新数据的类型

- (NSArray *)pasteboardTypes;

//获取剪切板中最新数据对象是否包含某一类型的数据

- (BOOL)containsPasteboardTypes:(NSArray *)pasteboardTypes;

//将剪切板中最新数据对象某一类型的数据取出

- (nullable NSData *)dataForPasteboardType:(NSString *)pasteboardType;

//将剪切板中最新数据对象某一类型的值取出

- (nullable id)valueForPasteboardType:(NSString *)pasteboardType;

//为剪切板中最新数据对应的某一数据类型设置值

- (void)setValue:(id)value forPasteboardType:(NSString *)pasteboardType;

//为剪切板中最新数据对应的某一数据类型设置数据

- (void)setData:(NSData *)data forPasteboardType:(NSString *)pasteboardType;

多组数据对象的存取:

//数据组数

@property(readonly,nonatomic) NSInteger numberOfItems;

//获取一组数据对象包含的数据类型

- (nullable NSArray *)pasteboardTypesForItemSet:(nullable NSIndexSet*)itemSet;

//获取一组数据对象中是否包含某些数据类型

- (BOOL)containsPasteboardTypes:(NSArray *)pasteboardTypes inItemSet:(nullable NSIndexSet *)itemSet;

//根据数据类型获取一组数据对象

- (nullable NSIndexSet *)itemSetWithPasteboardTypes:(NSArray *)pasteboardTypes;

//根据数据类型获取一组数据的值

- (nullable NSArray *)valuesForPasteboardType:(NSString *)pasteboardType inItemSet:(nullable NSIndexSet *)itemSet;

//根据数据类型获取一组数据的NSData数据

- (nullable NSArray *)dataForPasteboardType:(NSString *)pasteboardType inItemSet:(nullable NSIndexSet *)itemSet;

//所有数据对象

@property(nonatomic,copy) NSArray *items;

//添加一组数据对象

- (void)addItems:(NSArray *> *)items;

上面方法中很多需要传入数据类型参数,这些参数是系统定义好的一些字符窜,如下:

//所有字符串类型数据的类型定义字符串数组

UIKIT_EXTERN NSArray *UIPasteboardTypeListString;

//所有URL类型数据的类型定义字符串数组

UIKIT_EXTERN NSArray *UIPasteboardTypeListURL;

//所有图片数据的类型定义字符串数据

UIKIT_EXTERN NSArray *UIPasteboardTypeListImage;

//所有颜色数据的类型定义字符串数组

UIKIT_EXTERN NSArray *UIPasteboardTypeListColor;

相比于上面两组方法,下面这些方法更加面向对象,在开发中使用更加方便与快捷:

//获取或设置剪切板中的字符串数据

@property(nullable,nonatomic,copy) NSString *string;

//获取或设置剪切板中的字符串数组

@property(nullable,nonatomic,copy) NSArray *strings;

//获取或设置剪切板中的URL数据

@property(nullable,nonatomic,copy) NSURL *URL;

//获取或设置剪切板中的URL数组

@property(nullable,nonatomic,copy) NSArray *URLs;

//获取或s何止剪切板中的图片数据

@property(nullable,nonatomic,copy) UIImage *image;

//获取或设置剪切板中的图片数组

@property(nullable,nonatomic,copy) NSArray *images;

//获取或设置剪切板中的颜色数据

@property(nullable,nonatomic,copy) UIColor *color;

//获取或设置剪切板中的颜色数组

@property(nullable,nonatomic,copy) NSArray *colors;

//部分代码参考

- (BOOL)canBecomeFirstResponder {

return YES;

}

- (BOOL)canPerformAction:(SEL)action withSender:(id)sender {

//action 会返回很多,想用哪个就写那个(action == @selector(cut:) )

return (action == @selector(copy:) || action == @selector(paste:) );

}

-(void)copy:(id)sender{

UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

[pasteboard setImage:self.image];

if ([self.delegate respondsToSelector:@selector(transSomeTing:)]) {

[self.delegate transSomeTing:pasteboard.image];

NSLog(@"%@",self.image);

}

NSLog(@"您点击的是拷贝%@",pasteboard.items);

}

-(void)paste:(id)sender{

UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

UIImage *image = [pasteboard image];

if (image) {

self.image = image;

}

NSLog(@"您点击的是粘贴");

}

- (void)cut:(id)sender {

UIPasteboard *pasteboard = [UIPasteboard generalPasteboard];

[pasteboard setImage:self.image];

NSLog(@"您点击的是剪切");

}

- (void)select:(id)sender {

NSLog(@"您点击的是选择");

}

-(void)selectAll:(id)sender {

NSLog(@"您点击的是全选");

}

对剪切板的某些操作会触发如下通知:

//剪切板内容发生变化时发送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedNotification;

//剪切板数据类型键值增加时发送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedTypesAddedKey;

//剪切板数据类型键值移除时发送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedTypesRemovedKey;

//剪切板被删除时发送的通知

UIKIT_EXTERN NSString *const UIPasteboardRemovedNotification;

//使用举例

//当剪切板被删除时,监听通知,可处理相应事件;

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(menuControllerWillHide) name:UIPasteboardRemovedNotification object:nil];

2、剪切板管理类UIPasteboard具体使用

我们以系统粘贴板+ (UIPasteboard *)generalPasteboard;来举例子

我们给UIImageView添加复制粘贴事件

//

//  ViewController.m

//  Practice_UIPasteboard

#import "ViewController.h"

#import "PasteboardLabel.h"

#import "PasteboardImageView.h"

#import

@interface ViewController ()

@property (strong, nonatomic) IBOutlet PasteboardImageView *leftImageView;

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

self.leftLabel.userInteractionEnabled = YES;

//用于监听 UIMenuController的变化

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(menuControllerWillShow) name:UIMenuControllerWillShowMenuNotification object:nil];

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(menuControllerWillHide) name:UIMenuControllerWillHideMenuNotification object:nil];

// Do any additional setup after loading the view, typically from a nib.

}

- (IBAction)longPressGestureAction:(UILongPressGestureRecognizer *)sender {

//要将图片变为第一响应者,而且要把图片设为**可交换状态**

[self.leftImageView becomeFirstResponder];

self.leftImageView.userInteractionEnabled = YES;

self.leftImageView.delegate = self;

UIMenuController *menuController = [UIMenuController sharedMenuController];

[menuController setTargetRect:self.leftImageView.frame inView:self.view];

[menuController setMenuVisible:YES animated:YES];

}

}

//  PasteboardImageView.m

//  Practice_UIPasteboard

#import "PasteboardImageView.h"

@implementation PasteboardImageView

//这个方法不能少

- (BOOL)canBecomeFirstResponder {

return YES;

}

- (BOOL)canPerformAction:(SEL)action withSender:(id)sender {

return (action == @selector(copy:) || action == @selector(paste:) );

}

-(void)copy:(id)sender{

UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

[pasteboard setImage:self.image];

if ([self.delegate respondsToSelector:@selector(transSomeTing:)]) {

[self.delegate transSomeTing:pasteboard.image];

NSLog(@"%@",self.image);

}

NSLog(@"您点击的是拷贝%@",pasteboard.items);

}

-(void)paste:(id)sender{

UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

UIImage *image = [pasteboard image];

if (image) {

self.image = image;

}

NSLog(@"您点击的是粘贴");

}

/*

// Only override drawRect: if you perform custom drawing.

// An empty implementation adversely affects performance during animation.

- (void)drawRect:(CGRect)rect {

// Drawing code

}

@end

参考来自:作者山水域  http://www.jianshu.com/p/a6d2e46329f8






最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 一、自带剪切板操作的原生UI控件 在iOS的UI系统中,有3个控件自带剪切板操作,分别是UITextField、U...
    青菜白玉堂阅读 6,967评论 0 1
  • 转至元数据结尾创建: 董潇伟,最新修改于: 十二月 23, 2016 转至元数据起始第一章:isa和Class一....
    40c0490e5268阅读 1,678评论 0 9
  • 原文链接由于树莓派并没有传统意义上的BIOS, 所以现在各种系统配置参数通常被存在"config.txt"这个文本...
    palytoxin阅读 4,188评论 0 2
  • 9月8日 Friday sunny 经战友波力介绍,知道了他从“剽悍晨读”中获益匪浅,于是自己也扫码加入...
    艾问才会赢阅读 186评论 0 0