Textview内容过多,尾部显示省略号或【更多】

本文介绍了如何处理TextView内容过多的情况,通过设置maxLines和ellipsize属性实现简单的省略号效果。当需要在末尾显示【更多】时,提供了一种自定义控件AutoTextView的解决方案,该控件会在内容超出限制时自动添加【更多】并调整颜色。
摘要由CSDN通过智能技术生成

一先看图


二、TextView 内容过多,直接设置 maxLines 和ellipsize=end 效果如图 上方TextView

三、尾部添加[更多内容],一开始想通过相对布局实现,发现不太可能(若有解决方案欢迎指正)

四、解决方案:

public class AD01 extends Activity {
    TextView tv;
    String str = "举个例子来说明一吧,为了让大家更明白一点,比如一个铅笔盒中有一支笔,但在没有打开之前你并不知道它是什么笔,可能是铅笔也可能是钢笔,这里有两种可能,那么你就可以定义一个枚举类型来表示它";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        se
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
当 toast 展示的内容过多时,可以通过设置 Toast 的显示时长和位置,以及使用自定义的 Toast 布局来解决省略号的问题。 1. 设置 Toast 的显示时长和位置 可以通过Toast类的 setDuration() 方法来设置 Toast 的展示时长,如下所示: ``` Toast toast = Toast.makeText(context, message, Toast.LENGTH_LONG); toast.setDuration(5000); // 5秒钟 ``` 可以将 duration 设置为一个较长的时间,来确保用户足够的时间看清楚 Toast 显示内容。 另外,当 Toast 显示内容过多时,可以通过 setGravity() 方法来设置 Toast 的显示位置,如下所示: ``` toast.setGravity(Gravity.CENTER, 0, 0); ``` 上述代码会将 Toast 居中显示。通过调整 setGravity() 方法的参数,可以将 Toast 显示在其他位置。 2. 使用自定义的 Toast 布局 可以通过 LayoutInflater 类来加载自定义的 Toast 布局,并在其中显示需要展示的内容。自定义布局可以是一个 XML 文件,也可以是一个 View 对象。 以下是一个使用自定义布局的例子: ``` LayoutInflater inflater = getLayoutInflater(); View layout = inflater.inflate(R.layout.custom_toast, (ViewGroup) findViewById(R.id.custom_toast_layout)); TextView text = (TextView) layout.findViewById(R.id.text); text.setText("需要显示内容"); Toast toast = new Toast(getApplicationContext()); toast.setDuration(Toast.LENGTH_LONG); toast.setView(layout); toast.show(); ``` 在上述代码中,我们使用自定义布局 custom_toast.xml,并在其中添加一个 TextView显示需要展示的内容。然后,我们将该布局设置为 Toast 的 View,以此来展示自定义的 Toast。 通过使用自定义的 Toast 布局,我们可以自由地控制 Toast 的样式和显示内容,从而更好地展示需要展示的内容

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值