Java开发笔记(一百二十)AWT文本标签

前面介绍了AWT窗口及其面板的简单用法,其中展现出来的控件只有按钮一种,还有不少好用好玩的控件有待介绍。首先是文本标签Label,该控件用于显示一段平铺文本,它不花哨也不跳动,彻底就是素面朝天的文本字符。不过,即使是文本,也能拥有鲜明的个性,犹如书法那样,能够横排也能够竖排,既可写在白纸上也可写在红纸上,还能以专门的字体来书写如楷书、行书、草书、隶书等等。这些彰显个性的功能,须要调用文本标签的相应方法来实现,下面是Label的常见方法说明:
setText:设置文本内容。
setAlignment:设置内部文本的对齐方式。Label.CENTER表示居中对齐,Label.LEFT表示向左对齐,Label.RIGHT表示向右对齐。
setPreferredSize:设置文本标签的推荐宽高。
setBackground:设置文本标签的背景颜色。
setForeground:设置文本标签的前景颜色,其实就是文字颜色。
setFont:设置文本的字体(包括样式与大小)。
这里须要补充描述一下AWT的颜色与字体用法,不光是标签Label,还有不少控件会用到颜色和字体。颜色用到了Color工具,而且Color类自带了几种颜色常量,包括白色Color.WHITE、灰色Color.GRAY、黑色Color.BLACK、红色Color.RED、粉红Color.PINK、橙色Color.ORANGE、黄色Color.YELLOW、绿色Color.GREEN、玫红Color.MAGENTA、青色Color.CYAN、蓝色Color.BLUE等。但是彩虹的七种颜色——赤橙黄绿青蓝紫,AWT竟然没提供紫色的颜色常量,只好由程序员本身来计算紫色了。在计算机行业标准中,显示设备广泛采用RGB颜色模式,也就是以红、绿、蓝为三原色,三原色各取若干叠加起来,便造成万紫千红的花花世界。不料AWT的Color工具却采起另外一种HSB色彩模式,这样还得先将大众熟知的RGB色值转换为HSB色值才行,转换过程调用的是RGBtoHSB方法,而后再调用getHSBColor方法根据HSB色值得到颜色实例。从RGB色值到最终可用的颜色实例,完整的转换代码以下所示:html

	// 使用RGB数值得到AWT的颜色实例
	private static Color getColor(int red, int green, int blue) {
		// 把RGB色值转换为HSB色值数组
		float[] hsbs = Color.RGBtoHSB(red, green, blue, null);
		// 利用HSB色值得到AWT的颜色实例
		Color color = Color.getHSBColor(hsbs[0], hsbs[1], hsbs[2]);
		return color;
	}

 

如此一来,给新定义的getColor方法填入具体的RGB数值,便可获得五光十色的Color对象了。譬如紫光由红光与蓝光混合而成,那么只需下面一行代码就能得到紫光的颜色实例了:程序员

				Color purple = getColor(255, 0, 255); // 红光与蓝光混合就变成了紫光

至于字体则用到了Font工具,它决定了文字的形状和大小,调用Font的构造方法之时,第二个参数表示文字的书写字体,包括默认的普通体Font.PLAIN、斜体Font.ITALIC、粗体Font.BOLD;第二个参数表示文字的大小,默认值为12,数值越大文字也越大。好比如下代码就分别建立了大号斜体与中号粗体共两种字体对象:数组

				// 建立一个30号大小且为斜体的字体对象
				Font italic_big = new Font("大号斜体", Font.ITALIC, 30);
				// 建立一个20号大小且为粗体的字体对象
				Font bold_middle = new Font("中号粗体", Font.BOLD, 20);

接下来经过文本标签的相关方法,看看实际的界面展现效果。先在窗口的中间位置添加文本标签,准备经过该控件观察Label的文字变化效果,往面板添加标签的代码示例以下:工具

		Label label = new Label("这里查看文字效果"); // 建立一个文本标签
		label.setAlignment(Label.CENTER); // 设置文本标签的对齐方式
		label.setPreferredSize(new Dimension(300, 50)); // 设置文本标签的推荐宽高
		Panel panelCenter = new Panel(); // 建立中央面板
		panelCenter.add(label); // 在中央面板上添加文本标签
		frame.add(panelCenter, BorderLayout.CENTER); // 把中央面板添加到窗口的中间位置

而后看给标签设置背景色的例子,下面代码调用了文本标签的setBackground方法:字体

		Panel panelTop = new Panel(); // 建立顶部面板
		Button btn1 = new Button("背景黄色"); // 建立一个按钮
		btn1.addActionListener(new ActionListener() { // 给按钮注册点击监听器
			public void actionPerformed(ActionEvent e) { // 发生了单击事件
				label.setBackground(Color.YELLOW); // 设置文本标签的背景颜色
			}
		});
		panelTop.add(btn1); // 在顶部面板上添加按钮

 

运行以上的背景色设置代码,单击按钮后的窗口界面以下图所示,可见标签区域的背景颜色变为黄色。3d

再来看设置前景色的例子,下面代码调用了文本标签的setForeground方法:orm

		Button btn2 = new Button("前景红色"); // 建立一个按钮
		btn2.addActionListener(new ActionListener() { // 给按钮注册点击监听器
			public void actionPerformed(ActionEvent e) { // 发生了单击事件
				label.setForeground(Color.RED); // 设置文本标签的前景颜色(即文字颜色)
			}
		});
		panelTop.add(btn2); // 在顶部面板上添加按钮

 

运行以上的前景色设置代码,单击按钮后的窗口界面以下图所示,可见标签内部的文本颜色变为红色。htm

抛开AWT自带的几种颜色,程序员本身定义紫色实例,并将文本标签的背景色设置为紫色,此时的调用代码以下所示:对象

		Button btn3 = new Button("背景紫色"); // 建立一个按钮
		btn3.addActionListener(new ActionListener() { // 给按钮注册点击监听器
			public void actionPerformed(ActionEvent e) { // 发生了单击事件
				Color purple = getColor(255, 0, 255); // 红光与蓝光混合就变成了紫光
				label.setBackground(purple); // 把标签背景设置为紫色
			}
		});
		panelTop.add(btn3); // 在顶部面板上添加按钮

 

运行以上的背景色设置代码,单击按钮后的窗口界面以下图所示,可见标签区域的背景颜色变为紫色。blog

接着给标签文本设置大号斜体,利用setFont方法设置字体的代码示例以下:

		Button btn4 = new Button("大号斜体"); // 建立一个按钮
		btn4.addActionListener(new ActionListener() { // 给按钮注册点击监听器
			public void actionPerformed(ActionEvent e) { // 发生了单击事件
				// 建立一个30号大小且为斜体的字体对象
				Font italic_big = new Font("大号斜体", Font.ITALIC, 30);
				label.setFont(italic_big); // 设置文本标签的字体及大小
			}
		});
		panelTop.add(btn4); // 在顶部面板上添加按钮

 

运行上面的字体设置代码,单击按钮后的窗口界面以下图所示,可见标签文本变为斜体,同时文字也变大了很多。

最后给标签文本设置中号粗体,利用setFont方法设置字体的代码示例以下:

		Button btn5 = new Button("中号粗体"); // 建立一个按钮
		btn5.addActionListener(new ActionListener() { // 给按钮注册点击监听器
			public void actionPerformed(ActionEvent e) { // 发生了单击事件
				// 建立一个20号大小且为粗体的字体对象
				Font bold_middle = new Font("中号粗体", Font.BOLD, 20);
				label.setFont(bold_middle); // 设置文本标签的字体及大小
			}
		});
		panelTop.add(btn5); // 在顶部面板上添加按钮

 

运行上面的字体设置代码,单击按钮后的窗口界面以下图所示,可见标签文本变为粗体,同时文字也变大了一些。

另外,setBackground、setForeground、setFont这三个方法不仅仅为标签Label所用,按钮Button也能调用它们,举凡带文字的控件,都支持经过这三个方法来设置背景色、前景色与字体。



更多Java技术文章参见《Java开发笔记(序)章节目录

相关文章
相关标签/搜索