Android使用Libgdx渲染Html标签

在使用Libgdx的过程中,有时候会遇到这样的需要, 后端返回给我们的是html tag,比如如下:

<p><i>italic </i><b>bold <i>italic+bold <u>italic+bold+un</u></i></b></p>

对于以上Html tag,如果使用android自带的控件TextView可以通过setText(Html.from(“”))的方式直接设置显示内容。效果如下:
这里写图片描述

但是在Libgdx中并没有提供相应的控件实现这种效果。所以需要转换一下思路, 具体的实现思路就是先将Html文本内容设置到TextView,然后对TextView截图获取Bitmap对象,然后将Bitmap对象通过OpenGL转化为Texture对象,有了Texture对象就可以在Libgdx中渲染了。

具体实现如下:

package com.ef.smallstar.libgdx.util;

import android.graphics.Bitmap;
import android.opengl.GLES20;
import android.opengl.GLUtils;
import android.text.Html;
import android.view.Gravity;
import android.view.View;
import android.widget.TextView;

import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.graphics.Pixmap;
import com.badlogic.gdx.graphics.Texture;
import com.ef.smallstar.EFApplication;

/**
 * Created by Danny 姜 on 17/8/10.
 */

public class GdxHtmlUtils {

    public static Texture fromString(String string, int textSize) {

        return fromString(string, textSize, 0, 0);
    }

    public static Texture fromString(String string, int textSize,
                                     float textureWidth, float textureHeight) {
        return fromString(string, textSize, textureWidth, textureHeight, 0, 0, 0, 0);
    }

    public static Texture fromString(String string, int textSize,
                                     float textureWidth, float textureHeight,
                                     float paddingLeft, float paddingTop,
                                     float paddingRight, float paddingBottom) {
        TextView tv = new TextView(EFApplication.getInstance());
        tv.setGravity(Gravity.CENTER);

        tv.setText(Html.fromHtml(string));
        tv.setTextSize(textSize);

        tv.measure(View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED), View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));
        float width = textureWidth <= 0 ? tv.getMeasuredWidth() : textureWidth;
        float height = textureHeight <= 0 ? tv.getMeasuredHeight() : textureHeight;
        tv.layout(((int) paddingLeft), ((int) (0 + paddingTop)),
                (int) (width - paddingRight), ((int) (height - paddingBottom)));
        tv.buildDrawingCache();
        final Bitmap bitmap = tv.getDrawingCache();

        Texture tex = new Texture(bitmap.getWidth(), bitmap.getHeight(), Pixmap.Format.RGBA8888);
        GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, tex.getTextureObjectHandle());
        GLUtils.texImage2D(GLES20.GL_TEXTURE_2D, 0, bitmap, 0);
        GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, 0);
        bitmap.recycle();

        return tex;
    }
}
  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值