URL Scheme 应用示例(双向openURL实现,调用特定的其他应用程序)

这是一个URL Scheme应用实例,首先我假设你已经看过《用自定义协议调用自己的程序》一文。项目中有一个变态的需求,我们的项目中要集成另一个厂商开发的app,由于知识产权的问题,我们不能集成源代码(早期我们也试图源代码方式集成,但最后搞得大家都累)。这个app单独安装在iPhone上,但用户点击app图标不能启动它,而只能启动我们的程序,再通过我们的程序去启动这个app。想来想去,只能用一种双向的URLScheme解决这个问题。

一、注册自定义URL协议

打开Xcode4.2,新建Empty Application,命名为URLSchemeResponder。

修改AppDelegate,将程序窗口的背景色修改为某个颜色比如紫色,以便我们能识别是当前看到的是哪个应用程序:

self.window.backgroundColor = [UIColorpurpleColor];

编辑URLSchemeResponder-Info.plist文件。增加一行,选择Key的类型为URL Types。URL Types是数组类型,它展开后默认有一个item(即Item0),如下图所示:

 

为Item0是Dictionary类型。点击Item0右边的“+”号,我们可以为它新增一个键-值对,将Key设置为URLidentifier,Value则设置为com.yourcompany.yourapp样式,如下图所示:

 

再次点击Item 0右边的“+”号按钮,新建一个键值对,Key为URL Schemes。URL Schemes也是一个数组类型,展开后默认有一个item(即Item0)。我们将这个item的Value设置为自定义的URL协议名,比如:urlschemetest。注意,我们不需要在协议名后面加上“://”,例如“http://”写http就好,“urlschemetest://”写urlschemetest就好。

提示:你甚至可以加入多个协议名:item0、item1、item2⋯⋯只要你确实需要的话。

 

二、响应自定义URL协议

编辑文件AppDelegate.m,加入方法:

- (BOOL)application:(UIApplication *)applicationhandleOpenURL:(NSURL*)url  {

    if(!url) { 

        returnNO;

    }else{

        NSString* queryString=[url query];

        NSLog(@"query string:%@",queryString);

        if ([@"from=URLSchemeRequester"isEqualToString:queryString]) {

            returnYES;

        }else

            returnNO;

    }

}

注意,在这段代码中,我们判断了URL中的查询字串如果等于from=URLSchemeRequester,我们就会打开程序,否则不会处理。

三、在其他程序里打开自定义URL协议

新建Empty Application,命名为 URLSchemeRequester。

修改AppDelegate,将程序窗口的背景色修改为某个颜色比如红色,以便我们能识别是当前看到的是哪个应用程序:

self.window.backgroundColor = [UIColorredColor];

接着在窗口中加入一个Button:

UIButton* btn=[UIButtonbuttonWithType:UIButtonTypeRoundedRect];

    [btn setTitle:@"打开URLSchemeResponder"forState:UIControlStateNormal];

    [btn addTarget:selfaction:@selector(btnAction) forControlEvents:UIControlEventTouchUpInside];

    [self.windowaddSubview:btn];

 

接着在btnAction方法中打开自定义协议urlschemetest,即调用外部程序URLSchemeResponder:

-(void)btnAction{

    [[UIApplicationsharedApplication]openURL:

     [NSURLURLWithString:@"urlschemetest://?from=URLSchemeRequester"]];

}

如果我们想让URLSchemeResponder不能直接启动,只能由URLSchemeRequester通过openURL方式启动,可以修改URLSchemeResponder的application: didFinishLaunchingWithOptions方法,对launchOptions进行判断:

id url=[launchOptions objectForKey:UIApplicationLaunchOptionsURLKey];

    NSLog(@"url:%@",url);

    if (url) {

        self.window = [[[UIWindowallocinitWithFrame:[[UIScreenmainScreenbounds]] autorelease];

        // Override point forcustomization after application launch.

        self.window.backgroundColor = [UIColorpurpleColor];

        UILabel* lb=[[UILabelalloc]initWithFrame:CGRectMake(120, 240, 180, 44)];

        [lb setText:@"URL Scheme Responder"];

        [self.windowaddSubview:lb];

        [lbrelease];

        [self.windowmakeKeyAndVisible];

        returnYES;

    }else{

        exit(0);

        abort();

    }

参数launchOptions是一个字典,如果我们以 UIApplicationLaunchOptionsURLKeyw为Key去检索luanchOptions,能够得到一个NSURL对象。该对象的值跟应用程序启动方式有关。如果应用程序的启动方式为openURL,这个NSURL对象不应该为空。如果为nil,则表明应用程序不是用openURL方式启动的。

四、双向URL Scheme

很简单,app1能够openURL app2,app2也要能openURL app1。这样我们就还需要在URLSchemeRequester程序中再注册一个URLScheme,这个过程就不再复述了,你可以参考URLSchemeResponder的做法。

posted @ 2012-06-20 11:49  威尚  阅读(2294)  评论(3编辑  收藏  举报