Bubbles: clean and add changelog

This commit is contained in:
ganfra 2022-02-22 15:16:06 +01:00
parent d0413aef55
commit 9911233038
2 changed files with 4 additions and 65 deletions

1
changelog.d/5303.misc Normal file
View File

@ -0,0 +1 @@
Improve Bubble layouts rendering.

View File

@ -70,7 +70,8 @@ class MessageBubbleContentLayout @JvmOverloads constructor(context: Context, att
if (textLineCount == 1 && contentContainerView.measuredWidth + timeViewMeasuredWidthWithMargins < maxContentWidth) { if (textLineCount == 1 && contentContainerView.measuredWidth + timeViewMeasuredWidthWithMargins < maxContentWidth) {
width = contentContainerView.measuredWidth + timeViewMeasuredWidthWithMargins width = contentContainerView.measuredWidth + timeViewMeasuredWidthWithMargins
height = contentContainerView.measuredHeight height = contentContainerView.measuredHeight
} else if (textLineCount > 1 && lastLineWidth + timeViewMeasuredWidthWithMargins < contentContainerView.measuredWidth - contentContainerView.paddingEnd) { } else if (textLineCount > 1 && lastLineWidth + timeViewMeasuredWidthWithMargins
< contentContainerView.measuredWidth - contentContainerView.paddingEnd) {
width = contentContainerView.measuredWidth width = contentContainerView.measuredWidth
height = contentContainerView.measuredHeight height = contentContainerView.measuredHeight
} else { } else {
@ -120,67 +121,4 @@ class MessageBubbleContentLayout @JvmOverloads constructor(context: Context, att
super.onLayout(changed, left, top, right, bottom) super.onLayout(changed, left, top, right, bottom)
} }
} }
/*
override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {
val widthConstraints = paddingStart + paddingEnd
val heightConstraints = paddingTop + paddingBottom
val measuredWidth = MeasureSpec.getSize(widthMeasureSpec)
val width: Int
val height: Int
val maxAvailableWidth = min(measuredWidth, maxWidth)
measureChild(timeView, widthMeasureSpec, heightMeasureSpec)
val messageTextView = this.messageTextView
if (messageTextView != null) {
val newWidthMeasureSpec = MeasureSpec.makeMeasureSpec(maxAvailableWidth, MeasureSpec.AT_MOST)
measureChild(contentContainerView, newWidthMeasureSpec, heightMeasureSpec)
val textLineCount = messageTextView.lineCount
val lastLineWidth = if (textLineCount != 0) messageTextView.layout.getLineWidth(textLineCount - 1) else 0f
if (textLineCount == 1 && contentContainerView.measuredWidth + widthConstraints + timeViewMeasuredWidthWithMargins < measuredWidth) {
width = contentContainerView.measuredWidth + timeViewMeasuredWidthWithMargins + widthConstraints
height = contentContainerView.measuredHeight + heightConstraints
} else if (textLineCount > 1 && lastLineWidth + widthConstraints + timeViewMeasuredWidthWithMargins < contentContainerView.measuredWidth - contentContainerView.paddingEnd) {
width = contentContainerView.measuredWidth + widthConstraints
height = contentContainerView.measuredHeight + heightConstraints
} else {
width = contentContainerView.measuredWidth + widthConstraints
height = contentContainerView.measuredHeight + heightConstraints + timeView.measuredHeight
}
} else {
if (contentOverlayView.isVisible) {
val newWidthMeasureSpec = MeasureSpec.makeMeasureSpec(maxAvailableWidth, MeasureSpec.AT_MOST)
measureChild(contentContainerView, newWidthMeasureSpec, heightMeasureSpec)
val overlayWidthSpec = MeasureSpec.makeMeasureSpec(contentContainerView.measuredWidth, MeasureSpec.EXACTLY)
val overlayHeightSpec = MeasureSpec.makeMeasureSpec(contentContainerView.measuredHeight, MeasureSpec.EXACTLY)
contentOverlayView.measure(overlayWidthSpec, overlayHeightSpec)
width = contentContainerView.measuredWidth
height = contentContainerView.measuredHeight
} else {
val newWidthMeasureSpec = MeasureSpec.makeMeasureSpec(maxAvailableWidth, MeasureSpec.AT_MOST)
measureChild(contentContainerView, newWidthMeasureSpec, heightMeasureSpec)
width = contentContainerView.measuredWidth
height = contentContainerView.measuredHeight + timeView.measuredHeight
}
}
setMeasuredDimension(width, height)
}
override fun onLayout(changed: Boolean, left: Int, top: Int, right: Int, bottom: Int) {
val parentLeft: Int = paddingLeft
val parentRight: Int = right - left - paddingRight
val parentTop: Int = paddingTop
val parentBottom: Int = bottom - top - paddingBottom
val contentRight = parentLeft + contentContainerView.measuredWidth
val contentBottom = parentTop + contentContainerView.measuredHeight
contentContainerView.layout(parentLeft, parentTop, contentRight, contentBottom)
if (contentOverlayView.isVisible) {
contentOverlayView.layout(parentLeft, parentTop, contentRight, contentBottom)
}
timeView.layout(parentRight - timeView.measuredWidth - timeViewMargins, parentBottom - timeView.measuredHeight - timeViewMargins, parentRight, parentBottom)
}
*/
} }