0

tableviewcontrollerIB の a の上にドラッグ アンド ドロップして UIView を追加し、その に andIBoutletを割り当てましたUIView

問題は、サイズを動的に変更する uilabel があることです。したがって、uilabel が短い場合は、テーブルビューを近づけたいと考えています。それ以外の場合は、テーブルビューをそれほど近づけないで、非常に長いラベルを表示できるようにする必要があります。

だから私はフレームサイズを変更するuiviewuiviewの上にあるフレームを変更しようとしますが、tableviewはそこで安定したままです。tableview

フレームサイズの高さを大きくuitableviewするとダウンさせたいUIview

if ([[self agenda] getMeetingTime] != nil) {
        descriptionLabel = [[UILabel alloc] initWithFrame:CGRectMake(50, dateLabel.frame.origin.y + dateLabel.bounds.size.height+15, self.view.frame.size.width-75, 150)];
        descriptionLabel.textColor =[UIColor colorWithRed:96/256.0 green:96/256.0 blue:96/256.0 alpha:1.0];
        descriptionLabel.font = [UIFont fontWithName:@"GillSans" size:15.0f];
        descriptionLabel.text =[[self agenda] getMeetingTime];
        descriptionLabel.backgroundColor = [UIColor clearColor];
        descriptionLabel.numberOfLines=0;
        descriptionLabel.tag=PopulateTag;

        //Calculate the expected size based on the font and linebreak mode of your label
        CGSize maximumLabelSize = CGSizeMake(709,999);

        CGSize expectedLabelSize = [descriptionLabel.text sizeWithFont:descriptionLabel.font
                                              constrainedToSize:maximumLabelSize
                                                  lineBreakMode:descriptionLabel.lineBreakMode];

        //adjust the label the the new height.
        CGRect newFrame = descriptionLabel.frame;
        newFrame.size.height = expectedLabelSize.height;
        descriptionLabel.frame=newFrame;


        if ( expectedLabelSize.height>70) {

            self.upperView.frame = CGRectMake(0, 0, self.upperView.frame.size.width, self.upperView.frame.size.height+expectedLabelSize.height+20);

        }
        else
        {
            self.upperView.frame = CGRectMake(0, 0, self.upperView.frame.size.width, self.upperView.frame.size.height+expectedLabelSize.height);
        }


        [ self.upperView addSubview: descriptionLabel];


    }


    //black line
    UIView *line = [[UIView alloc] initWithFrame:CGRectMake(10, descriptionLabel.frame.origin.y + descriptionLabel.bounds.size.height+15, descriptionLabel.frame.size.width+50, 1)];
    line.backgroundColor=[UIColor colorWithRed:164/256.0 green:165/256.0 blue:160/256.0 alpha:1.0];
    line.tag=PopulateTag;

    [self.upperView addSubview:line];

      //this does not work pushes whole view down
     //self.restOfView.frame=CGRectMake(10, line.frame.origin.y + line.bounds.size.height+1, self.upperView.frame.size.width, 600);
    [restOfView reloadData];

IB について:

ここに画像の説明を入力

ここに画像の説明を入力

これが起こることです:

ここに画像の説明を入力

Tableview のニーズはここまで

ここに画像の説明を入力

どうすればこの問題を解決できますか?

4

1 に答える 1