《Android/OPhone开发完全讲义》连载(6):为TextView组件加上边框

本文为原创,如需转载,请注明作者和出处,谢谢!

《Android/OPhone 开发完全讲义》目前计算机类销售总排名:互动网(china-pub)第3名,当当网新书热卖榜销售总排名第4名

本文为新书《Android/OPhone 开发完全讲义》的内容连载。《Android/OPhone开发完全讲义》一书现已出版,敬请关注。

购 买:

互动网(china- pub)
当 当(dangdang)
卓越亚马逊

《Android/OPhone 开发完全讲义》目录

源代码下载




上一篇: Notification 与状态栏信息

Android系统本身提供的TextView组件并不支持边框,但可以对TextView进行扩展来添加边框。我们可以使用如下两种方法为TextView组件添加边框。

1. 编写一个继承TextView类的自定义组件,并在onDraw事件方法中画边框。

2. 使用9-patch格式的图像作为TextView的背景图来设置边框(这个背景图需要带一个边框)。

onDraw事件方法中画边框非常容易,只需要画TextView组件的上、下、左、右四个边即可。这个自定义组件的代码如下:

package net.blogjava.mobile;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.widget.TextView;

public class BorderTextView extends TextView
{
@Override
protected void onDraw(Canvascanvas)
{
super .onDraw(canvas);
Paintpaint
= new Paint();
// 将边框设为黑色
paint.setColor(android.graphics.Color.BLACK);
// 画TextView的4个边
canvas.drawLine( 0 , 0 , this .getWidth() - 1 , 0 ,paint);
canvas.drawLine(
0 , 0 , 0 , this .getHeight() - 1 ,paint);
canvas.drawLine(
this .getWidth() - 1 , 0 , this .getWidth() - 1 , this .getHeight() - 1 ,paint);
canvas.drawLine(
0 , this .getHeight() - 1 , this .getWidth() - 1 , this .getHeight() - 1 ,paint);
}
public BorderTextView(Contextcontext,AttributeSetattrs)
{
super (context,attrs);
}
}

在上面的代码中将边框设成了黑色,读者也可以根据需要将边框设置成任何的颜色,或从XML布局文件中读取相应的颜色值,关于自定义组件的详细介绍请读者参阅4.2的内容。

虽然可以直接使用带边框的图像作为TextView组件的背景来设置边框,但当TextView的大小变化时,背景图像上的边框也随之变粗或变细,这样看起来并不太舒服。为了解决这个问题,可以采用9-patch格式的图像来作为TextView组件的背景图。我们可以使用<Android SDK安装目录>\tools\draw9patch.bat命令来启动“Draw 9-patch”工具。制作9-patch格式的图像也很简单,将事先做好的带边框的png图像(必须是png格式的图像)用这个工具打开,并在外边框的上方和左侧画一个象素点,然后保存即可,如图1所示。9-patch格式的图像必须以9.png结尾,例如,abc.9.png。在生成完9-patch格式的图像后,使用<TextView>标签的android:background属性指定相应的图像资源即可。

图1

运行本例后,显示的效果如图2所示。


图2

注意:如果想让TextView透明,也就是将TextView的父视图的背景色作为TextView组件的背景色,如图2所示的第3TextView组件,需要制作带边框的透明png图像(除了边框,图像的其他部分都是透明的),然后再生成9-patch格式的图像。







Android开发完全讲义(第2版)(本书版权已输出到台湾)

http://product.dangdang.com/product.aspx?product_id=22741502



Android高薪之路:Android程序员面试宝典 》http://book.360buy.com/10970314.html


新浪微博:http://t.sina.com.cn/androidguy 昵称:李宁_Lining

更多相关文章

  1. Android高手进阶教程(十九)---Android中几种图像特效处理的集锦!
  2. Andropid自定义组件-坐标详解
  3. Android基础和运行机制
  4. Android高手进阶教程(二十二)之---Android中几种图像特效处理的
  5. Android(安卓)1.5和Android(安卓)2.1在相对布局(RelativeLayout)上
  6. Android之应用进程托管
  7. 第一部分:开发前的准备-第三章 Application 基本原理
  8. Chronometer android计时器组件Chronometer的使用,android通话时
  9. 基于android的远程视频监控系统

随机推荐

  1. Android Training - 使用碎片创建一个动
  2. Android蓝牙通讯模块源码(Android蓝牙开发
  3. [Android Studio 权威教程]Android Studio
  4. 关于Android中GestureOverlayView多笔画
  5. Android自动化测试工具实现简述
  6. 调试方法-Unity3D对各个target平台的模拟
  7. Android软件开发之获取通讯录联系人信息(
  8. 一个吊丝android个人开发者的逆袭之路
  9. Android聊天客户端Demo,开源了.基本功能
  10. 再一次在Eclipse下配置Android