AWT (Abstract Window Toolkit)

Материал из Национальной библиотеки им. Н. Э. Баумана
Последнее изменение этой страницы: 16:35, 5 января 2018.
AWT (Abstract Window Toolkit)
Easy Java AWT example.jpg
Разработчики: Sun Microsystems
Выпущена: 1995; 24 years ago (1995)
Написана на: Java
Платформа: мультиплатформенный
Тип ПО: GUI
Веб-сайт {{#property:P856}}

Abstract Window Toolkit (AWT) — это исходная платформо-независимая оконная библиотека графического интерфейса (Widget toolkit) языка Java. Сейчас AWT является частью Java Foundation Classes (JFC) — стандартного API для реализации графического интерфейса в Java-программе.

Также AWT является стандартной библиотекой GUI для некоторых профилей Java ME. Например, профили Connected Device Configuration требуют от среды исполнения Java на мобильных телефонах поддержки AWT.

История

Когда Sun Microsystems впервые выпустила Java в 1995 году, виджеты AWT предоставляли тонкий уровень абстракции над основным родным пользовательским интерфейсом. Например, создание флажка AWT заставляет AWT напрямую вызвать более низкоуровневую нативную подпрограмму, которая и создает флажок. Однако, флажок (check box) на Microsoft Windows это не совсем то же, как флажок на Mac OS или на различных видах Unix. Некоторые разработчики предпочитают эту модель, поскольку она обеспечивает высокую степень соответствия основному оконному инструментарию и беспрепятственную интеграцию с родными приложениями. Другими словами, GUI программа, написанная с использованием AWT, выглядит как родное приложение Microsoft Windows, будучи запущенной на Windows, и в то же время как родное приложение Apple Macintosh, будучи запущенным на Mac, и т. д.. Однако, некоторым разработчикам не нравится эта модель, потому что они предпочитают, чтобы их приложения выглядели одинаково на всех платформах.

В Java Platform, Standard Edition 1.2 виджеты AWT были в значительной степени заменены аналогичными из Swing. В дополнение к предоставлению более богатого набора элементов интерфейса пользователя, Swing рисует свои собственные виджеты (с помощью Java 2D для вызова низкоуровневых подпрограмм местной графической подсистемы), вместо того чтобы полагаться на высоком уровне модуля пользовательского интерфейса операционной системы. Swing обеспечивает возможность использования либо системного «look and feel», который использует родной «look and feel» платформы, либо кросс-платформенный внешний вид («Java Look and Feel»), который выглядят одинаково на всех платформах. Тем не менее, Swing использует AWT для взаимодействия с родной оконной системой[1].

Архитектура

AWT предоставляет два уровня API:

  • Общий интерфейс между Java и родной системой, используемый для управления окнами, события, менеджеры компоновки. Этот API является основой программирования Java GUI и используется также Swing и Java 2D. Он содержит:
    • Интерфейс между родной оконной системой и Java приложением;
    • Ядро обработчика событий интерфейса;
    • Некоторые менеджеры компоновки;
    • Интерфейс к устройствам ввода, таким как мышь и клавиатура;
    • Java пакет для использования с буфером обмена и Drag and Drop.
  • Базовый набор виджетов графического интерфейса, таких как кнопки, текстовые поля (text box) и меню. Она также предоставляет AWT Native Interface, который позволяет библиотекам в нативном коде рисовать непосредственно на Canvas.

AWT также предоставляет приложениям некоторую высокоуровневую функциональность:

  • Доступ к области уведомлений на поддерживаемых системах;
  • Возможность запуска некоторых десктопных приложений, таких как веб-браузеры и почтовые клиенты из Java-приложения[2].

Ни AWT, ни Swing не являются по своей природе потокобезопасными. Таким образом, код, обновляющий GUI, или processes events должны выполняться в Event dispatching thread. Невыполнение этого требования может привести к взаимной блокировке или состязанию. Для решения этой проблемы служебный класс SwingWorker позволяет приложениям выполнять «тяжёлые» обработчики интерфейсных событий в потоке обработки событий.

Смешивание компонентов AWT и Swing

Начиная с Java 6#Java SE 6 Update 10 смешивание компонентов Swing и основных виджетов AWT часто приводило к нежелательным побочным эффектам, с появлением AWT виджетов над виджетами Swing, независимо от их определенного порядка наложения. Эта проблема объясняется тем, что архитектура рендеринга двух widget toolkits очень разная, несмотря на заимствование Swing’ом тяжеловесных контейнеров верхнего уровня из AWT. Начиная с Java 6#Java SE 6 Update 12, стало возможно смешивать виджеты Swing and AWT без проблем с порядком наложения.

Реализация

Так как AWT является мостом к нижележащему нативному пользовательскому интерфейсу, его реализация на новой операционной системе может быть большой работой, главным образом для набора виджетов, которые требуют разработки с нуля нативных peers для каждого из виджетов AWT.

Одновременно с разработкой Java начал разрабатываться проект Caciocavallo. Его целью является предоставление Java API, основанных на OpenJDK для облегчения написания реализаций AWT для новых операционных систем. Для построения интерфейса используется Java2D. Все необходимые модификации включены в JDK начиная с версии OpenJDK 7.

Примечания

  1. Википедия [Электронный ресурс]: Abstract Window Toolkit — материал из Википедии — свободной энциклопедии: Версия 79094304, сохранённая в 14:23 UTC 20 июня 2016 / Авторы Википедии // Википедия, свободная энциклопедия. — Электрон. дан. — Сан-Франциско: Фонд Викимедиа, 2016. — Режим доступа: https://ru.wikipedia.org/wiki/Abstract_Window_Toolkit
  2. FINAL PROPOSAL: Portable GUI backends [Электронный ресурс] / Дата обращения: 31.10.2016. — Режим доступа: http://mail.openjdk.java.net/pipermail/challenge-discuss/2008-March/000082.html