TextView这个可以说是Android中最简单的一个控件了。该控件主要用来显示一段文字。
其中控件的显示设置也很简单,这里简单说一下重要的几个,控件的id,layout_weigth(宽度),layout_height(高度),text(显示文字内容)等都是比较常用和简单的设置,不在详细描述。
(1)文字的编辑
设置文本的大小,颜色有两种方式:一种是通过在layout中的布局文件中设置;另一种是在Activity中的onCreate方法中进行设置。
xml文件设置
设置文字的内容为“消息”,大小为“20sp”(文字的单位一般采用sp),颜色是“黑色”,文字对其方式是“居中”。
1 2 3 4 5 6 7 8 |
<TextView android:id="@+id/textView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="消息" android:textSize="20sp" android:textColor="#000000" android:gravity="center"/> |
Activity中的修改
1 2 3 4 5 6 7 8 9 |
//设置文字大小 ,大小只能传像素值 textView.setTextSize(67); //设置颜色,三种方式。 textView.setTextColor(0xff00ff00); textView.setTextColor(Color.BLUE); textView.setTextColor(Color.argb(0x99, 0xff, 0x00, 0x00)); // 通过values中的color中设置的颜色来设定。 int color = getResources().getColor(R.color.red); textView.setTextColor(color); |
(2)文本的链接
将文本中的电话号码,Email,URL等设置为链接。对这个的设置叶有两种方式:一种是在layout中的xml文件中进行添加;另一种是在Activity的onCreate方法中添加代码。
xml文件设置
链接设置可以设置为:all, map, none, email, phone以及web。在这我们以设置为phone为例。 (电话号码是随便编的哟……)
1 2 3 4 5 6 |
<TextView android:id="@+id/textView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="TextView:13314121514" android:autoLink="phone"/> |
Activity中的修改
1 2 3 |
// 设置连接方式,文字必须在其后面。 textView.setAutoLinkMask(Linkify.ALL); textView.setText("TextView:13314121514"); |
(3)添加图片
可以在TextView中添加图片,通过在layout中的布局文件中添加,添加的过程同时也设置了图片字TextView中的位置,如下设置的是在其顶部:
1 |
android:drawableTop="@mipmap/communication" |
也可以修改图片上下所占的间距,通过如下代码:
1 |
android:drawablePadding="10sp" |
(4)文本的省略显示
之前我记得我第一部智能手机在收到短信的时候,如果我在其他应用中,短信的内容如果过长机会再我手机的系统标题栏上滚动显示,那其实就是一种对文本过长的处理。
在TextView中可以设置 android:ellipsize属性就行修改。android:ellipsize的属性值有marquee(滚动显示),end(末尾显示······),middle(中间显示······),none(不显示省略号,多余自动不显示)。
其中end, middle, none的设置很简单,只需要设置android:ellipsize=""
即可,但是滚动显示“marquee”还需要设置焦点,代码如下:
1 2 3 4 |
android:ellipsize="marquee" android:focusable="true" android:focusableInTouchMode="true" android:singleLine="true" |
(5)富文本
先说一下什么是富文本,富文本就是对文本中一些特殊文字或者图片的特殊显示。例如我们我们发一段话“你还没有还我100块钱。”这句话我们要强调“100块钱”这是后我们可以把它显示为特殊的颜色,这其实就是一种富文本。有时候我们QQ聊天经常发表情,其实这也是一种富文本。富文本,可以支持一部分的HTML,也可以动态添加的一些图片。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
textFu = (TextView) findViewById(R.id.textFu); Spanned spanned = Html.fromHtml("这是一个<font color='#00ffff'>富文本</font>,然后加一个图标<img src='a_merchant_06_click'/>", new Html.ImageGetter() { @Override public Drawable getDrawable(String s) { int id = R.mipmap.ic_launcher; //方法一:通过反射获得s. Class clazz =R.mipmap.class; try { Field field = clazz.getDeclaredField(s); id = field.getInt(s); } catch (NoSuchFieldException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } Drawable drawable = getResources().getDrawable(id); drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight()); } },null); textFu.setText(spanned); textFu.setPaintFlags(Paint.STRIKE_THRU_TEXT_FLAG); |
1 2 3 4 5 6 7 8 9 10 11 12 13 |
textFu = (TextView) findViewById(R.id.textFu); Spanned spanned = Html.fromHtml("这是一个<font color='#00ffff'>富文本</font>,然后加一个图标<img src='a_merchant_06_click'/>", new Html.ImageGetter() { @Override public Drawable getDrawable(String s) { //方法二,直接通过R.mipmap.a_merchant_06_click,得到图片。 Drawable drawable = getResources().getDrawable(R.mipmap.a_merchant_06_click); drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight()); return drawable; } },null); textFu.setText(spanned); textFu.setPaintFlags(Paint.STRIKE_THRU_TEXT_FLAG); |
代码设置的富文本显示如下: