Я использую JSQMessagesViewController для реализации чата в своем приложении для iOS. Мне нужно отобразить некоторые системные сообщения в середине экрана (см. прикрепленное изображение). Я надеялся, что смогу добиться этого, используя нижнюю метку сообщения и не показывая всплывающее окно сообщения. Но я не нашел способа скрыть всплывающее окно с сообщением. Является ли это возможным? Спасибо.
можно ли скрыть всплывающее сообщение
Ответы (1)
Я как бы добился того, что мне нужно, переопределив функцию collectionView sizeForItemAtIndexPath
и вернув высоту kJSQMessagesCollectionViewCellLabelHeightDefault
, а затем вернув nil
для messageBubbleImageDataForItemAtIndexPath
и avatarImageDataForItemAtIndexPath
override func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize {
let userMessageCellSize = super.collectionView(collectionView, layout: collectionViewLayout, sizeForItemAtIndexPath: indexPath)
let message = messages[indexPath.item]
if message.type == MessageType.System {
// for system message, only show bottom label, plus the top label when timestamp needs to be displayed
// this will hide the avatar image and message bubble which are not needed for system messages.
var newHeight: CGFloat = 0
if (shouldDisplayTimestamp(indexPath)) {
newHeight = kJSQMessagesCollectionViewCellLabelHeightDefault * 2
} else {
newHeight = kJSQMessagesCollectionViewCellLabelHeightDefault
}
return CGSizeMake(userMessageCellSize.width, newHeight)
} else {
return super.collectionView(collectionView, layout: collectionViewLayout, sizeForItemAtIndexPath: indexPath)
}
}
override func collectionView(collectionView: JSQMessagesCollectionView!, messageBubbleImageDataForItemAtIndexPath indexPath: NSIndexPath!) -> JSQMessageBubbleImageDataSource! {
let message = messages[indexPath.item]
if message.type == MessageType.System {
return nil
}
if message.senderId == senderId{
return self.outgoingBubbleImageView
} else {
return self.incomingBubbleImageView
}
}
override func collectionView(collectionView: JSQMessagesCollectionView!, avatarImageDataForItemAtIndexPath indexPath: NSIndexPath!) -> JSQMessageAvatarImageDataSource! {
let message = messages[indexPath.item]
if message.type == MessageType.System {
return nil
}
if let avatar = avatars[message.senderDisplayName] {
return avatar
} else {
setupAvatarImage(message.senderDisplayName, imageUrl: message.profileImgUrl, incoming: true)
return avatars[message.senderDisplayName]
}
}
person
Quan Ding
schedule
17.03.2016
Можете ли вы поделиться своим кодом? Было бы здорово, потому что я пытаюсь сделать то же самое в Swift.
- person MJQZ1347; 27.03.2016