Android 将ImageSpan与TextView的顶部对齐

Android 将ImageSpan与TextView的顶部对齐,android,textview,spannablestring,Android,Textview,Spannablestring,目前,我希望在文本之间添加一个图像,并将其与文本视图的顶部对齐 大概是这样的: 我能找到的唯一垂直对齐方式是基线(它似乎把它放在文本中心的正下方)和底部对齐 如果我使用ALIGN_基线,会发生什么情况: 有没有办法将其与顶部对齐 我当前的代码: txtView.setText(this.addImageAsterisk( "The string to have asterisk at the end*"), BufferType.SPANNABLE); 然后 移除I

目前,我希望在文本之间添加一个图像,并将其与文本视图的顶部对齐

大概是这样的:

我能找到的唯一垂直对齐方式是基线(它似乎把它放在文本中心的正下方)和底部对齐

如果我使用ALIGN_基线,会发生什么情况:

有没有办法将其与顶部对齐

我当前的代码:

    txtView.setText(this.addImageAsterisk(
        "The string to have asterisk at the end*"), BufferType.SPANNABLE);
然后

移除ImageSpan.ALIGN_基线将其设置为与底部对齐,这也不是我预期的结果

---谢谢用户Lalit Poptani,我试着应用了你的答案----
应用此选项后,整个textview似乎有额外的页边空白

在应用span之前:

This is the text*
应用上标Panadjuster后

(some extra space)
This is the text*
我的代码:

String string = "This is the text*";
Drawable d = this.context.getResources().getDrawable(R.drawable.img_asterisk); 

d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight()); 

ImageSpan imageSpan = new ImageSpan(d, ImageSpan.ALIGN_BASELINE);
SuperscriptSpanAdjuster s = new SuperscriptSpanAdjuster(1.5);
final SpannableString spannableString = new SpannableString(string);
spannableString.setSpan(s, string.length() - 1, string.length(), 0);
spannableString.setSpan(imageSpan, string.length(), string.length() + 1, 0);
textView.setText(spannableString);

您可以使用自定义的
MetricAffectingSpan
来保持其比率,如

public class SuperscriptSpanAdjuster extends MetricAffectingSpan {
    double ratio = 0.5;

    public SuperscriptSpanAdjuster(double ratio) {
        this.ratio = ratio;
    }

    @Override
    public void updateDrawState(TextPaint paint) {
        paint.baselineShift += (int) (paint.ascent() * ratio);
    }

    @Override
    public void updateMeasureState(TextPaint paint) {
        paint.baselineShift += (int) (paint.ascent() * ratio);
    }
}
您可以使用
SpannableString
将星号应用于字符串

SpannableString mString = new SpannableString("This is what I wanted*");
mString.setSpan(new SuperscriptSpanAdjuster(0.5), mString.length() - 1, 
                     mString.length(), SpannableString.SPAN_EXCLUSIVE_EXCLUSIVE);
mTextView.append("\n");
mTextView.append(mString);
这是根据需要在文本中添加星号。您的输出将如下所示:


只需将您的drawable包装在inset drawable中,并将inset bottom设置为8dp之类的值。不是最好的解决方案,但会奏效

修改您的
drawable/img\u asterisk.xml
--



共享您的代码。并通过附加示例图像来明确您真正想要的内容。应用此方法后,出现的情况是我的文本顶部似乎有额外的边距。您可以通过链接
SuperscriptSpanAdjuster(0.5)的构造函数参数来增加或减少边距
ah你说得对:)但上标Panadjuster似乎只对文本有效,但当我在带有ImageSpan的部分上使用它时,ImageSpan仍然保持在相同的位置
SpannableString mString = new SpannableString("This is what I wanted*");
mString.setSpan(new SuperscriptSpanAdjuster(0.5), mString.length() - 1, 
                     mString.length(), SpannableString.SPAN_EXCLUSIVE_EXCLUSIVE);
mTextView.append("\n");
mTextView.append(mString);
<inset
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:insetBottom="8dp">

    <!-- Your previous asterisk drawable, probably a 'shape' -->

</inset>