Android开发实现文本后面添加小图标,SpannableStringBuilder的使用

根据需求需要在textview的文本末尾添加一个免费的icon,第一想到的就是自定义textview,但是感觉太麻烦了。所以就想到了SpannableStringBuilder,先看下效果图:

具体实现方法很简单:

String str = "你是个大好人,你的眉毛细又长,你的头发黑又亮,你的眼睛大又光";
int strLength = str.length();
String text = str + " 替换";
int textLength = text.length();SpannableStringBuilder stringBuilder = new SpannableStringBuilder(text);
Drawable drawable = getResources().getDrawable(R.drawable.icon_free);
drawable.setBounds(0, 0, 72, 39);  //确定图标所在的矩形位置,这里应该是要以text文本的下边距为基准的
ImageSpan imageSpan = new ImageSpan(drawable);
SpannableString ss = new SpannableString(text);
stringBuilder.setSpan(imageSpan, textLength - 2, textLength, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);//这里确定替换的部分
mTextView.setText(stringBuilder);

很明显我的 图标没有居中显示,我这边是让UI修改一下切图,icon下面余留一些空白部分。当然这样做是简单,但是为了追求完美,建议还是自定义textview,但是我这边对text的字体和颜色变换太多,就没有想那么麻烦。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android中,可以使用自定义适配器(Custom Adapter)为Spinner添加小图标。 首先,创建一个自定义的适配器类,继承自ArrayAdapter。在适配器的构造方法中,可以传入一个带有图标资源的数组,并将该数组传递给父类的构造方法。确保适配器可以正确地显示图标以及文本数据。 其次,重写适配器的getView方法。在getView方法中,可以获取当前位置的数据,并将数据显示在Spinner的每一个选项中。同时,还可以为每一个选项添加一个ImageView,用于显示小图标。 最后,在活动文件中,实例化自定义适配器,并将其设置给Spinner。这样就可以通过自定义适配器,为Spinner的每一个选项添加小图标了。 以下是一个示例代码: ```java public class CustomAdapter extends ArrayAdapter<String> { private Context context; private int[] icons; public CustomAdapter(Context context, String[] items, int[] icons) { super(context, R.layout.spinner_item, items); this.context = context; this.icons = icons; } @Override public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); View row = inflater.inflate(R.layout.spinner_item, parent, false); TextView textView = row.findViewById(R.id.text_view); ImageView imageView = row.findViewById(R.id.image_view); textView.setText(getItem(position)); imageView.setImageResource(icons[position]); return row; } } ``` 活动文件的代码片段: ```java Spinner spinner = findViewById(R.id.spinner); String[] items = {"选项1", "选项2", "选项3"}; int[] icons = {R.drawable.icon1, R.drawable.icon2, R.drawable.icon3}; CustomAdapter customAdapter = new CustomAdapter(this, items, icons); spinner.setAdapter(customAdapter); ``` 上述代码中,自定义适配器CustomAdapter继承自ArrayAdapter,并在getView方法中为每一个选项添加了一个ImageView,用于显示小图标。活动文件中首先实例化CustomAdapter,并将其设置给Spinner,从而实现了在Spinner的每一个选项后面添加小图标的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值