优化直播间聊天消息换行的问题

This commit is contained in:
老皮 2024-10-15 16:40:11 +08:00
parent 8d0cf94d46
commit fb340a152b

View File

@ -52,6 +52,8 @@ import com.yunbao.common.utils.WordUtil;
import com.yunbao.live.R; import com.yunbao.live.R;
import com.yunbao.live.bean.LiveChatBean; import com.yunbao.live.bean.LiveChatBean;
import net.lucode.hackware.magicindicator.buildins.UIUtil;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -282,7 +284,6 @@ public class LiveTextRender {
*/ */
private void createPrefix(Drawable levelDrawable, LiveChatBean bean, CreatePrefixCallback createPrefixCallback) { private void createPrefix(Drawable levelDrawable, LiveChatBean bean, CreatePrefixCallback createPrefixCallback) {
// if (bean.getGuardType() != Constants.GUARD_TYPE_NONE) {//守护图标 // if (bean.getGuardType() != Constants.GUARD_TYPE_NONE) {//守护图标
// Drawable drawable; // Drawable drawable;
// if (bean.getGuardType() == Constants.GUARD_TYPE_MONTH) { // if (bean.getGuardType() == Constants.GUARD_TYPE_MONTH) {
@ -458,6 +459,103 @@ public class LiveTextRender {
} }
private void createPrefixNew(Drawable levelDrawable, LiveChatBean bean,TextView textView, CreatePrefixCallback createPrefixCallback) {
getGuardImage(CommonAppContext.sInstance, bean.getGuardType(), new ImgLoader.DrawableCallback() {
@Override
public void onLoadSuccess(Drawable drawable) {
show(drawable);
}
@Override
public void onLoadFailed() {
show(null);
}
void show(Drawable drawable) {
SpannableStringBuilder builder = new SpannableStringBuilder();
int[] prefixWidthHolder = {0}; // 用于累加 prefixWidth
// 定义一个辅助方法来添加 Drawable 并累加宽度
// 见上述 appendDrawable 方法定义
// 添加 levelDrawable
if (levelDrawable != null) {
appendDrawable(builder, levelDrawable, 17, 17, textView, prefixWidthHolder);
}
// 添加贵族图标
if (gzDrawablesMap.containsKey(bean)) {
Drawable gzDrawable = gzDrawablesMap.get(bean);
appendDrawable(builder, gzDrawable, 35, 20, textView, prefixWidthHolder);
}
// 添加荣誉勋章
if (ryxzDrawablesMap.containsKey(bean)) {
Drawable ryxzDrawable = ryxzDrawablesMap.get(bean);
appendDrawable(builder, ryxzDrawable, 18, 18, textView, prefixWidthHolder);
}
// 添加靓号图标
if (nhDrawablesMap.containsKey(bean)) {
Drawable nhDrawable = nhDrawablesMap.get(bean);
appendDrawable(builder, nhDrawable, 17, 17, textView, prefixWidthHolder);
}
// 添加其他 Drawable
if (drawable != null) {
appendDrawable(builder, drawable, 34, 17, textView, prefixWidthHolder);
}
// 添加粉丝徽章
if (!TextUtils.isEmpty(bean.getMedalNmae()) && !TextUtils.isEmpty(bean.getMedalLevelImageUrl())
&& !bean.getMedalNmae().equals("null") && !bean.getMedalNmae().equals("(null)") && !bean.getMedalNmae().equals("<null>")) {
Drawable medalDrawable = getMedalImage(bean);
if (medalDrawable != null) {
appendDrawable(builder, medalDrawable, 44, 17, textView, prefixWidthHolder);
}
}
// 添加直播间管理员图标
if (bean.isManager()) {
Drawable managerDrawable = ContextCompat.getDrawable(CommonAppContext.sInstance, R.mipmap.icon_live_chat_m);
if (managerDrawable != null) {
appendDrawable(builder, managerDrawable, 17, 14, textView, prefixWidthHolder);
}
}
// 添加靓号图标
if (!TextUtils.isEmpty(bean.getLiangName())) {
Drawable liangDrawable = ContextCompat.getDrawable(CommonAppContext.sInstance, R.mipmap.icon_live_chat_liang);
if (liangDrawable != null) {
appendDrawable(builder, liangDrawable, 17, 14, textView, prefixWidthHolder);
}
}
// 获取最终的 prefixWidth
int prefixWidth = prefixWidthHolder[0];
createPrefixCallback.onPrefixCallback(builder, prefixWidth);
}
});
}
private void appendDrawable(SpannableStringBuilder builder, Drawable drawable, int widthDp, int heightDp, TextView textView, int[] prefixWidthHolder) {
if (drawable != null) {
int index = builder.length();
builder.append("\uFFFC ");
drawable.setBounds(0, 0, DpUtil.dp2px(widthDp), DpUtil.dp2px(heightDp));
builder.setSpan(new VerticalImageSpan(drawable), index, index + 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
prefixWidthHolder[0] += drawable.getBounds().width();
// 计算空格的宽度并累加
TextPaint paint = textView.getPaint();
float spaceWidth = paint.measureText(" ");
prefixWidthHolder[0] += (int) spaceWidth;
}
}
private Drawable getMedalImage(final LiveChatBean bean) { private Drawable getMedalImage(final LiveChatBean bean) {
View view = LayoutInflater.from(CommonAppContext.sInstance).inflate(R.layout.live_medal_icon, null, false); View view = LayoutInflater.from(CommonAppContext.sInstance).inflate(R.layout.live_medal_icon, null, false);
@ -501,6 +599,7 @@ public class LiveTextRender {
@Override @Override
public void onLoadFailed() { public void onLoadFailed() {
gz(context, textView, bean); gz(context, textView, bean);
} }
}); });
} }
@ -707,13 +806,11 @@ public class LiveTextRender {
private void renderTMP(Context context, final TextView textView, final LiveChatBean bean) { private void renderTMP(Context context, final TextView textView, final LiveChatBean bean) {
if (textView != null) { if (textView != null) {
getLiveLevelImage(context, bean.getLevel(), false, new ImgLoader.DrawableCallback() { getLiveLevelImage(context, bean.getLevel(), false, new ImgLoader.DrawableCallback() {
@Override @Override
public void onLoadSuccess(Drawable drawable) { public void onLoadSuccess(Drawable drawable) {
createPrefixNew(drawable, bean,textView, new CreatePrefixCallback() {
createPrefix(drawable, bean, new CreatePrefixCallback() {
@Override @Override
public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) { public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) {
int color = Color.parseColor("#68F1F4"); int color = Color.parseColor("#68F1F4");
@ -727,8 +824,7 @@ public class LiveTextRender {
builder = renderGift(color, builder, bean); builder = renderGift(color, builder, bean);
break; break;
default: default:
builder = renderChat(textView, color, builder, bean, prefixWidth); builder = renderChatNew(textView, color, builder, bean, prefixWidth);
// builder = renderChatNew(textView, color, builder, bean, prefixWidth);
break; break;
} }
textView.setText(builder); textView.setText(builder);
@ -739,7 +835,7 @@ public class LiveTextRender {
@Override @Override
public void onLoadFailed() { public void onLoadFailed() {
createPrefix(null, bean, new CreatePrefixCallback() { createPrefixNew(null, bean,textView, new CreatePrefixCallback() {
@Override @Override
public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) { public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) {
int color = 0; int color = 0;
@ -753,8 +849,7 @@ public class LiveTextRender {
builder = renderGift(color, builder, bean); builder = renderGift(color, builder, bean);
break; break;
default: default:
builder = renderChat(textView, color, builder, bean, prefixWidth); builder = renderChatNew(textView, color, builder, bean, prefixWidth);
// builder = renderChatNew(textView, color, builder, bean, prefixWidth);
break; break;
} }
textView.setText(builder); textView.setText(builder);
@ -849,50 +944,72 @@ public class LiveTextRender {
public static String userName = ""; public static String userName = "";
private SpannableStringBuilder renderChatNew(TextView textView, int color, SpannableStringBuilder builder, LiveChatBean bean, int prefixWidth) { private SpannableStringBuilder renderChatNew(TextView textView, int color, SpannableStringBuilder builder, LiveChatBean bean, int prefixWidth) {
// prefixWidth 图片title 的宽度 int length = builder.length();
// 1计算textview的可用宽度 // availableWidth textView 可用宽度 prefixWidth 图片宽度
int availableWidth = textView.getWidth() - textView.getPaddingLeft() - textView.getPaddingRight(); int availableWidth = textView.getWidth() - textView.getPaddingLeft() - textView.getPaddingRight();
Log.e("renderChatNew", "availableWidth: " + availableWidth); // Log.e("renderChatNew", "availableWidth: " + availableWidth);
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
String name = bean.getUserNiceName(); String name = bean.getUserNiceName();
if (bean.getType() != LiveChatBean.ENTER_ROOM) {//产品规定进场消息不允许加冒号 if (bean.getType() != LiveChatBean.ENTER_ROOM) { // 产品规定进场消息不允许加冒号
name += ""; name += "";
} }
int lengthContent = length + name.length();
sb.append(name).append(bean.getContent()); sb.append(name).append(bean.getContent());
// 2计算名称内容 的宽度
TextPaint paint = textView.getPaint(); TextPaint paint = textView.getPaint();
float nameWidth = paint.measureText(sb.toString()); float nameWidth = paint.measureText(sb.toString());
Log.e("renderChatNew", "nameWidth: " + nameWidth + " prefixWidth: " + prefixWidth); // Log.e("renderChatNew", "nameWidth: " + nameWidth + " prefixWidth: " + prefixWidth);
if (nameWidth + prefixWidth > availableWidth){ if (nameWidth + prefixWidth > availableWidth) {
// 4如果名称内容 的宽度大于textview的可用宽度则计算字符后插入换行符
StringBuilder sb_tmp = new StringBuilder(); StringBuilder sb_tmp = new StringBuilder();
int initImageWidth = prefixWidth; int initImageWidth = prefixWidth;
for (int i = 0; i < sb.length(); i++) { for (int i = 0; i < sb.length(); i++) {
char content = sb.charAt(i); char content = sb.charAt(i);
sb_tmp.append(content); sb_tmp.append(content);
float measuredText = textView.getPaint().measureText(sb_tmp.toString()) + initImageWidth; float measuredText = paint.measureText(sb_tmp.toString()) + initImageWidth;
Log.e("renderChatNew", "measuredText: " + measuredText + " availableWidth: " + availableWidth); // Log.e("renderChatNew", "measuredText: " + measuredText + " availableWidth: " + availableWidth);
if (measuredText > availableWidth) { if (measuredText > availableWidth) {
initImageWidth = 0; initImageWidth = 0;
sb_tmp.delete(sb_tmp.length() -1, sb_tmp.length()); sb_tmp.deleteCharAt(sb_tmp.length() - 1);
sb_tmp.append("\n"); sb_tmp.append("\n");
sb_tmp.append(content); sb_tmp.append(content);
Log.e("renderChatNew", "sb_tmp.toString():" + sb_tmp.toString()); // Log.e("renderChatNew", "sb_tmp.toString():" + sb_tmp.toString());
} }
} }
builder.append(sb_tmp); builder.append(sb_tmp);
Log.e("renderChatNew", "builder.toString():" + builder.toString()); // Log.e("renderChatNew", "builder.toString():" + builder.toString());
}else { } else {
builder.append(sb); builder.append(sb);
} }
//超皇设置渐变色展示昵称
if (TextUtils.equals("7", bean.getNobleId()) && !TextUtils.isEmpty(bean.getStartColor())) {
builder.setSpan(new LinearGradientFontSpan(Color.parseColor(bean.getStartColor()), Color.parseColor(bean.getEndColor())), length, length + name.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
} else {
builder.setSpan(new ForegroundColorSpan(color), length, length + name.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
}
//超皇设置渐变色展示昵称
if (TextUtils.equals("7", bean.getNobleId()) && !TextUtils.isEmpty(bean.getContentColor())) {
builder.setSpan(new ForegroundColorSpan(Color.parseColor(bean.getContentColor())), lengthContent, lengthContent + bean.getContent().length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
}
if (bean.getType() == LiveChatBean.LIGHT) {
Drawable heartDrawable = ContextCompat.getDrawable(CommonAppContext.sInstance, LiveIconUtil.getLiveLightIcon(bean.getHeart()));
if (heartDrawable != null) {
builder.append(" ");
heartDrawable.setBounds(0, 0, DpUtil.dp2px(16), DpUtil.dp2px(16));
length = builder.length();
builder.setSpan(new VerticalImageSpan(heartDrawable), length - 1, length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
}
}
return builder; return builder;
} }
@ -1071,7 +1188,7 @@ public class LiveTextRender {
@Override @Override
public void onLoadSuccess(Drawable drawable) { public void onLoadSuccess(Drawable drawable) {
if (textView != null) { if (textView != null) {
createPrefix(drawable, bean, new CreatePrefixCallback() { createPrefixNew(drawable, bean,textView, new CreatePrefixCallback() {
@Override @Override
public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) { public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) {
int start = builder.length(); int start = builder.length();
@ -1088,7 +1205,7 @@ public class LiveTextRender {
@Override @Override
public void onLoadFailed() { public void onLoadFailed() {
if (textView != null) { if (textView != null) {
createPrefix(null, bean, new CreatePrefixCallback() { createPrefixNew(null, bean,textView, new CreatePrefixCallback() {
@Override @Override
public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) { public void onPrefixCallback(SpannableStringBuilder builder, int prefixWidth) {
int start = builder.length(); int start = builder.length();