zoukankan      html  css  js  c++  java
  • IOS应用程序间相互跳转 与 传值

    阅读本文之前建议参考:<Communicating with Other App程序间通信[翻译]>
    在IOS中,实现在app1中打开app2,方法如下:
    1,在app2中注册一个URL Schemes
    注册的方法很简单,在XXX-info.plist文件中新增一个URL types数组元素,取一个名字,比如"tekuba_net".或者在工程的-TARGETS-Info,中找到URL Types添加一个URL Schemes,名为"tekuba_net".
    2,在app1中打开app2
    在app1中适当的位置执行:[[UIApplication sharedApplication] openURL:[NSURL URLWithString:@“tekuba_net://"]]即可。
    在app2中实现appDelegate中实现两个方法:
    (1)在IOS4.2或者之后的版本,使用application:openURL:sourceApplication:annotation;
    (2)在IOS4.1或者更早期的版本使用application:handleOpenURL:
    (3)使用 application:willFinishLaunchingWithOptions: 或application:didFinishLaunchingWithOptions:方法接收URL信息并决定是否打开它。如果返回NO,您的应用的 URL处理不会被唤醒.有待确认
    另外使用:[[UIApplication sharedApplication] openURL:url]方法中的url的格式不固定,只要满足tekuba_net://这种格式就行,比如tekuba_net://argument?=1等,而在app2中的application:openURL:sourceApplication:annotation代理中可以获取该url信息,因此可以约定一种格式的url来进行应用间传参。
    转载请注明来自特酷吧,本文地址:http://www.tekuba.net/program/305/

     

     

     

     

     

     

     

    一、调用系统应用

     
     
    1、调用app store界面方法
    在实际开发中,往往要推荐自己其他应用和推荐自己的收费软件,那么我们就需要在程序中直接连接到app store的相应页面。
     
    实际上的做法很简单,使用的还是UIApplication类的OpenURL方法: 
     
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"程序的相应连接"]];
     
     
     
     
    1、调用其它应用的方法
    1)调用 自带mail

     
     
    [[UIApplicationsharedApplication] openURL:[NSURLURLWithString:@"mailto://admin@hzlzh.com"]];
     
     
    2)调用 电话phone

     
    [[UIApplication sharedApplication] openURL:[NSURLURLWithString:@"tel://8008808888"]];

     
     
    3)调用 SMS
     
    
[[UIApplicationsharedApplication] openURL:[NSURL URLWithString:@"sms://800888"]];

     
    4)调用自带 浏览器 safari
     
    
[[UIApplicationsharedApplication] openURL:[NSURLURLWithString:@"http://www.hzlzh.com"]];
     
    5)调用 Remote
     
    
[[UIApplicationsharedApplication] openURL:[NSURL URLWithString:@"remote://fff"]];
     
     
     
     

     

     
     
    二、调用自己开发的应用
     
     
    1)在plist文件中,注册对外接口
     
        在xcode group&files 里面,展开 resources选择<app>info.plist
     
       鼠标右击information property list ,然后从列表中选择URL types 
     
        右击 add row 添加一个对象(item)右击item add row  
     
        从列表中选择 URL  Schemes 再右击添加一个对象(item1)
     
        将item1得值设置为:myapp
     
        这个myapp就是对外接口,其它应用可以通过它,调用该应用
     
       plist如下图所示:
     
     
     
    2)调用方法
     
       在你需要调用上面注册过对外接口的应用中,添加下面代码即可:   
     
     
      NSURL *url  = [NSURL URLWithString:@"myapp:"];
     
      [[UIApplication sharedApplication] openURL:url];
     
     
     
     
      通过上述两个步骤,你可以在你的应用中,让用户打开你的其它应用。
     
      如果加参数的话,最好写成@"myapp://.........",就好比http请求的“http”换成@“myapp”.
     
     
     
     
    3)处理URL请求
     
    应用程序委托在application:handleOpenURL:方法中处理传递给应用程序的URL请求。如果您已经为自己的应用程序注册了定制的URL模式,则务必在委托中实现这个方法。
     
    基于定制模式的URL采用的协议是请求服务的应用程序能够理解的。URL中包含一些注册模式的应用程序期望得到的信息,这些信息是该程序在处理或响应URL请求时需要的。传递给application:handleOpenURL:方法的NSURL对象表示的是Cocoa Touch框架中的URL。NSURL遵循RFC 1808规范,该类中包含一些方法,用于返回RFC 1808定义的各个URL要素,包括用户名、密码、请求、片断、和参数字符串。与您注册的定制模式相对应的“协议”可以使用这些URL要素来传递各种信息。
     
    在程序清单1-2显示的application:handleOpenURL:方法实现中,传入的URL对象在其请求和片断部分带有具体应用程序的信息。应用程序委托抽出这些信息—在这个例子中,是指一个to-do任务的名称和到期日—并根据这些信息创建应用程序的模型对象。
     
    [plain]
    - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {  
        if ([[url scheme] isEqualToString:@"myapp"]) {  
            //处理链接  
              
            return YES;  
        }  
          
        return NO;  
    }  
     
    - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
        if ([[url scheme] isEqualToString:@"myapp"]) {
            //处理链接
            
            return YES;
        }
        
        return NO;
    }
    请务必对传入的URL输入进行验证。如果您希望了解如何避免URL处理的相关问题,请参见安全编码指南文档中的验证输入部分。如果要了解苹果定义的URL模式,请参见苹果的URL模式参考
     
     
    第二种处理URL请求方法
    [cpp]
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  
    {  
        //被其他应用调用   
        NSURL *url = [launchOptions objectForKey:UIApplicationLaunchOptionsURLKey];  
        if(url) {//做出相应的判断   
            if ([[url scheme] isEqualToString:@"myapp"]) {  
                //处理链接   
            }  
        }  
        self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];  
        // Override point for customization after application launch.   
        self.viewController = [[[ViewController alloc] initWithNibName:@"ViewController" bundle:nil] autorelease];  
        self.window.rootViewController = self.viewController;  
        [self.window makeKeyAndVisible];  
        return YES;  
    }  
     
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        //被其他应用调用
        NSURL *url = [launchOptions objectForKey:UIApplicationLaunchOptionsURLKey];
        if(url) {//做出相应的判断
            if ([[url scheme] isEqualToString:@"myapp"]) {
                //处理链接
            }
        }
        self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
        // Override point for customization after application launch.
        self.viewController = [[[ViewController alloc] initWithNibName:@"ViewController" bundle:nil] autorelease];
        self.window.rootViewController = self.viewController;
        [self.window makeKeyAndVisible];
        return YES;
    }说明:iOS 程序启动时总会调用application:didFinishLaunchingWithOptions:,其中第二个参数launchOptions为NSDictionary类型的对象,里面存储有此程序启动的原因。
     
    launchOptions中的可能键值见UIApplication Class Reference的Launch Options Keys节 。
     
    若用户直接启动,lauchOptions内无数据;
    若由其他应用程序通过openURL:启动,则UIApplicationLaunchOptionsURLKey对应的对象为启动URL(NSURL),UIApplicationLaunchOptionsSourceApplicationKey对应启动的源应用程序的bundle ID (NSString);
    若由本地通知启动,则UIApplicationLaunchOptionsLocalNotificationKey对应的是为启动应用程序的的本地通知对象(UILocalNotification);
    若由远程通知启动,则UIApplicationLaunchOptionsRemoteNotificationKey对应的是启动应用程序的的远程通知信息userInfo(NSDictionary);
    其他key还有UIApplicationLaunchOptionsAnnotationKey,UIApplicationLaunchOptionsLocationKey,
    UIApplicationLaunchOptionsNewsstandDownloadsKey。
    参考:http://blog.csdn.net/tiger119/article/details/7949004
     
     
    4).快速测试外部调用
    1.回到Home屏幕,启动Safari(在iPhone仿真器上,在菜单上选择Hardware->Home命令就可以回到Home屏幕)。
    2.在Safari的地址栏中,键入使用定制模式的URL,即“myapp:”,加参数的话则为“myapp://........”
    3.确认您的应用程序是否启动,以及应用程序委托是否收到application:handleOpenURL:消息。
     
    三、官方原理讲解
     
     
    和其它应用程序进行通讯
    如果一个应用程序支持一些已知类型的URL,您就可以通过对应的URL模式和该程序进行通讯。然而,在大多数情况下,URL只是用于简单地启动一个应用程序并显示一些和调用方有关的信息。举例来说,对于一个用于管理地址信息的应用程序,您就可以在发送给它的URL中包含一个Maps程序可以处理的地址,以便显示相应的位置。这个级别的通讯为用户创造一个集成度高得多的环境,减少应用程序重新实现设备上其它程序已经实现的功能的必要性。
    苹果内置支持http、mailto、tel、和sms这些URL模式,还支持基于http的、指向Maps、YouTube、和iPod程序的URL。应用程序也可以自己注册定制的URL模式。您的应用程序可以和其它应用程序通讯,具体方法是用正确格式的内容创建一个NSURL对象,然后将它传给共享UIApplication对象openURL:方法。openURL:方法会启动注册接收该URL类型的应用程序,并将URL传给它。当用户最终退出该应用程序时,系统通常会重新启动您的应用程序,但并不总是这样。系统会考虑用户在URL处理程序中的动作及在用户看来返回您的应用程序是否合理,然后做出决定。
     
    下面的代码片断展示了一个程序如何请求另一个程序提供的服务(假定这个例子中的“todolist”是由应用程序注册的定制模式):
     
    NSURL *myURL = [NSURL URLWithString:@"todolist://www.acme.com?Quarterly%20Report#200806231300"]; 
    [[UIApplication sharedApplication] openURL:myURL]; 
     
    要提示:如果您的URL类型包含的模式和苹果定义的一样,则启动的是苹果提供的程序,而不是您的程序。如果有多个第三方的应用程序注册处理同样的URL模式,则该类型的URL由哪个程序处理是没重要提示:如果您的URL类型包含的模式和苹果定义的一样,则启动的是苹果提供的程序,而不是您的程序。如果有多个第三方的应用程序注册处理同样的URL模式,则该类型的URL由哪个程序处理是没有定义的。 
     
    如果您的应用程序定义了自己的URL模式,则应该实现对该模式进行处理的方法,具体信息在“实现定制的URL模式”部分中进行描述。有关系统支持的URL处理,包括如何处理URL的格式,请参见苹果的URL模式参考。
     
     
     
     
    实现定制的URL模式
    您可以为自己的应用程序注册包含定制模式的URL类型。定制的URL模式是第三方应用程序和其它程序及系统进行交互的机制。通过定制的URL模式,应用程序可以将自己的服务提供给其它程序。
     
     
     
     
    注册定制的URL模式
    在为您的应用程序注册URL类型时,必须指定CFBundleURLTypes属性的子属性,我们已经在“信息属性列表”部分中介绍过这个属性了。CFBundleURLTypes属性是应用程序的Info.plist文件中的一个字典数组,每个字典负责定义一个应用程序支持的URL类型。表1-6描述了CFBundleURLTypes字典的键和值。
     
     
     
     
    表1-6  CFBundleURLTypes属性的键和值 键
     值
     
    CFBundleURLName
     这是个字符串,表示URL类型的抽象名。为了确保其唯一性,建议您使用反向DNS风格的标识,比如com.acme.myscheme。
     
    这里提供的URL类型名是一个指向本地化字符串的键,该字符串位于本地化语言包子目录中的InfoPlist.strings文件中。本地化字符串是人类可识别的URL类型名称,用相应的语言来表示。
     
    CFBundleURLSchemes
     这是个URL模式的数组,表示归属于这个URL类型的URL。每个模式都是一个字符串。属于指定URL类型的URL都带有它们的模式组件。
     
     
    图1-7显示了一个正在用内置的Xcode编辑器编辑的Info.plist文件。在这个图中,左列中的URL类型入口相当于您直接加入到Info.plist文件的CFBundleURLTypes键。类似地,“URL identifier”和“URL Schemes”入口相当于CFBundleURLName和CFBundleURLSchemes键。
     
    在Info.plist文件中定义一个定制的URL模式
     
     
     
     
    您在对CFBundleURLTypes属性进行定义,从而注册带有定制模式的URL类型之后,可以通过下面的方式来进行测试:
     
    连编、安装、和运行您的应用程序。
     
    回到Home屏幕,启动Safari(在iPhone仿真器上,在菜单上选择Hardware > Home命令就可以回到Home屏幕)。
     
    在Safari的地址栏中,键入使用定制模式的URL。
     
    确认您的应用程序是否启动,以及应用程序委托是否收到application:handleOpenURL:消息。

     

     

     

     

     

     

     

    首先从Safari跳到APP

    既然要想跳到你指定的APP,那么就需要在你的APP中定义一个特殊的标示,也就是一个URL协议。

    定义URL协议的如下图  TARGETS ——> info ——>URL Types——>添加一个URL协议

    如图 其中 URL Schemes 字段就是你这个APP的特殊标示,而 indentifier 字段是这个URL协议的标示。(一个APP可以拥有多个URL协议)

    下面的两个字段可为空。最后再运行一下你的APP。

    接下来就是见证奇迹的时刻了

    打开你模拟器中的Safari浏览器,在输入在地址栏输入: appABC://  

    然后回车,结果就是你想要的。(是不是很简单?)

    有时候你可能需要在从Safari跳回到APP时传一些参数,那么又有什么方法可以接收这些参数呢?

    在appdelegate.m文件中写下如下方法

    这个方法是系统自动调用的方法,意思是:如果APP是通过openURL打开的自动调用此方法。而参数 url 就是打开APP的特定的URL。 也就是上面的  appABC://  ,但是怎么通过这个方法传参呢?

    答案就在URL中,你可以在  appABC:// 后面加上任何你想要的字符参数,例如appABC://name:wanglei//name:lilei

    至于如何把这些参数给解析出来,就看你怎么处理了。

    下面是  APP(A)跳转APP(B)

    前面说了他们之间的原理是一样的,从Safari跳到APP是通过打开特定的URL,那么从 APP(A)跳转APP(B)是不是也要打开特定的URL呢?

    答案是肯定的,那么怎么打开这个特定的URL呢,其实在UIApplication里面有这么一个方法openURL,如下

    [[UIApplication shareApplication] openURL:url]

    参数URL为APP(B)特定的URL协议所表示的URL(后面会附上demo)

    至于对参数的处理同上

    两个APP之间的跳转是通过[[UIApplication sharedApplication] openURL:url]这种方式来实现的。

    1.首先设置第一个APP的url地址

    mamicode.com,码迷

    2.接着设置第二个APP的url地址

    mamicode.com,码迷

    3.需要跳转的时候

    NSString *urlString = [NSString stringWithFormat:@"AppJumpSecond://%@",textField.text];
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:urlString]];

    我这里将textField的文字也传过去

    同样的,在第二个页面也是如此

    NSString *urlString = [NSString stringWithFormat:@"AppJumpFirst://%@",textField.text];
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:urlString]];

    这样就能相互跳转了

    4.处理传过去的数据

    在上面传了textField的数据,接收时在AppDelegate的

    - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation方法里。

    在AppDelegate里设置属性

    @property (nonatomic, strongRootViewController *rvc;

    在didFinishLaunchingWithOptions方法里添加

    self.rvc = [[RootViewController alloc] init];
    UINavigationController *nc = [[UINavigationController alloc] initWithRootViewController:self.rvc];
    self.window.rootViewController = nc;

    添加代码块

    - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
    {
        self.rvc.textField.text = [[url host] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
        return YES;
    }

    使得textField显示另一个页面传过来的数据。

    下面是APP(A)与APP(B)相互跳到转的demo

    http://download.csdn.net/detail/u012884714/7679105

     

     

     

    目标应用程序:
    打开info.plist,添加一项URL types
    展开URL types,再展开Item1,将Item1下的URL identifier修改为URL Scheme
    展开URL Scheme,将Item1的内容修改为myapp
    其他程序可通过myapp://访问此自定义URL
     
    要跳转至myapp的应用程序:
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"myapp://"]];

     

     

     

     

    iOS开发拓展篇—应用之间的跳转和数据传

    说明:本文介绍app如何打开另一个app,并且传递数据。

    一、简单说明

    新建两个应用,分别为应用A和应用B.

    实现要求:在appA的页面中点击对应的按钮,能够打开appB这个应用。

    1.新建两个应用,分别为A和B.

       

    2.设置应用B的url。

    3.在应用A中编写打开app的代码

    点击之后,会跳转到新的控制器。

    注意:打开应用B的过程中,B有两种状态。

    第一种状态:B并没有启动,那么会启动B。并调用下面的方法。

    第二种状态:此时B已经启动了,但是在后台运行,这个时候不会调用该方法。

    二:说明

    如果一个应用被另外一个应用打开,那么会调用下面的代理方法,且在该方法中可以实现两个应用之间数据的传递。

    代码说明:

    复制代码
     1 #import "YYAppDelegate.h"
     2 
     3 @implementation YYAppDelegate
     4 
     5 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
     6 {
     7     NSLog(@"didFinishLaunchingWithOptions---B");
     8     return YES;
     9 }
    10 
    11 //当一个应用程序被其他程序打开的时候会调用这个方法,在该方法中可以实现两个应用程序间的数据局传递
    12 -(BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
    13 {
    14     NSLog(@"%@",url);
    15     NSLog(@"%@",sourceApplication);
    16     return YES;
    17 }
    复制代码
  • 相关阅读:
    LTE
    LTE
    LTE
    LTE
    LTE DL-SCH and PDSCH Processing Chain
    LTE PDSCH Port 5 UE-Specific Beamforming
    推荐我的公众号
    GitHub Top 微信小程序
    深度前馈网络
    考研经历吐血总结
  • 原文地址:https://www.cnblogs.com/lvyinbentengzhe/p/4169558.html
Copyright © 2011-2022 走看看