EditText 插入表情(基于socket方式)

核心方法:editText.setText(Html.fromHtml(.....));

 

大家在用android版的qq时候一定见过有发送表情这样一个功能,我们知道类似qq这样的即时通信软件基本上都是通过socket方式实现的,在网上找了找有些网友已经实现了在edittext里面插入表情,但是真正基于 socket实现的还真没找到,在很一些网友帮助下加上自己的摸索终于实现了基于socket方式发送表情,今天我把它分享给大家,希望能帮助需要的人,帮助你就是帮助我!

1.首先你要准备好你的表情图片啦,我找了一些作为例子演示,把所有的表情图片放到res/drawable文件夹里面,至于表情的名字大家可以随便起,但是为了方便,最好是比较统一的格式,例如 face1,face2 ...,因为我实现的方式是在一个girdview里面显示这些表情,用户点击某个后就插入到edittext里面所以应该是如下图所示:



相信这个界面应该不难搞吧,要是搞不定了网上找找例子啊,这里就不多说了。然后再声明一个数组这个数组里面放的都是图片的id 如下:

1 public static Integer[] mThumbIds = {
2         R.drawable.face01,
3         R.drawable.face02,
4          R.drawable.face03,
5         R.drawable.face04
6 }

你把你所有的图片都放进去。

2 .在girdview控件的setOnItemClickListener方法里面我们需要写如下代码:

01 gridShowFace.setOnItemClickListener(new OnItemClickListener() {
02             public void onItemClick(AdapterView<?> parent, View view,intposition, long id) {
03                    ImageGetter imageGetter = new ImageGetter() {
04                    public Drawable getDrawable(String source) {
05                    int id = Integer.parseInt(source);
06                    Drawable d = getResources().getDrawable(id);
07                    d.setBounds(00, d.getIntrinsicWidth(), d.getIntrinsicHeight());
08                    return d;
09                   }
10                };
11          
12               CharSequence cs = Html.fromHtml("<img src='" + mThumbIds[position]+"'/>",imageGetter, null);
13               etContent.getText().append(cs);
14               faceContent =FilterHtml(Html.toHtml(etContent.getText()));
15                   
16                 }
17              });

代码分析:

在setOnItemClickListener里面 我们先实例化一个ImageGetter,ImageGetter是什么大家自己查查,我也不知道怎么定义它,这里我们可以理解为通过它可以把 edittext里面的html标签替换为图片的一个方法(不知道这样解释对不对),然后通过Html.fromHtml把它转换成文本格式,这个方法里面的 mThumbIds[position] 解释下,mThumbIds就是放图片id的数组,position就是你点击的id,这样就能得到图片的id了,得到的id 是一个16进制的字符串,也就是在 R文件里面系统自动生成的类似 “0x7f020009”这样的, 再通过 etContent.getText().append(cs) 附加给edittext 此时你可以试试,点击一个图片后就显示在edittext里面了。显示是没问题了,但是这里我们需要注意下,虽然显示成功了,但是现在要是你打印出 edittext的text 里面肯定有个OBJ的小图标,我们发出去后也是显示那个样子,我们是要通过socket发出去的,所以我们不能直接发送edittext.gettext()的值,这时候我们需要用一个方法过滤一下才能发,我们还需要一个方法 如下:

1 public static String FilterHtml(String str){
2             str = str.replaceAll("<(?!br|img)[^>]+>""").trim();
3             return str;
4         }

于是有个这句代码:faceContent =FilterHtml(Html.toHtml(etContent.getText())); 这就是把edittext的内容过滤,除了br标签和img标签,其他都去掉后的内容,现在就可以发送啦。注意:有些可能发送后就会出现#&62137这样编码的内容,需要再转码一下,转码的方法也给大家贴上 如下:

01 public static String UnicodeToGBK2(String s){
02         String[] k = s.split(";") ;
03         String rs = "" ;
04         for(int i=0;i<k.length;i++) {
05             int strIndex=k.indexOf("&#");
06             String newstr = k;
07             if(strIndex>-1) {
08                 String kstr = "";
09                 if(strIndex>0) {
10                     kstr = newstr.substring(0,strIndex);
11                     rs+=kstr;
12                     newstr = newstr.substring(strIndex);
13                 }
14                 int m = Integer.parseInt(newstr.replace("&#",""));
15                 char c = (char)m ;
16                 rs+= c ;
17             else {
18                 rs+=k;
19             }
20         }
21         return rs;
22     }

上面的就改为:

1 public static String FilterHtml(String str){
2         str = str .replaceAll("<(?!br|img)[^>]+>""").trim();
3         return UnicodeToGBK2(str);
4     }

3.还有最后一步,发出去了还要显示出来,

只需要在 适配器的 getview 给 textview 绑定内容时处理一下原来是setViewText((TextView) v, text) 改成 Html.fromHtml(text,imageGetter, null), 同样也需要 弄个 imageGetter对象出来就ok了。如图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现图文混排,可以使用一个自定义的 EditText 控件,并在其中添加一个 ImageView 控件来实现。 以下是实现方法: 1.创建一个自定义的带有 ImageView 控件的 EditText 控件。 ```java public class RichEditText extends androidx.appcompat.widget.AppCompatEditText { public RichEditText(Context context) { super(context); } public RichEditText(Context context, AttributeSet attrs) { super(context, attrs); } public RichEditText(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } //插入图片 public void insertImage(Bitmap bitmap) { SpannableString ss = new SpannableString(" "); ImageSpan span = new ImageSpan(getContext(), bitmap); ss.setSpan(span, 0, 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); append(ss); } } ``` 2.在布局文件中使用自定义的 EditText 控件。 ```xml <com.example.richedittextdemo.RichEditText android:id="@+id/edit_text" android:layout_width="match_parent" android:layout_height="wrap_content" /> ``` 3.在 Activity 中获取自定义的 EditText 控件,并添加一个点击事件。 ```java public class MainActivity extends AppCompatActivity { private RichEditText editText; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); editText = findViewById(R.id.edit_text); editText.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //调用选择图片的方法 chooseImage(); } }); } //选择图片 private void chooseImage() { Intent intent = new Intent(Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI); startActivityForResult(intent, 1); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (resultCode == RESULT_OK && requestCode == 1) { try { Uri selectedImage = data.getData(); InputStream inputStream = getContentResolver().openInputStream(selectedImage); Bitmap bitmap = BitmapFactory.decodeStream(inputStream); editText.insertImage(bitmap); } catch (FileNotFoundException e) { e.printStackTrace(); } } } } ``` 4.在 onActivityResult 方法中获取选择的图片,并调用自定义的 EditText 控件的 insertImage 方法,将图片插入EditText 中。 以上就是在 Android 中实现 EditText 插入图片并实现图文混排的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值