如何在视图右侧设置气球图像?

时间:2014-03-31 20:46:12

标签: ios objective-c ipad offset cgfloat

上下文:

我正在构建一个聊天应用,我使用了来自apple sample的代码。

它看起来与本机消息应用程序完全一样。我的问题出在我正在实施的iPad版本上。

这是一张图片:

enter image description here

正如你在图片中看到的那样,我需要将右边的气球放在屏幕的右边缘

我追踪代码,然后缩小需要调整的代码块。

// Comput the X,Y origin offsets
CGFloat xOffsetLabel;
CGFloat xOffsetBalloon;
CGFloat yOffset;

if (TRANSCRIPT_DIRECTION_SEND == transcript.direction) {//
    // Sent messages appear or right of view
    xOffsetLabel = 320 - labelSize.width - (BALLOON_WIDTH_PADDING / 2) - 3;
    xOffsetBalloon = 320 - balloonSize.width;
    yOffset = BUFFER_WHITE_SPACE / 2;
    _nameLabel.text = @"";
    // Set text color
    _messageLabel.textColor = [UIColor whiteColor];
    // Set resizeable image
    _balloonView.image = [self.balloonImageRight resizableImageWithCapInsets:_balloonInsetsRight];
}
else {
    // Received messages appear on left of view with additional display name label
    xOffsetBalloon = 0;
    xOffsetLabel = (BALLOON_WIDTH_PADDING / 2) + 3;
    yOffset = (BUFFER_WHITE_SPACE / 2) + nameSize.height - NAME_OFFSET_ADJUST;
    if (TRANSCRIPT_DIRECTION_LOCAL == transcript.direction) {
        _nameLabel.text = @"user";
    }
    else {
        _nameLabel.text = @"Admin"; //nameText;
    }
    // Set text color
    _messageLabel.textColor = [UIColor darkTextColor];
    // Set resizeable image
    _balloonView.image = [self.balloonImageLeft resizableImageWithCapInsets:_balloonInsetsLeft];
}

// Set the dynamic frames
_messageLabel.frame = CGRectMake(xOffsetLabel, yOffset + 5, labelSize.width, labelSize.height);
_balloonView.frame = CGRectMake(xOffsetBalloon, yOffset, balloonSize.width, balloonSize.height);
_nameLabel.frame = CGRectMake(xOffsetLabel - 2, 1, nameSize.width, nameSize.height);

不幸的是,我试图将绿色气球放到右边是不成功的(我只能更多地将文本内容放到右边而不是气球本身)。任何想法?

1 个答案:

答案 0 :(得分:2)

下面:

xOffsetLabel = 320 - labelSize.width - (BALLOON_WIDTH_PADDING / 2) - 3;
xOffsetBalloon = 320 - balloonSize.width;

320是iPhone屏幕的宽度。需要将其更改为iPad的宽度(1024或768,具体取决于方向)。

当然,您的视图也需要与iPad屏幕一样宽,所以请确保它的大小也已调整。