0

Scroll Viewを追加するView Controllerがあります。次に、UITextFields の数を追加し、ユーザーが必要とするテキスト フィールドの数に応じて、UIScrollView.contentSize のサイズを動的に変更します。これまでのところ、デリゲート、contentSize プロパティのサイズ、テキスト フィールドの起点とサイズを確認し、再確認しました。これを行うには、次のコードを使用します。

-(void)setScrollViewSize
{
    NSLog(@"Rows count: %d", self.rows);
    self.matrixInputScrollView.contentSize = CGSizeZero;
    CGSize scrollVieSize;
    if (!self.columns) {
    NSLog(@"Setting scroll view frame row");
    scrollVieSize = CGSizeMake(self.rows * TEXT_FIELD_WIDTH + (self.rows - 1) * TEXT_FIELD_INDENT, TEXT_FIELD_HEIGHT);
    }
    else
    {
        NSLog(@"Setting scroll view frame rows and columns");
        scrollVieSize = CGSizeMake(self.rows * TEXT_FIELD_WIDTH + (self.rows - 1) * TEXT_FIELD_INDENT, self.columns * TEXT_FIELD_HEIGHT + (self.columns - 1) * TEXT_FIELD_INDENT);
    }
    self.matrixInputScrollView.contentSize = scrollVieSize;

     if (!self.columns) {
         for (NSInteger i = 0; i < self.rows; ++i) {
             NSLog(@"Text filed adding");
             UITextField *textField = [[UITextField alloc] initWithFrame:CGRectMake(i * (TEXT_FIELD_WIDTH + TEXT_FIELD_INDENT), 0, TEXT_FIELD_WIDTH, TEXT_FIELD_HEIGHT)];
             NSLog(@"uitextfield position ad size: %f %f %f %f", textField.frame.origin.x, textField.frame.origin.y, textField.frame.size.width, textField.frame.size.height);
             [self.matrixInputScrollView addSubview:textField];
         }
      }
      else
      {
          for (NSInteger i = 0; i < self.rows; ++i) {
             for (NSInteger j = 0; j < self.columns; ++j) {
                  UITextField *textField = [[UITextField alloc] initWithFrame:CGRectMake(i * (TEXT_FIELD_WIDTH + TEXT_FIELD_INDENT), j * (TEXT_FIELD_HEIGHT + TEXT_FIELD_INDENT), TEXT_FIELD_WIDTH, TEXT_FIELD_HEIGHT)];
                   [self.matrixInputScrollView addSubview:textField];
            }
         }
      }

    NSLog(@"Before setNeedsDisplay");
    NSLog(@"Scroll view position and size: %f %f %f %f",      self.matrixInputScrollView.frame.origin.x, self.matrixInputScrollView.frame.origin.y,   self.matrixInputScrollView.frame.size.width, self.matrixInputScrollView.frame.size.height);
    NSLog(@"Scroll view content size: %f %f", self.matrixInputScrollView.contentSize.width,    self.matrixInputScrollView.contentSize.height);
}

上記のサンプルの出力は次のとおりです。

2013-10-16 15:27:30.672 RZCalc[2765:a0b] Rows count: 3
2013-10-16 15:27:30.672 RZCalc[2765:a0b] Setting scroll view frame row
2013-10-16 15:27:30.673 RZCalc[2765:a0b] Text filed adding
2013-10-16 15:27:30.673 RZCalc[2765:a0b] uitextfield position ad size: 0.000000 0.000000 40.000000 30.000000
2013-10-16 15:27:30.674 RZCalc[2765:a0b] Text filed adding
2013-10-16 15:27:30.674 RZCalc[2765:a0b] uitextfield position ad size: 50.000000 0.000000 40.000000 30.000000
2013-10-16 15:27:30.674 RZCalc[2765:a0b] Text filed adding
2013-10-16 15:27:30.675 RZCalc[2765:a0b] uitextfield position ad size: 100.000000 0.000000 40.000000 30.000000
2013-10-16 15:27:30.675 RZCalc[2765:a0b] Before setNeedsDisplay
2013-10-16 15:27:30.676 RZCalc[2765:a0b] Scroll view position and size: 76.000000 42.000000 244.000000 246.000000
2013-10-16 15:27:30.676 RZCalc[2765:a0b] Scroll view content size: 140.000000 30.000000

ここに表示されているのは、スクロール ビューが作成されて画面に配置され、コンテンツ サイズがそれに応じてサイズ変更され、3 つのテキスト フィールドが作成されてスクロール ビューに追加され、原点とサイズが contentSize の制限内にあることです。

その結果、スクロール ビューが画面に表示され、テキスト フィールドは表示されません。

上記のコードに何か問題があるかどうか、またはそれについてさらに情報が必要かどうかを教えていただけますか?

4

1 に答える 1

1

コメントを回答として追加:

ラベルの背景色をスクロールビューの色とは異なる色に設定して、ラベルが存在するかどうかを確認します。ラベルの書式設定オプションを設定していないため、現時点では透明なビューになっている可能性があります。

于 2013-10-17T13:12:13.703 に答える