android TextView里边实现图文混配效果

本文介绍如何使用Android的TextView实现图文混排效果,包括设置文本的不同颜色、字体样式、超链接、电话链接及插入图片等操作。通过示例代码展示了如何利用SpannableString和各种Span来实现这些功能。


用TextView实现这种效果,图片文字混排,文字不同颜色字体。打电话和吊起浏览器等等

代码例如以下:

 @Override     
      public void onCreate(Bundle savedInstanceState) {           
     super.onCreate(savedInstanceState);           
     setContentView(R.layout.activity_main);           
     myTextView = (TextView) this.findViewById(R.id.img_iv);                      
     //创建一个 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);          
    //打电话
     sp.setSpan(new URLSpan("tel:4155551212"), 2, 5,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
     //图片显示在textview里边
      Drawable d = getResources().getDrawable(R.drawable.ic_launcher);
      d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight());
      ImageSpan span = new ImageSpan(d, ImageSpan.ALIGN_BASELINE);
      sp.setSpan(span, 0, 1, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

      //SpannableString对象设置给TextView    
     myTextView.setText(sp);          
      //设置TextView可点击        
       myTextView.setMovementMethod(LinkMovementMethod.getInstance());      
      }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值