`
sarin
  • 浏览: 1761256 次
  • 性别: Icon_minigender_1
  • 来自: 大连
博客专栏
E3b14d1f-4cc5-37dd-b820-b6af951740bc
Spring数据库访问系列...
浏览量:174042
C2083dc5-6474-39e2-993e-263652d27795
Android学习笔记
浏览量:368839
5f40a095-b33c-3e8e-8891-606fcf3b8d27
iBatis开发详解
浏览量:189642
B272a31d-e7bd-3eff-8cc4-c0624ee75fee
Objective-C学习...
浏览量:100310
社区版块
存档分类
最新评论

Android学习笔记四:基本视图组件:TextView

阅读更多
    接上文   
    TextView在我们第一个应用程序中已经使用过了,通过第一个程序,我们看到Activity程序和视图组件关系密切,这里我们进行深入介绍。
    Android中的全部视图组件的父类是android.view.View类,看一下文档:

java.lang.Object
   ↳ android.view.View

    从文档中我们可以看出TextView类是View类的直接子类,而Button类是View的间接子类,后面我们会详细介绍。
    下面来看看TextView组件,TextView组件主要用于静态文本的显示,这在第一个程序中,我们很容易就能看出来。android.widget.TextView类是android.view.View类的直接子类,这里注意TextView类并不在android.view包中,而是在android.widget包中,也就是说,我们在Aandroid中使用的具体视图组件,都是在android.widget包中的。下面看一下TextView类的文档:

java.lang.Object
   ↳ android.view.View
   ↳ android.widget.TextView

    从中我们看到了类的继承关系,也知道了Button类和EditText类是TextView的直接子类,并从类说明中了解到TextView用于文本的显示,而要修改文本的内容,我们就要使用EditText了。
    了解过基本内容后,我们来深入了解一下TextView组件。
    在Eclipse中我们新建一个项目TextViewDemo,

    之后我们来编写几个基本的TextView组件:
    <TextView
        android:id="@+id/text1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="#FDF5E6"
        android:textSize="16dp"
        android:text="这里是一个TextView视图组件" />

    在这个TextView中我们较之前的示例添加了两个属性,一个是textColor,很显然这是设置文件颜色的,另外一个是textSize,设置文字大小。
    这里多说一点,关于文字大小,是数字加单位的格式,这里我们使用的是dp,当然还有pt,px,mm等值可选。
    运行程序,我们来看看效果:

    可以看到文本的颜色变化了,字体也变化了,说明我们的设置都起作用了。
    下面再来看第二个TextView示例:
    <TextView
        android:id="@+id/text2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="30dp"
        android:autoLink="all"
        android:text="Google一下: http://www.google.com.hk" />

    这里的文本中我包含的一个超链接,这样我们就可以通过点击超链接来访问网站,如果在TextView中想让文本中的超链接自动识别成地址,那么需要加入autoLink属性,其值有多种,这里设置成all表示所有的可链接的地址都识别,包括email地址。还有一个属性是layout_margin,这是样式属性,表示页边距,它和CSS中的margin属性类似,这里表示距离上下左右各30dp的距离,其余属性不再说明,下面看一下运行效果:

    可以看出,首先样式上,距离上下左右各有30dp的间隔,其次是其中的网址信息已经被识别成了超链接,那么我们就可以点击这个网址来访问想要访问的站点,保证模拟器运行环境是可以上网的,那么点击该地址,我们可以看到:

    就访问到了移动版的Google(这里切到横屏显示,效果更好一点)。
    下面继续对TextView进行说明,看第三个示例:
<TextView
        android:id="@+id/text3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="40dp"
        android:maxLength="7"
        android:text="@string/powered_by" />

    这里设置的属性有layout_marginLeft,从字母理解就是左边距,也是样式上的设置,和CSS中的margin-left也是一样的,那么这个组件仅仅是对左边有40dp的距离,而上下和右侧则不会有边距了。默认的显示文本是“Powered By Nan Lei”,但这里我们多设置了一个属性是maxLength,也就是最大显示的长度,是7个字符长度,也就是说,我们只会看到“Powered”显示出来了,后面的文本就被截掉了,看一下运行效果:

    下面来看第四种TextView的示例,我们将会插入一张图片:
    <TextView
        android:id="@+id/text4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/ic_launcher"
        android:text="图片上的文字"
        android:textColor="#FFFFFF"
        android:textStyle="italic" />

    和之前的示例比较,这里我们多用了一个background属性,就是用来表示背景图片的,那么我们使用项目自带的一个图片,就是Android机器人的图标,引用图片资源,要使用@drawable来引用,那么就得到如下的显示效果了:

    此时,文字就在图片上方显示出来了。
    看了四个示例之后,我们会发现,对显示文本的样式设置较多,结合CSS的使用,我们在网页中常把CSS文件单独分离出来,便于后期的维护。类似地,在Android中,我们也可以将用于样式控制的属性单独抽取出来形成样式文件,而在TextView组件中直接引用样式即可,那么对样式属性的维护就变得容易了,我们来设置显示样式。
    首先需要在values文件夹下创建styles.xml,用于放置样式的配置信息,内容如下:
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="text_style">
        <item name="android:textSize">16dp</item>
        <item name="android:textColor">#FDF5E6</item>
        <item name="android:textStyle">italic|bold</item>
        <item name="android:layout_width">wrap_content</item>
        <item name="android:layout_height">wrap_content</item>
    </style>
</resources>

    和strings.xml文件中的内容类似,只是这里我们使用了style来定义样式,给出一个样式的名称,这里为text_style,那么就可以在style元素中来设置具体的样式了。每个样式使用item来定义,name就是前面看到的样式名称,然后给出样式属性的值,这和前面都是一样的,只是这里在定义字体时,使用了斜体粗体并存的样式,使用竖线分隔开即可。然后修改我们的TextView定义:
   <TextView
        android:id="@+id/text1"
        style="@style/text_style"
        android:text="这里是一个TextView视图组件" />

    这里面已经去掉了所有和样式相关的内容,然后使用style属性来引用外部样式表中配置的样式即可,运行程序,得到如下效果:

    可以看到我们的样式对一个TextView组件起作用了,说明我们的代码是好用的。
    做了这么多的东西,看看我们哪些资源已经反映到了R.java中:
package org.ourpioneer;
public final class R {
    public static final class attr {
    }
    public static final class drawable {
        public static final int ic_launcher=0x7f020000;
    }
    public static final class id {
        public static final int text1=0x7f060000;
        public static final int text2=0x7f060001;
        public static final int text3=0x7f060002;
        public static final int text4=0x7f060003;
    }
    public static final class layout {
        public static final int main=0x7f030000;
    }
    public static final class string {
        public static final int app_name=0x7f040001;
        public static final int hello=0x7f040000;
        public static final int powered_by=0x7f040002;
    }
    public static final class style {
        public static final int text_style=0x7f050000;
    }
}

    我们没有设置attr资源,所以该类下是空的,id资源表示了我们配置的四个TextView组件,layout只有一个main,string资源有三个,这是我们配置的,最后一个是style资源,这里就是我们配置的text_style样式表。
    前面说过所有的XML配置都可以通过代码来实现,那么我们看看对text3在程序中进行进一步的设置:
package org.ourpioneer;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class TextViewDemoActivity extends Activity {
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		super.setContentView(R.layout.main);
		TextView text3 = (TextView) super.findViewById(R.id.text3);
		text3.setTextAppearance(this, R.style.text_style);
	}
}

    这段代码不用过多解释了,获取到text3组件之后,设置显示的样式,只是注意这里不是setStyle()方法,而是setTextAppearance()方法。该方法参数为Context和resId,那么只需传入this和R.style.text_style即可。我们来看下对text3组件的效果:

    我们就可以看到最后的效果了,text3组件的显示效果也变化了,说明我们的代码起作用了。
    全部示例代码请参考附件。
    接下文
  • 大小: 69.4 KB
  • 大小: 74.9 KB
  • 大小: 48.5 KB
  • 大小: 29 KB
  • 大小: 35.6 KB
  • 大小: 42.9 KB
  • 大小: 36.5 KB
  • 大小: 41.3 KB
  • 大小: 41.6 KB
  • 大小: 41.8 KB
7
0
分享到:
评论
2 楼 奮闘ing 2014-12-09  
谢谢,学习了~
1 楼 qianguming 2013-09-29  
紧紧跟随3.挺详细的哦。但是要真项目的话,还是直接的配置好了,在activity中配置好麻烦的说

相关推荐

    Android学习笔记六:基本视图组件:EditText

    这篇“Android学习笔记六:基本视图组件:EditText”将深入探讨`EditText`的使用、功能以及相关知识点。 首先,`EditText`继承自`TextView`,因此它具备`TextView`的所有属性,如显示文本、字体样式等。但与`...

    Android学习笔记五:基本视图组件:Button

    在Android开发中,基本视图组件是构建用户界面的基础元素,它们构成了应用程序的大部分交互界面。本篇笔记将深入探讨Android中的Button组件,它是用户进行点击操作的主要元素,广泛用于触发事件或导航。 Button组件...

    Android学习笔记13:表格布局管理器TableLayout

    本篇学习笔记将深入探讨TableLayout的核心概念、属性以及使用方法。 一、TableLayout的基本结构 TableLayout由多个TableRow组成,每个TableRow代表一行,可以包含一个或多个子视图。在Android XML布局文件中,...

    Android学习笔记三:第一个应用程序的扩充

    在这个"Android学习笔记三:第一个应用程序的扩充"中,我们将深入探讨如何扩展这个基础,以更好地理解和掌握Android应用开发的核心概念。 首先,Android Studio作为Google官方推荐的集成开发环境(IDE),是Android...

    Android+学习笔记

    ### Android学习笔记知识点详解 #### 一、简介与背景 Android作为全球最受欢迎的移动操作系统之一,自2007年谷歌发布以来,迅速占领市场并持续引领移动技术的发展。随着移动互联网的兴起和发展,Android应用开发...

    ANDROID学习笔记4

    ### ANDROID学习笔记4 #### 一、ListView深入解析与实战应用 在Android开发中,`ListView`是一种非常重要的UI组件,它能够显示一个可以滚动的列表,支持单选或多选模式。本节将详细介绍`ListView`的基本用法、...

    Android的学习笔记

    ### Android学习笔记:Chronometer(计时器)的使用 #### 一、Chronometer简介 在Android开发过程中,经常会遇到需要计时的情况,比如游戏应用中的倒计时、运动类应用中的跑步计时等场景。这时候,`Chronometer`...

    Android学习笔记(二三): 多页显示-Flipper的使用.doc

    【Android学习笔记(二三):多页显示-Flipper的使用】 在Android开发中,展示多页内容是常见的需求,通常我们可以通过Tab布局来实现,但除此之外,还有一个组件可以帮助我们实现这一功能,那就是`ViewFlipper`。`...

    Android学习笔记(十七):再谈ListView.doc

    在本篇学习笔记中,我们将深入探讨如何使ListView更生动、更具表现力,主要涉及自定义Adapter和动态设置ListView元素。 首先,我们来看一个基础示例,每个列表项包含一个图标和一段文字信息: 1. 在主界面的XML...

    android 学习笔记整理

    在Android学习过程中,掌握基础知识是至关重要的。这份"android 学习笔记整理"包含了作者在学习Android时积累的详尽资料,旨在为初学者提供一个系统化的学习路径和参考资料。 首先,Android是一种开源的操作系统,...

    Android Studio 学习笔记-新手入门-(1)第一个案例

    这篇学习笔记将引导新手入门,通过创建第一个简单的案例来了解Android Studio的基本操作。 首先,让我们了解一下Android Studio的核心功能。它基于IntelliJ IDEA,具备代码自动补全、重构、调试等强大的开发特性。...

    Android学习笔记总结初学者必看.rar_Android java_android

    在Android学习之旅中,初学者会遇到各种概念和实践技巧,这份"Android学习笔记总结初学者必看"的文档正是为了帮助他们系统性地掌握这一领域。以下是对这份压缩包内容的详细解读。 首先,Android是由Google开发的一...

    Android学习笔记(八):Activity-OpenMenu和LinearLayout.doc

    在Android开发中,Activity是应用程序的基本组件,负责与用户交互。OpenMenu涉及到的是Android系统中的选项菜单机制,而LinearLayout是一种常用的布局管理器,用于组织和排列应用界面中的控件。 首先,我们来看如何...

    黑马Android基础笔记

    《黑马Android基础笔记》是一份全面且深入的Android开发学习资料,主要针对初学者和希望巩固基础知识的开发者。这份笔记涵盖了Android开发的核心概念和技术,旨在帮助读者构建坚实的Android开发基础。 1. **Android...

    Android学习笔记(十一):Activity-ListView.doc

    在Android开发中,ListView是一个非常重要的组件,用于展示大量数据的列表形式。在本文中,我们将深入探讨如何在Activity中使用ListView,并通过实例讲解其基本用法。 首先,当我们需要在Activity中仅显示一个...

    [转载]Android学习笔记(三):Andriod程序框架.doc

    这篇学习笔记主要涵盖了如何在Eclipse环境下创建一个基本的Android项目以及对Android程序框架的基本理解。以下是对这些内容的详细阐述: 首先,Android程序框架的核心组件是Activity,它是应用程序与用户交互的窗口...

    Android学习笔记(Android Studio)2-1~2-5(LinearLayout、RelativeLayout、TextView、Button、EditText、RadioButton)

    学习这些基础知识是Android开发的起点,理解并熟练运用LinearLayout、RelativeLayout、TextView、Button和EditText等基本组件,将有助于构建功能丰富的用户界面。在实际开发中,还需要结合Activity、Intent等概念,...

    android学习笔记最新版(1-4)

    总结来说,这份"android学习笔记最新版(1-4)"全面覆盖了Android开发的起步阶段,从基本概念到实际操作,为有志于投身Android开发的新人提供了扎实的学习路径。通过系统学习并实践这些内容,不仅能够掌握Android...

Global site tag (gtag.js) - Google Analytics