自定义键盘 Keyboard Extension 防坑指南

最近尝试开发了一个Keyboard Extension,主要功能是用于服务微信上的那些商家。遇到过一些坑点,mark一下,也希望能帮到遇到同样问题的你们。

首先得理解Extension的概念,这个很重要,很重要,很重要。好吧,总而言之,言而总之,它就是个扩展.....

HostApp、ContainApp、KeyboardExtension三者之间的关系得捋清楚。开发者不能单独创建扩展,你得创建一个App应用(ContainApp),然后在target里面新建扩展(KeyboardExtension)。但是,扩展是有自己的BundleID的,它可以在其他App(HostApp)中独立运行。

比如,你用微信打开App应用KeyboardDemo的自定义键盘keyboard,微信:HostApp KeyboardDemo:ContainApp  keyboard:Extension。

好吧,废话了,接下来是我经历的坑点:

//程序员,都是从0开始的

0、cocoapods导入,正常导入就行。

1、自定义高度。这个坑了我99根头发:一定要在viewWillAppear方法中添加给view添加高度约束!!!!在viewDidLoad和updateViewConstraints中添加,会先跳到自定义高度,然后回到默认高度(226),最后又回到自定义高度,体验极差!

2、viewDidLoad方法中,self.view.window为nil,updateViewConstraints中才有值。

3、 UIApplication, window, UIInputViewController的获取方法:

+ (UIApplication *)getApplication {

    UIScreen *screen = [UIScreen mainScreen];

    UIWindow*window = [screen valueForKey:@"_preferredFocusedWindow"];

    if(!window)return nil;

    UIResponder*responder = window.nextResponder;

    while(!responder || ![responder isMemberOfClass:[UIApplication class]]) {

        responder = responder.nextResponder;

    }

    return(UIApplication*)responder;

}

UIInputViewController *inputVC = (UIInputViewController *)window.rootViewController.childViewControllers.firstObject;

4、跳到containApp:

UIApplication *app;  可用上面获取UIApplication

SEL sel = NSSelectorFromString(@"openURL:");

        if([app respondsToSelector:sel]) {

            [app performSelector:selwithObject:url];

        }

吐槽下,这个试了N次,然并卵

//    [self.extensionContext openURL:url completionHandler:^(BOOL success) {

//        NSLog(@"%@", success ? @"打开成功" : @"打开失败");

//    }];

5、实时获取剪切板的内容,我是通过定时器获取剪切板内容的,不能通过UIPasteboardChangedNotification等通知监听,毕竟不同应用。

6、直接跳过textfiled/textview 直接输出,直接在自己的发送方法中:

        [self.textDocumentProxy insertText:text];  

        [self.textDocumentProxy deleteBackward];

        [self.textDocumentProxy insertText:@"\n"];

7、针对微信发送图片,方法1、分享(搜狗 讯飞等)方法2、复制到剪切板(我用的是YYImage,系统剪切板不能直接识别 Y YImage,UIImage *systemImage = [UIImage imageWithCGImage:image.CGImage];),提示用户点击微信输入框粘贴

8、针对微信发送表情动图,我用原生UIActivityViewController分享Data和沙盒URL都只能得到第一帧,剪切板也类似,求大佬们推荐解决方法.

9、微信朋友圈防折叠推测:我测出2个因素:1、粘贴 ,   2、文字重复率。

10、获取剪切板文字:

+ (void)getPasterBoardStrResultBlock:(void(^)(NSString*))resultBlock {

    if(!resultBlock)return;

    UIPasteboard *pasterBoard = [UIPasteboard generalPasteboard];

    if(pasterBoard.string.length>0) resultBlock(pasterBoard.string);

    //ios10之前,需要完全权限才能拿到pasterBoard,没有则提示开启完全权限

    if(!pasterBoard) {

        [TipsManager showTipsWithStr:@"您需要在设置->通用->键盘开启完全权限"];

    }else{

       resultBlock(nil);

    }

}

11、判断完全权限

static BOOL hasFullAccess = NO;

+ (BOOL)isGetAllAccessGranted {

    if (hasFullAccess) {

        NSLog(@"打开了权限");

        returnYES;

    }else{

        if(@available(iOS11.0, *)) {

            UIScreen*screen = [UIScreenmainScreen];

            UIWindow*window = [screenvalueForKey:@"_preferredFocusedWindow"];

            UIInputViewController *inputVC = (UIInputViewController *)window.rootViewController.childViewControllers.firstObject;

            if ([inputVC isKindOfClass:[UIInputViewController class]]) {

                hasFullAccess= inputVC.hasFullAccess;

            }

        }else{

            UIPasteboard *board = [UIPasteboard generalPasteboard];

            if(@available(iOS10.0, *)) {

                NSString*originStr = board.string;

                board.string=@"test";

                hasFullAccess= board.hasStrings;

                board.string= originStr;

            }else{

                hasFullAccess= board ?YES:NO;

            }

        }

    }

    if (!hasFullAccess) {

        [TipsManager showTipsWithStr:@"您需要在设置->通用->键盘开启完全权限"];

    }

    return hasFullAccess;

}

最后,再次跪求在微信发送图片和表情包更优雅方案!欢迎讨论

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

推荐阅读更多精彩内容