Android基于XMPP的即时通讯3-表情发送
这篇博文主要讲表情发送的一些东西。
1、准备好资源文件
采用的是emoji的表情,我打包好了,下载地址:http://files.cnblogs.com/files/pear-lemon/drawable.zip
2、表情布局文件layout_send_emotion.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/rl_send_emotion"
android:layout_width="match_parent"
android:layout_height="260dp"
android:orientation="vertical"
android:visibility="gone" >
<android.support.v4.view.ViewPager
android:id="@+id/vp_pager_emotion"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true" >
</android.support.v4.view.ViewPager>
<LinearLayout
android:id="@+id/ll_emotion_dot"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="10dp"
android:orientation="horizontal" >
</LinearLayout>
</RelativeLayout>
3、用于和图片资源对应的字符array.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="emoji">
<item>01</item>
<item>02</item>
<item>03</item>
<item>04</item>
<item>05</item>
<item>06</item>
<item>07</item>
<item>08</item>
<item>09</item>
<item>10</item>
<item>11</item>
...
</string-array>
</resources>
4、获取表情资源文件(资源文件命名为"emoji_XX",所以key我自定义一个静态AppDefine.EMOJI = "emoji_")
private List<Integer> emotionImgs;//表情图片 private String[] emotionText;//表情文字
String packageName = activity.getPackageName();
Resources resource = activity.getResources();
emotionImgs = new ArrayList<Integer>();
//获取所有的表情
emotionText = resource.getStringArray(R.array.emoji);
for(String emution :emotionText) {
String key = AppDefine.EMOJI + emution;
int resId = resource.getIdentifier(key, "drawable", packageName);
emotionImgs.add(resId);
}
5、初始化views
ViewPager viewPager = (ViewPager) findViewById(R.id.vp_pager_emotion);
LinearLayout llDots = (LinearLayout) findViewById(R.id.ll_emotion_dot);
//初始化表情格子
for(int i = 0;i < pageCount;i ++){
gridViews[i] = new GridView(activity);
gridViews[i].setStretchMode(GridView.STRETCH_COLUMN_WIDTH);
gridViews[i].setNumColumns(5);
gridViews[i].setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.WRAP_CONTENT));
gridViews[i].setGravity(Gravity.CENTER);
gridViews[i].setAdapter(new EmotionGridAdapter(activity, emotionImgs, pageCount, i));
gridViews[i].setOnItemClickListener(mOnItemClickListener);
gridViews[i].setSelector(new ColorDrawable(Color.TRANSPARENT));
}
//初始化下面的点
for(int i=0;i<pageCount;i++){
viewDots[i]=new View(activity);
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(10, 10);
lp.setMargins(10, 0, 10, 0);
viewDots[i].setLayoutParams(lp);
if(i!=currentIndex){
viewDots[i].setBackgroundResource(R.drawable.icon_dot_normal);
}else{
viewDots[i].setBackgroundResource(R.drawable.icon_dot_focused);
}
llDots.addView(viewDots[i]);
}
viewPager.setAdapter(new EmotionPagerAdapter(gridViews, pageCount));
6、界面上边的内容没什么难度,写好基本这个效果

7、处理点击事件,加载到发送框里边
OnItemClickListener mOnItemClickListener = new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
// 获取图片对应的字符,资源ID
String emotion = AppDefine.EMOJI + emotionText[currentIndex * 15 + position];
int resId = emotionImgs.get(currentIndex * 15 + position);
Drawable drawable = getResources().getDrawable(resId);
int length = (int) getResources().getDimension(R.dimen.emotion_icon);
drawable.setBounds(0, 0, length, length);
// 根据字符创建SpannableString
SpannableString spannable = new SpannableString(emotion);
// 根据drawable创建ImageSpan
ImageSpan span = new ImageSpan(drawable, ImageSpan.ALIGN_BOTTOM);
spannable.setSpan(span, 0, emotion.length(), Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
// 设置输入框内容
etSend.append(spannable);
etSend.setSelection(etSend.getText().toString().length());
}
};
8、列表中也要显示表情,做法如下:
private final String[] emotionText;//表情文字 private final int [] emotionImgs;//表情图片 private final HashMap<String, Integer> emotionToText;//文字图片对应 private final Pattern mPattern;//正则匹配
一步一步初始化需要的数据
String packageName = context.getPackageName();
Resources resource = context.getResources();
emotionText = context.getResources().getStringArray(R.array.emoji);
int length = emotionText.length;
emotionImgs = new int[length];
emotionToText = new HashMap<String, Integer>();
for(int i = 0;i < length;i ++) {
String key = AppDefine.EMOJI + emotionText[i];
int resId = resource.getIdentifier(key, "drawable", packageName);
emotionImgs[i] = resId;
emotionToText.put(key, resId);
}
初始化正则匹配字符(百度找的)
StringBuilder patternString = new StringBuilder(emotionText.length * 3);
patternString.append('(');
for (String str : emotionText) {
patternString.append(Pattern.quote(AppDefine.EMOJI + str));
patternString.append('|');
}
patternString.replace(patternString.length() - 1,
patternString.length(), ")");
mPattern = Pattern.compile(patternString.toString());
主要的文字转换图片方法
public SpannableString textToEmotion(Context context, String text){
Matcher matcher = mPattern.matcher(text);
SpannableString spannable = new SpannableString(text);
while (matcher.find()) {//找到匹配的字符
String findText = matcher.group();
//根据对应关系找到资源ID
int resId = emotionToText.get(findText);
Drawable drawable = context.getResources().getDrawable(resId);
int length = (int) context.getResources().getDimension(R.dimen.emotion_icon);
drawable.setBounds(0, 0, length, length);
ImageSpan span = new ImageSpan(drawable, ImageSpan.ALIGN_BOTTOM);
spannable.setSpan(span, matcher.start(), matcher.end(), Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
}
return spannable;
}
源码送上:https://github.com/PearLemon/XmppTest.git
Android基于XMPP的即时通讯3-表情发送的更多相关文章
- Android基于XMPP的即时通讯2-文件传输
本文是在上一篇博文Android基于XMPP的即时通讯1-基本对话的基础上,添加新的功能,文件传输 1.初始化文件传输管理类 public static FileTransferManager get ...
- Android基于xmpp的即时通讯应用
xmpp是一个通信协议.因为这是个开放的协议,为了节俭开发成本,很多即时应用都采用了这个协议.Android上最常用的组合asmack +openfire.Asmack是smack的android版, ...
- Android基于XMPP的即时通讯1-基本对话
闲暇之余,自己写了个简单的即时通讯,基于OpenFire服务器平台. 整个项目包括两个部分,一个是服务器端,一个是android手机端: 一.关于服务器端没什么好说的,下载安装配置即可 推荐下载带ja ...
- 【XMPP】基于XMPP的即时通讯解决方案
什么是XMPP 介绍XMPP之前,先来看看GTalk. GTalk是Google推出的IM(Instant Messaging,即时通讯)软件,类似于QQ和MSN. 从技术角度来说,GTalk与QQ和 ...
- iOS基于XMPP实现即时通讯之一、环境的搭建
移动端访问不佳,请访问我的个人博客 使用XMPP已经有一段时间了,但是一直都没深入研究过,只是使用SDK做一些简单的操作,看了许多大神的博客,自己总结一下,准备写一系列关于XMPP的使用博客,以便于自 ...
- Android基于XMPP Smack openfire 开发的聊天室
Android基于XMPP Smack openfire 开发的聊天室(一)[会议服务.聊天室列表.加入] http://blog.csdn.net/lnb333666/article/details ...
- android环境下的即时通讯
首先了解一下即时通信的概念.通过消息通道 传输消息对象,一个账号发往另外一账号,只要账号在线,可以即时获取到消息,这就是最简单的即使通讯.消息通道可由TCP/IP UDP实现.通俗讲就是把一个人要发送 ...
- 基于openfire+smack即时通讯instant message开发
前言 Java领域的即时通信的解决方案可以考虑openfire+spark+smack.当然也有其他的选择. Openfire 是基于Jabber协议(XMPP)实现的即时通信服务器端版本,目前建议使 ...
- [Python]实现XMPP协议即时通讯发送消息功能
#-*- coding: utf-8 -*- __author__ = 'tsbc' import xmpp import time #注意帐号信息,必须加@域名格式 from_user = 'che ...
随机推荐
- linux使用读写锁pthread_rwlock_t
转自:http://blog.csdn.net/onlyou930/article/details/6755593 使用读写锁 配置读写锁的属性之后,即可初始化读写锁.以下函数用于初始化或销毁读写锁. ...
- 求CRC校验和的低位和高位的两种方式
方式1 unsigned ; // 校验和 ]; memcpy(tstCRCChecksum,&shrCRCCheckSum,); // shrCRCCheckSum:216D LOGI(]) ...
- java线程之——synchronized的注意细节
我在学习synchronized的时候,十分好奇当一个线程进入了一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法? 然后就做了个实验(实验代码最后贴出),最后得到了如下 ...
- pythonchallenge之C++学习篇-02
第二关任然是一个字符处理的关卡 查看网页源码发现有一大串字符需要处理,这么多的字符如果放在源代码里就很不好了 所以要用到C++对文件的操作,用到的头文件是fstream 这里参照了这个博文 对文件处理 ...
- 德飞莱STM32单片机学习(一)——下载环境搭建
一.下载驱动安装. 1.手动打开CH341 文件夹(驱动程序文件夹内) ,双击安装驱动 2. 尼莫M3S 开发硬件设置 硬件需要做到以下2 点:1. USB插入USB1(COM),打开电源开关J14( ...
- DOM、Window对象操作
一.DOM的基本概念 DOM是文档对象模型,这种模型为树模型:文档是指标签文档:对象是指文档中每个元素:模型是指抽象化的东西. 一.基本语法: 数据类型(字符串,小数,整数,布尔,时间) var, v ...
- 使用lsof查看进程句柄使用情况
lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more
- css样式—字体垂直、水平居中
“来,老板娘,给个div瞅瞅”: “好的,宇哥,来了了了”: <div class="tt">啦啦啦</div> “给各样啊,我去”: “是”: .tt{ ...
- CSS3详解:background
CSS3对于background做了一些修改,最明显的一个就是采用设置多背景,不但添加了4个新属性,并且还对目前的属性进行了调整增强. 1.多个背景图片 在css3里面,你可以再一个标签元素里应用多个 ...
- Ajax实现点击省份显示相应城市
功能:不用级联效果,自己写ajax,从接口读取省份城市数据,实现点击省份显示相应城市.后端根据省份ID,给前端返回城市. 一.DOM结构(套用blade模板) <div class=" ...