布局与控件(三)-TextView那些事儿

原创 2016年05月30日 15:04:47
更新时间 修改意见
2016-08-02 陈敏

第3节 TextView

这是界面设计最为常用的控件,也是很多别的控件的父类,例如Button

3.1 文字常用属性

最常使用到的属性,通过它们的名字就可以判断出它们的作用:

android:text:为TextView设置显示的文字内容;

<TextView
    ......
    <!--直接设置要显示的文字-->
    android:text="Hello world!"/>

<TextView
    ......
    <!--使用引用设置要显示的文字-->
    android:text="@string/hello_world"/>

android:textColor:设置文字的颜色;

<TextView
    ......
    <!--直接设置文字的颜色-->
    android:textColor="#FFFF0000"/>

<TextView
    ......
    <!--使用引用设置文字的颜色-->
    android:text="@color/color_red"/>

android:textSize:设置文字的大小,文字大小最好使用sp为单位;

<TextView
    ......
    <!--直接设置文字的大小-->
    android:textSize="12sp"/>

<TextView
    ......
    <!--使用引用设置文字的大小-->
    android:textSize="@dimen/text_size"/>

android:textAllCaps:显示的字符都是大写,

<TextView
    ......
    <!--直接设置文字的大小-->
    android:textAllCaps="true"/>

3.2 文字字体

android:textStyle:设置文字的样式,粗体bold、斜体italic等等,默认情况下是normal

<TextView
    ......
    <!--字体设置成了粗体-->
    android:textStyle="bold"/>

android:fontFamily:设置文字显示用的的特定字体家族,可用的字体家族可以参考安卓系统源码的system_fonts.xml文件,里面fileset标签中的名字,就可以用作android:fontFamily的参数,

<TextView
    ......
    <!--字体系统内置的一种字体家族-->
    android:fontFamily="sans-serif-light"/>

android:typeface:设置文字的字型,有normal sans serif monospace四种字型设置;它会与font family对应的字体家族合作,查找合适的字体用来显示文字;

<TextView
    ......
    <!--字体设置成了等宽字体-->
    android:typeface="monospace"/>

如果你使用了fontFamily,那么系统会优先从该fontFamily中,结合typefacetextStyle查找合适的字体;假如没有找到,就会在默认的fontFamily中,结合typefacetextStyle查找合适的字体。

3.3 文字空间利用

android:singleLine:即使文字内容很长,也不要换行显示;

<TextView
    ......
    <!--只能单行显示-->
    android:singleLine="true"/>

android:lines:如果文字内容很长,会换行显示,并且显示行数为设置的行数;如果你的文字没有设定的行数(例如10行)那么多,那么整个TextView也会占据10行文字的高度;

<TextView
    ......
    <!--显示内容的高度为10行的高度-->
    android:lines="10"/>

android:maxLines:如果文字内容很长,会换行显示,但是行数不能超过设置的行数;如果你的文字没有设定的行数那么长,那么整个TextView的高度也就是文字实际占用的高度;

<TextView
    ......
    <!--显示内容不超过2-->
    android:maxLines="2"/>

android:maxLength:指定要显示的字符数量,一个中文汉字也认为是一个字符;

<TextView
    ......
    <!--显示内容不超过4个字符-->
    android:maxLength="4"/>

android:ellipsize:如果文字内容很长,可以通过这个属性设定它的显示效果,

  1. end:显示文字内容的前面部分,后面显示不下的内容用...表示;

    <TextView
        ......
        <!--设置end效果-->
        android:ellipsize="end"
        <!--设置单行显示-->
        android:singleLine="true"/>
  2. start:显示文字内容的后面部分,前面显示不下的内容用...表示;还有其它的条件需要满足:文字必须只有一行;

    <TextView
        ......
        <!--设置start效果-->
        android:ellipsize="start"
        <!--设置单行显示-->
        android:singleLine="true"/>
  3. middle:显示文字的中间部分:两头显示不下的内容用...表示;还有其它的条件需要满足:文字必须只有一行;

    <TextView
        ......
        <!--设置middle效果-->
        android:ellipsize="middle"
        <!--设置单行显示-->
        android:singleLine="true"/>
  4. marquee:以走马灯的方式(文字从右到左滚动)显示;不过要显示这个效果,还有其它的条件需要满足:文字必须只有一行,TextView可以获取焦点,并处于被选中的状态;

    <TextView
        ......
        <!--设置走马灯效果-->
        android:ellipsize="marquee"
        <!--设置单行显示-->
        android:singleLine="true"
        <!--设置可以获取焦点-->
        android:focusableInTouchMode="true"
        android:focusable="true" />

3.4 文字显示效果

android:textAppearance用来指定TextView显示文字时的风格-style。这种style的定义如下,设置了字体的大小、颜色等属性

<style name="TextAppearance">
    <item name="textColor">#FFF</item>
    <item name="textColorHighlight">#0F0</item>
    <item name="textColorHint">#000</item>
    <item name="textColorLink">#FFF</item>
    <item name="textSize">16sp</item>
    <item name="textStyle">normal</item>
</style>

使用的时候,可以使用上面那种自己定义的style,

<TextView
    ......
    android:textAppearance="style/TextAppearance"/>

也可以使用系统预设好的style,
android:textAppearance="?android:attr/textAppearanceSmall
android:textAppearance="?android:attr/textAppearanceMedium
android:textAppearance="?android:attr/textAppearanceLarge
android:textAppearance="?android:attr/textAppearanceLarge等等,是最经常使用的系统提供的style,

<TextView
    ......
    android:textAppearance="?android:attr/textAppearanceSmall"/>

文字阴影
给文字添加阴影效果需要使用android:shadowRadius android:shadowDy android:shadowDx属性。

<TextView
    ......
    android:shadowDx="5"
    android:shadowDy="5"
    android:shadowRadius="10"/>

3.5 文字内容修饰

android:autoLink:如果文字中包含了特定格式的字符串,那么会高亮这个字符串,并且让用户可以点击进行进一步的操作;这个属性有none web email phone map all等多个值选用,

<TextView
    ......
    <!--网址 邮件地址 电话号码 地理位置都可以被高亮显示-->
    android:autoLink="all"/>

3.6 配图的使用

android:drawableTop android:drawableBottom android:drawableLeft android:drawableRight属性可以在文字的上下左右位置设置一个Drawable(例如图片)。

<TextView
    ......
    <!--在文字上方设置图片-->
    android:drawableTop="@mipmap/icon"
    android:text="图库"/>

/*******************************************************************/
* 版权声明
* 本教程只在CSDN安豆网发布,其他网站出现本教程均属侵权。

*另外,我们还推出了Arduino智能硬件相关的教程,您可以在我们的网店跟我学Arduino编程中购买相关硬件。同时也感谢大家对我们这些码农的支持。

*最后再次感谢各位读者对安豆的支持,谢谢:)
/*******************************************************************/

版权声明:本文为博主原创文章,禁止转载,违者必究。

相关文章推荐

Android LinearLayout及TextView的布局方式

LinearLayout(线性布局) android:orientation="vertical"垂直线性布局,"horizontal"水平线性布局 android:gravity="top"(bu...

Android动态布局,并动态为TextView控件设置drawableLeft、drawableRight等属性添加图标

Android动态布局,并动态为TextView控件设置drawableLeft、drawableRight等属性添加图标 注:(图中每一个条目和图标都是由代码动态生...
  • xgsjyl
  • xgsjyl
  • 2015年10月27日 16:49
  • 3795

一个TextView控件搞定图文一行布局

利用TextView控件的drawableLeft、drawableRight、drawableTop、drawableBottom属性实现图文一行布局。...
  • Monas
  • Monas
  • 2017年04月12日 17:51
  • 248

Android 使Textview等其他控件重叠,在布局的正上方中间

项目中需要时一个textview居于layout布局的正中间部分,如下图所示:      使用相对布局的形式,可以使控件居于左上角和右上角,但就是无法居于布局的正中间的上方,会被覆盖掉,原先的布...

Android动态布局,并动态为TextView控件设置drawableLeft、drawableRight等属性添加图标

注:(图中每一个条目和图标都是由代码动态生成) 代码动态布局,并需要为每一个条目设置图标,此时用到了 android:drawableLeft="@drawable/icon"  ...

布局与控件(九)-ListView的Adapter们

Android SDK为我们提供了不少可以直接使用的Adapter,你对它们了解吗?这些Adapter都合适吗?自己实现一个吧。本文将详细的介绍常用的几个Adapter,并教会你如何自定义一个全能Ad...

布局与控件(七)-ListView知多少(上)

ListView在很多应用当中都会用到。它有那么多属性都能够干嘛?本文为你整理了最为经常使用的属性,图文并茂的让你看到它们的实际效果。...

布局与控件(八)-ListView知多少(下)ChoiceMode详解

列表要常常用到单选或多选功能对吧?!ListView的Choice Mode你听说过吗?它已经自带选择功能了!那么什么又是模式多选?本文将详细的讲述ListView的各种选择功能,教你结合选择项如何指...

布局与控件(四)-Button的响应与背景

你知道Button控件不仅可以在代码中指定响应函数,而且还可以在xml文件中指定响应函数吗?Button控件点击的效果怎么修改呢?本文将解答这两个开发时一定会遇到的问题。...

GirdLayout布局:更改其中的TextView控件的TextSize属性后,出现控件未对齐情况

采用GridLayout布局,子控件为TextView,在使用过程中,由于数据都是从数据库中读取出来的,所以在TextView中显示的文字长度不同,造成字数过多时字会换行或溢出,那么,根据这个情况,针...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:布局与控件(三)-TextView那些事儿
举报原因:
原因补充:

(最多只允许输入30个字)