我正在尝试为已设置尺寸的图像周围的文本创建“包装”效果。

         ___________
........|
........| image
label.1.|
........|___________
....................
.......label.2......
....................
....................

这是即时通讯使用的方法:
- (NSArray *)splitString:(NSString*)str maxCharacters:(NSInteger)maxLength { //this will split the string to add to two UILabels
    NSMutableArray *tempArray = [NSMutableArray arrayWithCapacity:1];
    NSArray *wordArray = [str componentsSeparatedByCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
    NSInteger numberOfWords = [wordArray count];
    NSInteger index = 0;
    NSInteger lengthOfNextWord = 0;

    while (index < numberOfWords) {
        NSMutableString *line = [NSMutableString stringWithCapacity:1];
        while ((([line length] + lengthOfNextWord + 1) <= maxLength) && (index < numberOfWords)) {
            lengthOfNextWord = [[wordArray objectAtIndex:index] length];
            [line appendString:[wordArray objectAtIndex:index]];
            index++;
            if (index < numberOfWords) {
                [line appendString:@" "];
            }
        }
        [tempArray addObject:line];
    }
    return tempArray;
}

我给它我要分割文本的位置的maxCharacters值,这是第一个UILabel的最大高度。这种方法本质上就是我想要的方法,但是有时第一个UILabel的最后一行比其他的“高”行,从而在第一个UILabel和第二个UILabel之间留有空隙。

这是我使用方法的方式:
NSArray *splitStringArray = [self splitString:eventRecord.summary maxCharacters:280];

    UILabel *firstSumValue = [[UILabel alloc] init];
    NSString *firstSumString = [splitStringArray objectAtIndex:0];
    CGSize maxFirstSumSize = CGSizeMake(185.0,150.0);
    UIFont *firstSumFont = [UIFont fontWithName:@"HelveticaNeue-Bold" size:12];
    CGSize firstSumStringSize = [firstSumString sizeWithFont:firstSumFont
                                     constrainedToSize:maxFirstSumSize
                                         lineBreakMode:firstSumValue.lineBreakMode];



    CGRect firstSumFrame = CGRectMake(10.0, presentedValue.frame.origin.y + presentedValue.frame.size.height, 185.0, firstSumStringSize.height);


    firstSumValue.frame = firstSumFrame;

    firstSumValue.font = [UIFont fontWithName:@"HelveticaNeue" size:12];
    firstSumValue.lineBreakMode = UILineBreakModeWordWrap;
    firstSumValue.numberOfLines = 0 ;
    [self.mainScrollView addSubview:firstSumValue];



    firstSumValue.text = [splitStringArray objectAtIndex:0];


    UILabel *secondSumValue = [[UILabel alloc] init];

    NSInteger isSecond = 0;  //no
    if([splitStringArray count] > 1){
        isSecond = 1;  //yes

        NSString *secondSumString = [splitStringArray objectAtIndex:1];
        CGSize maxSecondSumSize = CGSizeMake(310.0,9999.0);
        UIFont *secondSumFont = [UIFont fontWithName:@"HelveticaNeue-Bold" size:12];
        CGSize secondSumStringSize = [secondSumString sizeWithFont:secondSumFont
                                               constrainedToSize:maxSecondSumSize
                                                   lineBreakMode:secondSumValue.lineBreakMode];



        CGRect secondSumFrame = CGRectMake(10.0, firstSumValue.frame.origin.y + firstSumValue.frame.size.height, 310.0, secondSumStringSize.height);


        secondSumValue.frame = secondSumFrame;

        secondSumValue.font = [UIFont fontWithName:@"HelveticaNeue" size:12];
        secondSumValue.lineBreakMode = UILineBreakModeWordWrap;
        secondSumValue.numberOfLines = 0 ;
        [self.mainScrollView addSubview:secondSumValue];


         secondSumValue.text = [splitStringArray objectAtIndex:1];


    }

如何使所有内容保持一致并正确对齐。也许,有一种更好的方法可以推荐。不是核心文字,因为它超出了我的知识范围。

最佳答案

考虑改用UIWebView,其布局在本地HTML文件中定义。它可以让您省去很多麻烦,而不必尝试手动处理复杂的布局。

关于iphone - 准确无缝地将文本分成两个UILabel,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7542156/

10-10 20:45