• Stars
    star
    484
  • Rank 90,873 (Top 2 %)
  • Language
    Java
  • Created almost 8 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

一个超级牛逼的表情库,可使用表情及贴图功能,方便好用,抽离图片加载接口,图片加载工具可让开发者自己选择。

LQREmojiLibrary

一个超级牛逼的表情库,可使用表情及贴图功能,方便好用,抽离图片加载接口,图片加载工具可让开发者自己选择。

一、简述

这个库相当牛逼,好用。这个库相当牛逼,好用。这个库相当牛逼,好用。好了,接下来直接看效果图吧:

DemoApp下载

image

二、引用初始化

1、在自己项目中添加本项目依赖:

compile 'com.lqr.emoji:library:1.0.2'

2、初始化

使用本库必须在自定义的Application中使用LQREmotionKit对库进行初始化,LQREmotionKit提供了四种初始化方法,请根据自己的需要选择。

*使用前需要注意以下几点:

  1. 本库抽离出了图片加载接口,可让开发者自己选择图片加载工具(如:Glide、UIL等),所以使用本库必须实现IImageLoader接口。
  2. 本库支持设置贴图的存放路径,这意味着开发者可以根据自己项目需求修改贴图的存放位置,并且支持贴图自定义。默认的贴图存放在/data/data/包名/files/stickers 目录下。

1)不带IImageLoader的init()

public static void init(Context context)

public static void init(Context context, String stickerPath)

2)带IImageLoader的init()

public static void init(Context context, IImageLoader imageLoader)

public static void init(Context context, String stickerPath, IImageLoader imageLoader)

3)示例

public class App extends Application {

    @Override
    public void onCreate() {
        super.onCreate();
        LQREmotionKit.init(this, new IImageLoader() {
            @Override
            public void displayImage(Context context, String path, ImageView imageView) {
                Glide.with(context).load(path).centerCrop().diskCacheStrategy(DiskCacheStrategy.SOURCE).into(imageView);
            }
        });
    }
}

三、表情功能集成

1、布局中使用EmotionLayout控件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
              android:orientation="vertical">

    <!--内容区-->
    <LinearLayout
        android:id="@+id/llContent"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:orientation="vertical">

        ...
		这里一般是放消息列表,和内容输入框等控件
		...

    </LinearLayout>

    <!--表情区-->
    <com.lqr.emoji.EmotionLayout
        android:id="@+id/elEmotion"
        android:layout_width="match_parent"
        android:layout_height="270dp"
        android:visibility="gone"/>

</LinearLayout>

2、实现输入框图文混排

1)将内容输入框交给EmotionLayout管理(强烈建议!!!)

mElEmotion.attachEditText(mEtContent);

2)实现IEmotionSelectedListener接口,手动实现图文混排(有自己的实现方式的,可以采用这种方式)

mElEmotion.setEmotionSelectedListener(new IEmotionSelectedListener() {
    @Override
    public void onEmojiSelected(String key) {
        if (mEtContent == null)
            return;
        Editable editable = mEtContent.getText();
        if (key.equals("/DEL")) {
            mEtContent.dispatchKeyEvent(new KeyEvent(KeyEvent.ACTION_DOWN, KeyEvent.KEYCODE_DEL));
        } else {
            int start = mEtContent.getSelectionStart();
            int end = mEtContent.getSelectionEnd();
            start = (start < 0 ? 0 : start);
            end = (start < 0 ? 0 : end);
            editable.replace(start, end, key);

            int editEnd = mEtContent.getSelectionEnd();
            MoonUtils.replaceEmoticons(LQREmotionKit.getContext(), editable, 0, editable.toString().length());
            mEtContent.setSelection(editEnd);
        }
    }

    @Override
    public void onStickerSelected(String categoryName, String stickerName, String stickerBitmapPath) {

    }
});

3、实现内容区与表情区仿微信切换效果

private EmotionKeyboard mEmotionKeyboard;

private void initEmotionKeyboard() {
    mEmotionKeyboard = EmotionKeyboard.with(this);
    mEmotionKeyboard.bindToContent(mLlContent);
    mEmotionKeyboard.bindToEmotionButton(mIvEmo);
    mEmotionKeyboard.bindToEditText(mEtContent);
    mEmotionKeyboard.setEmotionLayout(mElEmotion);
}

4、效果

经过上面几步,就可以实现以下效果了:

image

四、贴图功能集成

1、设置贴图的存放位置

这一步可略过,不设置的话,贴图的默认存放位置是 /data/data/包名/files/stickers ,可通过LQREmotionKit.getStickerPath()获得。

贴图的存放位置只能通过LQREmotionKit的init()来设置:

LQREmotionKit.init(this, Environment.getExternalStorageDirectory().getAbsolutePath()+ File.separator+"sticker");

LQREmotionKit.init(this, Environment.getExternalStorageDirectory().getAbsolutePath() + File.separator + "sticker", new IImageLoader() {
        @Override
        public void displayImage(Context context, String path, ImageView imageView) {
            Glide.with(context).load(path).centerCrop().diskCacheStrategy(DiskCacheStrategy.SOURCE).into(imageView);
        }
    });

2、将贴图下载到指定贴图的存放位置

1)自带贴图

本库支持 集成默认贴图,可将贴图按规则放置在assets的sticker目录下,当程序启动时,会自动将assets的sticker目录下所有的贴图复制到贴图的存放位置。

2)网络下载贴图

//得到贴图的存放位置
String stickerPath = LQREmotionKit.getStickerPath();
...
网络下载(这里不同项目实现方式不同,请根据自己的项目实现该部分代码)
...

3、监听用户点击贴图事件

mElEmotion.setEmotionSelectedListener(new IEmotionSelectedListener() {
    @Override
    public void onEmojiSelected(String key) {
        
    }

    @Override
    public void onStickerSelected(String categoryName, String stickerName, String stickerBitmapPath) {
        String stickerPath = stickerBitmapPath;
        ...
		发送图片
		...
    }
});

4、效果

经过上面几步,就可以实现以下效果了:

image

五、拓展按钮的控制

1、设置表情控件的拓展按钮

默认表情控件的底部Tab是不显示“添加”按钮和“设置”按钮的,如果需要,可通过以下代码进行控制。

mElEmotion.setEmotionAddVisiable(true);
mElEmotion.setEmotionSettingVisiable(true);
mElEmotion.setEmotionExtClickListener(new IEmotionExtClickListener() {
    @Override
    public void onEmotionAddClick(View view) {
        Toast.makeText(getApplicationContext(), "add", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onEmotionSettingClick(View view) {
        Toast.makeText(getApplicationContext(), "setting", Toast.LENGTH_SHORT).show();
    }
});

2、效果

image

More Repositories

1

LQRWeChat

本项目仿最新版微信6.5.7(除图片选择器外),基于融云SDK,使用目前较火的 Rxjava+Retrofit+MVP+Glide 技术开发。相比上个版本,加入发送位置消息,红包消息等功能。
Java
3,370
star
2

LQRAudioRecord

集成录音与播音功能,使用简单方便
Java
382
star
3

MaterialDesignDemo

Material Design 兼容性控件学习
Java
226
star
4

HotFixDemo

热修复Demo(附文章讲解)
Java
162
star
5

TopsalesSellControlTableDemo

仿房产销冠APP的销控表界面
Java
147
star
6

LQRImagePicker

完全仿微信的图片选择,并且提供了多种图片加载接口,选择图片后可以旋转,可以裁剪成矩形或圆形,可以配置各种其他的参数
Java
139
star
7

LQRNineGridImageView

仿微信群头像九宫格控件
Java
132
star
8

LQRRecyclerViewLibrary

对RecyclerView的封装,让其使用更加简单,得心应手
Java
128
star
9

LQRBiliBlili

高仿bilibili安卓客户端
Java
116
star
10

LQRLibyuv

基于 libyuv 封装各种图像格式转换,用于处理摄像头yuv图像数据
C++
113
star
11

LQRDropdownLayoutLibrary

下拉导航菜单,使用非常简单
Java
71
star
12

LQRAdapterLibrary

万能适配器(RecyclerView、ListView、GridView)
Java
57
star
13

LQRViedoRecordView

安卓视频录制控件,可以用来仿微信小视频
Java
57
star
14

LQRNativePicSelect

为使用系统原生选择图片需求做了一个工具类封装,并适配了Android 7.0
Java
44
star
15

RePluginX

🔥 Supports AndroidX and Android-Support
Java
43
star
16

LQROptionItemView

项目中常用选项条目布局控件
Java
21
star
17

AndroidAopDemo

Android面向切面编程Demo(AOP)
Java
20
star
18

AspectLogDemo

Spring Boot使用自定义注解+AOP处理日志
Java
16
star
19

LQRArticlePatch

解析下载今日头条视频及图片
Java
14
star
20

SimpleDbFrame

手撸一个简单的面向对象数据框架(工厂模式+泛型+注解+反射)
Java
13
star
21

LQRRecordProgress

仿微信小视频进度条
Java
8
star
22

DropdownLayoutDemo

下拉导航菜单,使用非常简单
Java
6
star
23

LiteARouter

精简版ARouter,与 RePluginX 更配哦~
Java
5
star
24

OpenGLDemo

Android中OpenGL编程Demo
Java
3
star
25

meiduo_project

django美多商城
HTML
3
star
26

UniappIseXfyun

Uniapp小程序版 科大讯飞语音评测Demo
TypeScript
3
star
27

LQROpenCV

基于OpenCV3.4.1,实现人脸识别,手部识别。
C++
3
star
28

IocDemo

使用注解打造自己的IOC框架
Java
2
star
29

vue-legacy-project

兼容低版本浏览器的vue工程示例
Vue
2
star
30

LQRCustomerView

自定义View练习
Java
2
star
31

OpenGLStudy

study opengl and camera
Java
1
star
32

pagehelper

Mybatis逆向工程分页助手fix
Java
1
star
33

www---api-6-17-

Python
1
star
34

LQRCameraDemo

Android相机使用Demo
Java
1
star
35

WeiXinEmotion

模仿微信表情
Java
1
star
36

game-tank

Kotlin坦克大战
Kotlin
1
star
37

LQRLibrtmp

基于librtmp搭建的RTMP推流器
C
1
star
38

uniapp-tensorflowjs-mp

uniapp 集成 tensorflowjs(微信小程序)
SCSS
1
star
39

vite-plugin-variant

vite-plugin-variant is a vite plugin for managing multi-channel differentiated source code
TypeScript
1
star