Каждый стандартный графический компонент — это прямоугольная область на экране со сторонами, параллельными сторонам экрана. Стороны прямоугольника выделяются каким-то образом на экране. Например, стороны кнопки JButton нарисованы так, что создают впечатление ее выпуклости. При нажатии кнопки мыши оформление сторон графической кнопки меняется, создавая впечатление ее "вдавленности".
Некоторые компоненты, например JLabei, вообще не оформляют свои границы.
В любом случае библиотека Swing позволяет изменить оформление границ всякого компонента, в том числе и контейнера, обведя его рамкой, причем рамка может быть самого разного вида.
Самые общие свойства всех рамок описаны интерфейсом Border из пакета javax. swing. border. Основное свойство — вычерчивание рамки методом
public void paintBorder(Component c, Graphics g,
int x, int y, int width, int height);
Здесь задается компонент c, который обводится рамкой, экземпляр g класса Graphics, обладающего методами рисования, и размеры рамки, которые обычно совпадают с размерами компонента, чуть больше или чуть меньше их.
Рамка может быть прозрачной или не прозрачной. Это отмечается логическим методом
isBorderOpaque().
Последний метод интерфейса, getBorderInsets(Component c), возвращает пространство, занятое рамкой данного компонента c, в виде экземпляра класса Insets. Напомним, что в классе Insets это пространство определяется толщиной рамки сверху top, слева left, справа right и снизу bottom. Все четыре поля класса Insets — просто целочисленные переменные, и получить толщину рамки сверху можно так:
int d = b.getBorderInsets(this).top;
Интерфейс Border частично реализован абстрактным классом AbstractBorder, в котором сделана пустая реализация метода paintBorder(), метод isBorderOpaque() возвращает false, а метод getBorderInsets () — объект с нулевыми значениями. Кроме этих реализаций в классе есть метод
public static Rectangle getInteriorRectangle(Component c, Border b,
int x, int y, int width, int height);
который удобно использовать для определения размеров самого компонента без рамки.
Класс AbstractBorder расширяют около двадцати классов, вычерчивающих самые разнообразные рамки. Для удобства работы с ними в пакете javax.swing имеется класс BorderFactory, в котором собраны статические методы вида createXxxBorder ( ) для различных типов рамок с разными параметрами. Чаще всего для создания рамки достаточно воспользоваться одним из этих методов, а затем установить полученную рамку в компонент методом setBorder(Border) класса JComponent. Например, на рис. 16.1 один из компонентов создан методами:
JLabel l2 = new JLabel(" LineBorder(Color.blue, 3) ");
l2.setBorder(BorderFactory.createLineBorder(Color.blue, 3));
Рассмотрим подробнее некоторые типы рамок. Простые типы рамок показаны на рис. 16.1, созданном программой листинга 16.1.
import java.awt.*; import javax.swing.*; import javax.swing.border.*;
public class SimpBorders extends JFrame{
SimpBorders(){
super(" Простые рамки"); setLayout(new FlowLayout());
JButton l1 = new JButton(" EmptyBorder() "); l1.setBackground(Color.white);
11. setBorder(BorderFactory.createEmptyBorder());
JLabel l2 = new JLabel(" LineBorder(Color.blue, 3) ");
12. setBorder(BorderFactory.createLineBorder(Color.blue, 3));
JLabel l3 = new JLabel(" BevelBorder(BevelBorder.RAISED) ");
13. setBorder(BorderFactory.createBevelBorder(BevelBorder.RAISED));
JLabel l4 = new JLabel(" BevelBorder(BevelBorder.LOWERED) ");
14. setBorder(BorderFactory.createBevelBorder(BevelBorder.LOWERED));
JLabel l5 = new JLabel(" Объемная двухцветная рамка ");
15. setBorder(BorderFactory.createBevelBorder(BevelBorder.RAISED,
Color.black, Color.white, Color.black, Color.white));
JLabel l6 = new JLabel(" EtchedBorder() ");
l6.setBorder(BorderFactory.createEtchedBorder());
add(l1); add(l2); add(l3); add(l4); add(l5); add(l6);
setSize(400, 400);
setDefaultCloseOperation(EXIT ON CLOSE); setVisible(true);
public static void main(String[] args){ new SimpBorders();
}
}
Рис. 16.1. Простые рамки |
Пустая рамка
Класс EmptyBorder представляет самую простую рамку. Это пустое пространство, окружающее компонент, как показано на рис. 16.1, сверху слева. Конструкторы класса
EmptyBorder(Insets);
EmptyBorder(int top, int left, int bottom, int right);
задают толщину рамки.
Статический метод createEmptyBorder( ) класса BorderFactory создает пустую рамку с нулевыми размерами, а статический метод
createEmptyBorder(int top, int left, int bottom, int right);
рамку с заданными размерами.
Рамка невидима- метод isBorderOpaque() возвращает false, метод paintBorder() не вы
черчивает ничего. Метод getBorderInsets () без аргументов возвращает размеры рамки в виде экземпляра класса Insets.
Употребление пустой невидимой рамки сводится к определению экземпляра класса
EmptyBorder и установке его в компонент методом setBorder (Border) класса JComponent.
Прямолинейная рамка