关于im:Android-端如何添加自定义表情

4次阅读

共计 2131 个字符,预计需要花费 6 分钟才能阅读完成。

实现步骤 1. 新建 RongEmoticonTab 类继承 IEmoticonTab。

public class RongEmoticonTab implements IEmoticonTab {

public RongEmoticonTab() {
}
@Override
public Drawable obtainTabDrawable(final Context context) {
return context.getResources().getDrawable(R.drawable.u1f603);
}

@Override
public View obtainTabPager(Context context) {

return view;
}
@Override
public void onTableSelected(int i) {
}
}

2. 在 obtainTabPager 中增加您想要展现在表情面板上的 view。

@Override
public View obtainTabPager(Context context) {
View view = LayoutInflater.from(context).inflate(R.layout.view_emoji, null);
RecyclerView rv = view.findViewById(R.id.recycler_view);
//LinearLayoutManager 是用来做列表布局,也就是单列的列表
GridLayoutManager mLayoutManager = new GridLayoutManager(context, 5, OrientationHelper.VERTICAL, false);
rv.setLayoutManager(mLayoutManager);
// 谷歌提供了一个默认的 item 删除增加的动画
rv.setItemAnimator(new DefaultItemAnimator());
rv.setHasFixedSize(true);
// 模仿列表数据
ArrayList newsList = new ArrayList<>();
TypedArray array = context.getResources().obtainTypedArray(context.getResources().getIdentifier(“rc_emoji_res”, “array”, context.getPackageName()));
int i = -1;
while (++i < array.length()) {
newsList.add(array.getResourceId(i, -1));
}
rv.setAdapter(new NewsAdapter(newsList));
return view;
}

3.Adapter 和布局文件能够参考 GitHub 4. 自定义一个 ExtensionModule 继承自 DefaultExtensionModule,复写其中的 getEmoticonTabs() 办法,返回须要展现的 EmoticonTab 列表。

public class MyExtensionModule extends DefaultExtensionModule {
private RongEmoticonTab rongEmoticon;
@Override
public List<IEmoticonTab> getEmoticonTabs() {
List<IEmoticonTab> emoticonTabs =  super.getEmoticonTabs();
RongEmoticonTab emojiTab=new RongEmoticonTab();
emoticonTabs.add(myEmoticon);
return emoticonTabs;
}
}

5. 在初始化之后,勾销 SDK 默认的 ExtensionModule,注册自定义的 ExtensionModule,如下:

public void setMyExtensionModule() {
List<IExtensionModule> moduleList = RongExtensionManager.getInstance().getExtensionModules();
IExtensionModule defaultModule = null;
if (moduleList != null) {
for (IExtensionModule module : moduleList) {
if (module instanceof DefaultExtensionModule) {
defaultModule = module;
break;
}
}
if (defaultModule != null) {
RongExtensionManager.getInstance().unregisterExtensionModule(defaultModule);
RongExtensionManager.getInstance().registerExtensionModule(new MyExtensionModule());
}
}
}

6. 如果须要网络下载表情须要下载并长久化表情数据, 须要在增加 EmoticonTab 前下载好表情数据。

正文完
 0