1

PKPass を返すサーバーをセットアップしました。URL をブラウザーにコピーすると、パスが表示されます (Mac と iPhone の両方で)。パスをダウンロードするために使用しているコードは次のとおりです。

NSData *data = [[NSData alloc] initWithContentsOfURL:[NSURL URLWithString:kAPIPass]];
if (nil != data) {
    PKPass *pass = [[PKPass alloc] initWithData:data error:nil];
    PKAddPassesViewController *pkvc = [[PKAddPassesViewController alloc] initWithPass:pass];
    pkvc.delegate = self;
    [self presentViewController:pkvc
                       animated:YES
                     completion:^{
                         // Do any cleanup here
                     }
     ];
}

とにかく、このコードを実行すると、次のエラーが発生します。

*キャッチされない例外 'NSInternalInconsistencyException' が原因でアプリを終了します。理由: 'RGBA または白色空間のみをサポートします。このメソッドはハックです。'

何がバグなのかわかりません... Safariでダウンロードするとパスは問題ないように見え、コードも問題ないようです(単純な行が3つしかありません...) Passkitの経験者が助けてくれますか?

編集:奇妙なことは、まったく同じコードが新しいプロジェクトで機能していることです

編集 2: AppDelegate から次の行を削除し、クラッシュを削除します。これは奇妙です!

[[UINavigationBar appearance] setTintColor:[UIColor colorWithPatternImage:[UIImage imageNamed:@"navbar_bg_gen.png"]]];
4

3 に答える 3

3

スイフト3

これは、完了ハンドラーを使用してサーバーから .pkpass (passbook ファイル) をダウンロードし、さらに Apple ウォレットに追加するために pkpassviewcontroller を表示するコードです。

import PassKit


let url : NSURL! = NSURL(string: "YOUR .pkpass URL GOES HERE")
        let request: NSURLRequest = NSURLRequest(url:
            url as URL)
        let config = URLSessionConfiguration.default
        let session = URLSession(configuration: config)

    let task : URLSessionDataTask = session.dataTask(with: request as URLRequest, completionHandler: {(data, response, error) in

        var error: NSError?
        let pass = try? PKPass(data: data!, error: &error)
        if error != nil {
            DispatchQueue.main.async {
                let alertView = UIAlertView(title: "Error", message: (error?.localizedDescription)!, delegate: nil, cancelButtonTitle: "OK", otherButtonTitles: "Cancel")
                alertView.show()
            }
        }
        else {
            let passLibrary = PKPassLibrary()
            if passLibrary.containsPass(pass!) {
                DispatchQueue.main.async {
                    let alertView = UIAlertView(title: "Already Exist", message: "This pass already added in wallet. Thanks!", delegate: nil, cancelButtonTitle: "OK", otherButtonTitles: "Cancel")
                    alertView.show()
                    self.hideLoading()
                }
            } else {
                let pkvc = PKAddPassesViewController(pass: pass!)
                pkvc.delegate = self
                self.present(pkvc, animated: true, completion: {() -> Void in
                    // Do any cleanup here
                    self.hideLoading()
                })

            }
        }

    })
    task.resume()
于 2017-03-13T10:37:03.040 に答える
2

PKAddPassesViewController現在の状態のコードは、パスをユーザーに提示するために を呼び出しません。

パス ライブラリが利用可能であると仮定すると、iOS6 および iOS7 で指定した URL で次のように動作します。

NSData *data = [[NSData alloc] initWithContentsOfURL:[NSURL URLWithString:kAPIPass]];

if (nil != data) {
    PKPass *pass = [[PKPass alloc] initWithData:passData error:&error];

    if(error) {

        UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Error" message:[error localizedDescription] delegate:nil cancelButtonTitle:@"OK"otherButtonTitles:nil];
        [alertView show];

    } else {

        PKAddPassesViewController *pkvc = [[PKAddPassesViewController alloc] initWithPass:pass];
        pkvc.delegate = self;
        [self presentViewController:pkvc
                           animated:YES
                         completion:^{
                                      // Do any cleanup here                     
                                     }
        ]; 
    }                       
}

または、メイン スレッドをブロックしないように非同期でロードすることもできます。

[NSURLConnection sendAsynchronousRequest:_request 
                                   queue:_browser 
                       completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) {

    if (nil != error) {
        // handle error
    } else if (nil != data) {
        PKPass *pass = [[PKPass alloc] initWithData:passData error:&error];

        if(error) {

            UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Error" message:[error localizedDescription] delegate:nil cancelButtonTitle:@"OK"otherButtonTitles:nil];
            [alertView show];

        } else {

            vc = [[PKAddPassesViewController alloc] initWithPass:pass];
            pkvc.delegate = self;
            [self presentViewController:pkvc
                               animated:YES
                             completion:^{
                                          // Do any cleanup here                     
                                         }
            ]; 
        }
    }
}];    
于 2013-06-25T01:27:38.037 に答える
0

したがって、問題は AppDelegate の次の行でした。

[[UINavigationBar appearance] setTintColor:[UIColor colorWithPatternImage:[UIImage imageNamed:@"navbar_bg_gen.png"]]];

通帳を追加するまでは問題なく動作していた画像が、通帳を表示するコントローラーに気に入られないようです。

于 2013-06-25T13:08:22.637 に答える