• Android 动态设置TextView的drawableLeft等属性


      首先,我们在开发过程中,会经常使用到android:drawableLeft="@drawable/ic_launcher"这些类似的属性:


      关于这些属性的意思,无非是在你的textView文本的上下左右处添加一个图片。比如下面这么一段代码:

    <TextView
            android:id="@+id/text_drawable"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/hello_world"
            android:drawableLeft="@drawable/ic_launcher"
            android:drawablePadding="4dp"
             />

    它设置了在文本的左边,显示一个小图标,效果如下:



      而在一些情况下,我们需要在动态在代码中设置文本周围的图标,那该如何呢,首先,我们看下TextView提供了哪些方法:

    乍眼看去,挺多方法的,好,我们主要介绍setCompoundDrawables和setCompoundDrawablesWithIntrinsicBounds。

    手工设置文本与图片相对位置时,常用到如下方法:

      setCompoundDrawables(left, top, right, bottom)及setCompoundDrawablesWithIntrinsicBounds(left, top, right, bottom),它们的意思是设置Drawable显示在text的左、上、右、下位置。

      但是两者有些区别:
      setCompoundDrawables 画的drawable的宽高是按drawable.setBound()设置的宽高,
    所以才有The Drawables must already have had setBounds(Rect) called,即使用之前必须使用Drawable.setBounds设置Drawable的长宽。

      而setCompoundDrawablesWithIntrinsicBounds是画的drawable的宽高是按drawable固定的宽高,
    所以才有The Drawables' bounds will be set to their intrinsic bounds.即通过getIntrinsicWidth()与getIntrinsicHeight()获得。

      一般,建议使用setCompoundDrawablesWithIntrinsicBounds,这样你即无需设置Drawables的bounds了。


     看下代码:

    		TextView textDrawable = (TextView) findViewById(R.id.text_drawable);
    
    		Drawable drawableLeft = getResources().getDrawable(
    				R.drawable.ic_launcher);
    
    		textDrawable.setCompoundDrawablesWithIntrinsicBounds(drawableLeft,
    				null, null, null);
    		textDrawable.setCompoundDrawablePadding(4);

     效果和以上直接通过android:drawableLeft一样!

  • 相关阅读:
    hadoop配置文件说明
    hadoop集群部署
    Linux iptables防火墙实用模板
    不容忽视的SQL注入式攻击
    字符串的加解密
    .NET程序集版本号的奥秘
    SQL Server 2005 数据库引擎的容量规范
    Microsoft Visual Studio Tools for the Microsoft Office system(3.0 版)
    How to: Display a Dialog Box for Selecting Entries from the Contacts Folder
    OpenID及其原理介绍
  • 原文地址:https://www.cnblogs.com/hehe520/p/6329960.html
Copyright © 2020-2023  润新知