腾讯开源库QMUI FaceView使用教程

腾讯的QMUI已经问世好长时间了,然而官方至今也没有给出一个详细的文档。为了方便大家使用,我就把我用过的控件的使用方法记录下来。

先来个效果图,由于我没有现成的表情图片,只好先用软件图标代替了。


Screenshot_2019-02-17-18-50-04-323_cn.devmeteor.qmui[1].png

官方说QMUIQQFaceView实质上并不是TextView,所以用法和TextView还是有差异的。

首先,自定义一个控件继承QMUIQQFaceView;

    import android.content.Context;

    import android.util.AttributeSet;

    import com.qmuiteam.qmui.qqface.QMUIQQFaceCompiler;

    import com.qmuiteam.qmui.qqface.QMUIQQFaceView;

    public class FaceViewextends QMUIQQFaceView {

      public FaceView(Context context) {
        super(context);
      }

      public FaceView(Context context, AttributeSet attrs) {
        super(context, attrs);
        setCompiler(QMUIQQFaceCompiler.getInstance(FaceManager.getInstance()));
      }

    }

然后再贴上FaceManager的代码;

    import android.graphics.drawable.Drawable;

    import com.qmuiteam.qmui.qqface.IQMUIQQFaceManager;

    public class FaceManagerimplements IQMUIQQFaceManager {

        private static FaceManagerfaceManager=new FaceManager();

        public static FaceManagergetInstance(){

            return faceManager;

        }

   @Override

    public boolean maybeSoftBankEmoji(char c) {

        return false;

    }

    @Override

    public int getSoftbankEmojiResource(char c) {

        return 0;

    }

    @Override

    public boolean maybeEmoji(int codePoint) {

        return false;

    }

    @Override

    public int getEmojiResource(int codePoint) {

        return 0;

    }

    @Override

    public int getDoubleUnicodeEmoji(int currentCodePoint, int nextCodePoint) {

        return 0;

    }

    @Override

    public int getQQfaceResource(CharSequence text) {

        if (text.equals("[微笑]"))

            return R.mipmap.ic_launcher;

        return 0;

    }

    @Override

    public DrawablegetSpecialBoundsDrawable(CharSequence text) {

        return null;

    }

    @Override

    public int getSpecialDrawableMaxHeight() {

        return 0;

    }

}

这样就可以像用TextView一样使用FaceView了,只要它的字符串中有 [微笑] 就会替换成特定的表情。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,573评论 0 17
  • 遥望山景近眼前, 必旺之功穿闲川。 五味承旧非米尔, 远观豪情似真缘。 湘...
    湘邵铁炉阅读 221评论 6 10
  • 窗外,下着倾盆大雨,我坐在室内,朝着落地窗外看去,能见度很低,只看见雨幕或向左漂或向右漂。此刻,我的内心充满喜悦。...
    无名的了了阅读 456评论 2 0
  • 今天补上了昨天的日期函数课程,还有今天的数据透视表课程。真是太感谢储君老师了,以前我一直想用数据透视表,看到有同事...
    云芸_4912阅读 215评论 0 0
  • 珞珈的秀美, 瑜伽的静悦, 如一潺清泉, 滋润现代都市人, 洗尽铅华与倦怠, 奉上焕然一新的生命体验! 编者: 彼...
    彼珞yoga阅读 440评论 1 5