3

現在 iTunes で公開されているユニバーサル バイナリ アプリがあり、iOS 4.x から 5.1 の iPhone 3、4、4S、iPad 2 では正常に動作しますが、iOS 5.1 を実行している新しい iPad (3) では黒い UIImage が表示されます。

他の誰かがこれに遭遇しましたか?修正案はありますか?

問題は、NSData から読み込まれた UIImage が黒く表示されることです。

最初は NSData が nil または読み取り不能である可能性があると考えていたので、NSData の長さと UIImage サイズのプロパティを出力するために UIAlert と NSLog を追加しました (データを UIImage に正常に読み込むと適切なサイズの値が生成されると仮定します)。UIAlert ではすべて問題ないように見えます...

// MyView.m

- (NSData*)getImageData

{      

     Screening *screen = [[Model sharedInstance] screenInProgress];

     return screen.anteriorImage;  // returns the NSData from the managed 'Screening' object

}


- (void)viewWillAppear:(BOOL)animated

{
     NSData *imagedata = [self getImageData];

     UIImage *image = [UIImage imageWithData:imagedata];

     [clientImageView setImage:image];     /// UIImageView in nib




     /// apply user grid
     NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];


     if ([defaults integerForKey:@"com.ikonetics.posture.gridoverlay"] >= 0) {     

          UIImageView *grid = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"grid.png"]];

          [grid setBackgroundColor:[UIColor clearColor]];

          [grid setAlpha:0.6f];

          [grid setFrame:clientImageView.frame];

          [screenshotWrapper addSubview:grid];     // screenshotWrapper is a UIView in xib arranged as a parent to other views

          [grid release];

     }


     NSString *note = [NSString 

                           stringWithFormat:@"NSData length: %d \nUIImage size: %@ \nUIImage scale: %1.f \nClientImage info: %@"

                           , [imagedata length]

                           , NSStringFromCGSize(image.size)

                           , image.scale

                           , [clientImageView description]

                           ];



     NSLog(@"debug note: %@ ", note);

     UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"DEBUG INFO" 

                                                                 message:note

                                                               delegate:nil

                                                    cancelButtonTitle:@"OK"

                                                    otherButtonTitles:nil];

     [alert show];   

     [alert release];



}



// Screening.h

@interface Screening : NSManagedObject


@property (nonatomic, retain) NSData * anteriorImage;     // this data is stored elsewhere using UIImageJPEGRepresentation(image, 0.8);
...
@end

UIAlertView を表示している iPad 3 のスクリーンショット。NSData には長さがあり、UIImage にはサイズがあり、UIImageView (ClientImage) には適切なフレームがあり、グリッド オーバーレイ UIImage が期待どおりに正しく表示されていることがわかります。

  • 返された NSData には長さがありますが、そうではありませんnil (以下の 187433)。
  • UIImage はデータを解析して画像を構築できました。サイズとスケールのプロパティによる証拠(784、980)

iPad3のスクリーンショット

最後に、これもオプションを無効にしてテストされている/// apply user gridため、そのコード ブロックが実行されないため、オーバーレイ png はインスタンス化されません。黒の UIImage の問題は解決しません。

実際の画像ではなく黒い UIImage を表示する UIImageView に問題がある人はいますか? これが iPad 3 で正しく動作するようにコードを修正する方法についての考えやアイデアはありますか?

ありがとう!

編集 - その他のデバッグ情報:

NSData (imagedata) を電子メールに書き出して、デバイスから表示できるようにしました。おそらく画像自体が空白/黒であるかどうかを調べたかったのですが、デバイスから保存したときにデータが画像として正しく表示されることを知りました(空白ではありません)。

そのため、UIImage と UIImageView に読み込まれた NSData は黒く表示されますが、メールに添付すると画像が正しく表示されます。

さらに、ビューの階層が意図したとおりに表示されるようにしたかったのです。私の画像が別のビューの下にないことを確認してください。ViewController から始めてviewをログに記録recursiveDescriptionし、iPad 3 のビューの階層が iPad 2 と一致していることを知りました。

新しいデバッグ コード:

NSString *note = [NSString 
                  stringWithFormat:@"NSData length: %d \nUIImage size: %@ \nUIImage scale: %1.f \nRecursive info: %@"
                  , [imagedata length]
                  , NSStringFromCGSize(image.size)
                  , image.scale
                  , [[self view] recursiveDescription]
                  ];

MFMailComposeViewController *mailViewController = [[MFMailComposeViewController alloc] init];
mailViewController.mailComposeDelegate = self;
[mailViewController setSubject:@"Debug email"];
[mailViewController setMessageBody:note isHTML:NO];
[mailViewController addAttachmentData:imagedata mimeType:@"image/jpg" fileName:@"imagedata.jpg"];

[self presentModalViewController:mailViewController animated:YES];
[mailViewController release];

最後に、2 台と 3 台の両方のデバイスからの再帰的なログ情報を次に示します。

iPad 2 ログ:

NSData length: 123254 
UIImage size: {800, 960} 
UIImage scale: 1 
Recursive info: <UIView: 0x10a91620; frame = (0 0; 768 960); autoresize = W+H; layer = <CALayer: 0x10a91650>>
   | <UIScrollView: 0x10a90a10; frame = (0 0; 768 960); clipsToBounds = YES; autoresize = RM+TM; layer = <CALayer: 0x10a90bb0>; contentOffset: {0, 0}>
   |    | <UIView: 0x10a90be0; frame = (0 0; 1536 1920); autoresize = LM+RM+TM+BM; layer = <CALayer: 0x10a90c10>>
   |    |    | <UIView: 0x10a90c40; frame = (384 480; 768 960); autoresize = LM+RM+TM+BM; layer = <CALayer: 0x10a90c70>>
   |    |    |    | <UIImageView: 0x10a908f0; frame = (0 0; 768 960); opaque = NO; autoresize = LM+RM+TM+BM; userInteractionEnabled = NO; layer = <CALayer: 0x10a90930>>
   |    |    |    | <LineView_iPad: 0x10a90ce0; frame = (0 0; 768 960); autoresize = LM+RM+TM+BM; userInteractionEnabled = NO; layer = <CALayer: 0x10a90d20>>
   |    |    |    | <PointView_iPad: 0x10a90dd0; frame = (0 0; 768 960); autoresize = LM+RM+TM+BM; layer = <CALayer: 0x10a90e20>>
   |    |    |    | <UIImageView: 0x10a96480; frame = (0 0; 768 960); alpha = 0.6; opaque = NO; userInteractionEnabled = NO; layer = <CALayer: 0x10a966e0>>
   | <UIView: 0x10a91680; frame = (-10 750; 220 220); autoresize = RM+TM; layer = <CALayer: 0x10a916b0>>
   |    | <UIImageView: 0x10a916e0; frame = (0 0; 220 220); autoresize = W+H; userInteractionEnabled = NO; layer = <CALayer: 0x10a91720>>
   |    | <UIImageView: 0x10a91480; frame = (10 10; 200 200); autoresize = RM+BM; userInteractionEnabled = NO; layer = <CALayer: 0x10a914c0>>
   |    | <UIImageView: 0x10a91840; frame = (102 102; 16 16); autoresize = RM+BM; userInteractionEnabled = NO; layer = <CALayer: 0x10a91880>>

iPad 3 ログ:

NSData length: 166252
UIImage size: {784, 980}
UIImage scale: 1
Recursive info: <UIView: 0xc669470; frame = (0 0; 768 980); autoresize = W+H; layer = <CALayer: 0xc667550>>
 | <UIScrollView: 0x33d410; frame = (0 20; 768 960); clipsToBounds = YES; autoresize = RM+TM; layer = <CALayer: 0x325840>; contentOffset: {0, 0}>
 |    | <UIView: 0x308630; frame = (0 0; 1536 1920); autoresize = LM+RM+TM+BM; layer = <CALayer: 0xc666f40>>
 |    |    | <UIView: 0x318970; frame = (384 480; 768 960); autoresize = LM+RM+TM+BM; layer = <CALayer: 0xc682a70>>
 |    |    |    | <UIImageView: 0xc66cd60; frame = (0 0; 768 960); opaque = NO; autoresize = LM+RM+TM+BM; userInteractionEnabled = NO; layer = <CALayer: 0xc672c00>>
 |    |    |    | <LineView_iPad: 0x301680; frame = (0 0; 768 960); autoresize = LM+RM+TM+BM; userInteractionEnabled = NO; layer = <CALayer: 0x329fa0>>
 |    |    |    | <PointView_iPad: 0xc6841b0; frame = (0 0; 768 960); autoresize = LM+RM+TM+BM; layer = <CALayer: 0xc672b10>>
 |    |    |    | <UIImageView: 0xc588b70; frame = (0 0; 768 960); alpha = 0.6; opaque = NO; userInteractionEnabled = NO; layer = <CALayer: 0xc589500>>
 | <UIView: 0x324330; frame = (-10 770; 220 220); autoresize = RM+TM; layer = <CALayer: 0xc687970>>
 |    | <UIImageView: 0xc665b80; frame = (0 0; 220 220); autoresize = W+H; userInteractionEnabled = NO; layer = <CALayer: 0x321490>>
 |    | <UIImageView: 0x314e50; frame = (10 10; 200 200); autoresize = RM+BM; userInteractionEnabled = NO; layer = <CALayer: 0xc684f30>>
 |    | <UIImageView: 0x63d220; frame = (102 102; 16 16); autoresize = RM+BM; userInteractionEnabled = NO; layer = <CALayer: 0xc580d90>>

この投稿は耐えられないほど長いですが、誰かがこの問題を引き起こす可能性のある何かを考えてくれることを願っています...

4

1 に答える 1

2

これは iOS のバグのようです。これは回避策です:

  • Interface Builder で、UIImageView の背景テクスチャを任意の色に変更します

それでおしまい。

デバッグ中に、何か面白いことを起こそうとスイッチを任意に切り替えているときに、これに出くわしました。私のコード/アプリは UIImageView の背景色を使用していません。そのプロパティは調整されていません...これまでに?

上記のコードでは、UIImageView「clientImageView」の背景にテクスチャ「View Flipside Background Color」が設定されています。そのテクスチャを背景として設定すると、ロードされた UIImage の表示が拒否されました。背景テクスチャを Flipside 以外のものに変更し、UIImage を期待どおりに表示しました。

  • 私たちが行った唯一の変更は、Interface Builder 内の UIImageView の背景色プロパティです。
  • エラーが表示された唯一の場所は、iOS 5.1 を実行している iPad 3 ハードウェアでした。
  • 毎回失敗し、再現可能です
  • iOS 4.x から 5.1 の Phone 4、4S、iPad 2 でもテスト済み

バグ ID# 11080928 として Apple に報告

于 2012-03-20T14:06:24.407 に答える