Kevin Abstract
- 1 year ago
- 0
- 0
Abstract Window Toolkit (AWT) — это исходная платформо-независимая оконная библиотека графического интерфейса (Widget toolkit) языка Java . Сейчас AWT является частью Java Foundation Classes (JFC) — стандартного API для реализации графического интерфейса в Java-программе.
Также AWT является стандартной библиотекой GUI для некоторых профилей Java ME . Например, профили требуют от среды исполнения Java на мобильных телефонах поддержки AWT.
Когда Sun Microsystems впервые выпустила Java в 1995 году, виджеты AWT предоставляли тонкий уровень абстракции над основным родным пользовательским интерфейсом . Например, создание флажка AWT заставляет AWT напрямую вызвать более низкоуровневую нативную подпрограмму, которая и создает флажок. Однако, флажок (check box) на Microsoft Windows - это не совсем то же, что флажок на Mac OS или на различных видах Unix . Некоторые разработчики предпочитают эту модель, поскольку она обеспечивает высокую степень соответствия основному оконному инструментарию и беспрепятственную интеграцию с родными приложениями. Другими словами, GUI-программа, написанная с использованием AWT, выглядит как родное приложение Microsoft Windows, будучи запущенной на Windows, и в то же время - как родное приложение Apple Macintosh , будучи запущенной на Mac, и т. д. Однако, некоторым разработчикам не нравится эта модель, потому что они предпочитают, чтобы их приложения выглядели одинаково на всех платформах.
В J2SE 1.2 виджеты AWT были в значительной степени заменены аналогичными из Swing . В дополнение к предоставлению более богатого набора элементов интерфейса пользователя, Swing рисует свои собственные виджеты (с помощью Java 2D для вызова низкоуровневых подпрограмм местной графической подсистемы) вместо того, чтобы полагаться на высокоуровневый модуль пользовательского интерфейса операционной системы. Swing обеспечивает возможность использования либо системного , который использует родной «look and feel» платформы, либо кросс-платформенный внешний вид («Java Look and Feel»), который выглядят одинаково на всех платформах. Тем не менее, Swing использует AWT для взаимодействия с родной оконной системой.
AWT предоставляет два уровня API :
для использования с
буфером обмена
и
Drag and Drop
.
.
AWT также предоставляет приложениям некоторую высокоуровневую функциональность:
Ни AWT, ни Swing не являются по своей природе
потокобезопасными
. Таким образом, код, обновляющий GUI или обрабатывающий события, должен выполняться в
(
англ.
event dispatching thread
, EDT). Невыполнение этого требования может привести к
взаимной блокировке
или состязанию. Для решения этой проблемы служебный класс
позволяет приложениям выполнять «тяжёлые» обработчики интерфейсных событий в потоке обработки событий.
Начиная с смешивание компонентов Swing и основных виджетов AWT часто приводило к нежелательным побочным эффектам, с появлением AWT-виджетов над виджетами Swing, независимо от их определенного порядка наложения . Эта проблема объясняется тем, что архитектура рендеринга двух widget toolkits очень разная, несмотря на заимствование Swing’ом тяжеловесных контейнеров верхнего уровня из AWT .
Начиная с стало возможно смешивать виджеты Swing и AWT без проблем с порядком наложения.
Так как AWT является мостом к нижележащему нативному пользовательскому интерфейсу, его реализация на новой операционной системе может быть большой работой, главным образом для набора виджетов, которые требуют разработки с нуля нативных peers для каждого из виджетов AWT.
Одновременно с разработкой Java начал разрабатываться проект . Его целью является предоставление Java API, основанных на OpenJDK для облегчения написания реализаций AWT для новых операционных систем . Для построения интерфейса используется Java2D . Все необходимые модификации включены в JDK начиная с версии OpenJDK 7 .
(AWT
Javadoc
API documentation)