left_x = x; left_y = y; left_color = color; }
/** * 设置右阴影 * * @param x 定位信息 * @param y 定位信息 * @param color 颜色 */ public void setRightShadow(int x, int y, Color color) { right_x = x; right_y = y; right_color = color; } }
RichJLabel扩展了标准的javax.swing.JLabel,并在构造函数中加入了tracking参数。接下来,它增加了两个方法用来绘制左阴影和右阴影。这里之所以称之为阴影是因为它们绘制在主体文本的下面,但它们看起来到底像不像阴影这取决于它的颜色,以及x-和y-的偏移量。
JLabel自动通知布局管理器它的最佳尺寸依赖于字体的大小。当你加入定制的tracking时,尺寸将会变得不准确,导致JLabel太小以至于容纳不下所显示的字体。对于小字体而言这并不容易引起人们的注意,但对于一些特殊显示效果的字体(如广告字之类的字体被放大,一个字可能会占用半张纸或更多的)而言,我们就不得不想办法加以改善了。
所有的Swing组件都通过getPreferredSize()方法返回它的最佳尺寸。通过将返回值适当的调大,使用这个组件的布局管理器会给JLabel预留出它所需要的额外空间,因此我们可以通过重载该方法来满足我们特殊的显示要求,参考下面的代码片段:
示例代码2:
/** * 获取最佳尺寸 */ public Dimension getPreferredSize() { // 获取JLabel的文本 String text = getText(); // 获取字体相关信息 FontMetrics fm = this.getFontMetrics(getFont());
int w = fm.stringWidth(text); w += (text.length() - 1) * tracking; w += left_x + right_x;
int h = fm.getHeight(); h += left_y + right_y; return new Dimension(w, h); } 在上面的方法中,getPreferredSize()方法计算的依据是当前要显示文本的度量单位。对象FontMetrics包含了获得当前显示字体高度和宽度的方法。由于变量tracking已经加到了字体原有的tracking属性中,我们可以 上一页 [1] [2] [3] [4] [5] 下一页
|