• SpannableString 记录(转)


    引用 http://blog.csdn.net/rockcoding/article/details/7231756

    TextView是用来显示文本的,有时需要给TextView中的个别字设置为超链接,或者设置个别字的颜色、字体等,那就需要用到Spannable对象,可以借助Spannable对象实现以上设置

    myTextView = (TextView) this.findViewById(R.id.myTextView);   
        
      //创建一个 SpannableString对象   
      SpannableString sp = new SpannableString("这句话中有百度超链接,有高亮显示,这样,或者这样,还有斜体.");   
      //设置超链接   
      sp.setSpan(new URLSpan("http://www.baidu.com"), 5, 7,   
      Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);   
      //设置高亮样式一   
      sp.setSpan(new BackgroundColorSpan(Color.RED), 17 ,19,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);   
      //设置高亮样式二   
      sp.setSpan(new ForegroundColorSpan(Color.YELLOW),20,24,Spannable.SPAN_EXCLUSIVE_INCLUSIVE);   
      //设置斜体   
      sp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 27, 29, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);   
      //SpannableString对象设置给TextView   
      myTextView.setText(sp);   
      //设置TextView可点击   
      myTextView.setMovementMethod(LinkMovementMethod.getInstance()); 

    textview显示不同的颜色、样式来表示,需要用到SpannableString对象来处理

    下面是从网上找的一段代码,已验证过:

    mTextView = (TextView)findViewById(R.id.test);
    SpannableString tSS = new SpannableString(“SpannableString学习中”);
    tSS.setSpan(new BackgroundColorSpan(Color.RED), 0, 2, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);  //红色高亮
    tSS.setSpan(new UnderlineSpan(), 15, 18,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);    //下划线
    tSS.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 2, 5, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); //斜体
    mTextView.setText(tSS);

    关键方法:
    public void setSpan (Object what, int start, int end, int flags)
    主要是start跟end
    start是起始位置,无论中英文,都算一个。从0开始计算起。end是结束位置,所以处理的文字,包含开始位置,但不包含结束位置。

  • 相关阅读:
    低落
    栗子
    Wireless Password HDU
    考研路茫茫——单词情结 HDU
    DNA Sequence POJ
    HDU 6138 Fleet of the Eternal Throne 多校#8 AC自动机
    Rikka with Candies HDU
    Wavel Sequence HDU
    Counting Divisors HDU
    Codeforces Round #424 E. Cards Sorting 线段树/数据结构瞎搞/模拟
  • 原文地址:https://www.cnblogs.com/wjjair/p/3357026.html
Copyright © 2020-2023  润新知