jeśli uważnie przeczytać komentarz powyżej aplikacji: metodą handleOpenURL, prawdopodobnie będzie zrozumieć:
// this happens while we are running (in the background, or from within our own app)
// only valid if Calinda-Info.plist specifies a protocol to handle
- (BOOL) application:(UIApplication*)application handleOpenURL:(NSURL*)url
Te metody nie zostanie wywołana, gdy wniosek nie jest bieganie. Moje rozwiązanie było dostosować projekt z następującymi zmianami:
MainViewController.h
@interface MainViewController : CDVViewController
@property (nonatomic, retain) NSString *URLToHandle;
@end
MainViewController.m
- (void) webViewDidFinishLoad:(UIWebView*) theWebView
{
if (self.URLToHandle)
{
NSString* jsString = [NSString stringWithFormat:@"window.setTimeout(function() {handleOpenURL(\"%@\"); },1);", self.URLToHandle];
[theWebView stringByEvaluatingJavaScriptFromString:jsString];
}
[...]
}
- (void)dealloc
{
self.URLToHandle = nil;
[super dealloc];
}
@synthesize URLToHandle;
AppDelegate.m
- (BOOL) application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
{
[...]
self.viewController = [[[MainViewController alloc] init] autorelease];
self.viewController.useSplashScreen = YES;
self.viewController.wwwFolderName = @"www";
self.viewController.startPage = @"index.html";
self.viewController.view.frame = viewBounds;
// Patch for handleOpenURL
((MainViewController *)self.viewController).URLToHandle = URLToHandle;
[...]
}
nadzieję, że pomoże.
Cyril
dodatkowe Uwaga: podczas testowania upewnij się zatrzymać Xcode. Gdy uruchomiono xcode, aplikacja wyrzuciłaby wyjątek. jeśli zatrzymam kod xcode to rozwiązanie działa dobrze.
mając ten sam problem w cordova 3.5 (tak, minęły lata, przypuszczam, że zostało to naprawione w niektórych wersjach). Teraz iOS przestarzałe handleOpenUrl itp., Nadal jednak poprawna odpowiedź poniżej powinna działać. – mentat