Многодокументный интерфейс - Multiple-document interface

Пример макета многодокументного интерфейса

А многодокументный интерфейс (MDI) это графический интерфейс пользователя в котором несколько окон находятся под одним родительским окном. Такие системы часто позволяют дочерним окнам встраивать в них и другие окна, создавая сложные вложенные иерархии. Это контрастирует с однодокументные интерфейсы (SDI), где все окна независимы друг от друга.

Сравнение с однодокументным интерфейсом

в удобство использования сообщества, было много споров о том, что предпочтительнее - многодокументный или однодокументный интерфейс. Компании-разработчики программного обеспечения использовали оба интерфейса с неоднозначной реакцией. Например, Microsoft изменил свой Офис приложения из режима SDI в режим MDI, а затем обратно в режим SDI, хотя степень реализации варьируется от одного компонента к другому. SDI может быть более полезным в случаях, когда пользователи переключаются между отдельными приложениями чаще, чем между окнами одного приложения.

MDI может сбивать с толку, если в нем отсутствует информация об открытых в данный момент окнах. В приложениях MDI разработчик приложения должен предоставить способ переключения между документами или просмотра списка открытых окон, а пользователю, возможно, придется использовать меню для конкретного приложения («список окон» или что-то подобное) для переключения между открытыми документами. Это отличается от приложений SDI, в которых оконный менеджер панель задач или же диспетчер задач отображает открытые в данный момент окна. В последние годы для приложений MDI стало все более обычным использование «вкладок» для отображения окон, открытых в данный момент. Интерфейс, в котором вкладки используются для управления открытыми документами, называется "интерфейс документа с вкладками »(TDI). Другой вариант -« плиточный » панели или окна, которые упрощают предотвращение перекрытия содержимого.

Некоторые приложения позволяют пользователю переключаться между этими режимами по своему выбору, в зависимости от личных предпочтений или поставленной задачи.

Почти все графический интерфейс пользователя Наборы инструментов на сегодняшний день предоставляют по крайней мере одно решение для разработки ДИ. Заметным исключением было Какао API от Apple до появления групп окон с вкладками в MacOS High Sierra. В Ява Набор инструментов GUI, Качать, например, предоставляет класс javax.swing.JDesktopPane который служит контейнером для отдельных кадров (класс javax.swing.JInternalFrame). GTK отсутствует какая-либо стандартизированная поддержка MDI.

Преимущества

  • С многодокументными интерфейсами (а также интерфейсы документов с вкладками ), отдельную строку меню и / или панель инструментов распределяется между всеми дочерними окнами, уменьшая беспорядок и повышая эффективность использования экранного пространства. Этот аргумент менее актуален в операционной системе, в которой используется общая строка меню.
  • Дочерние окна приложения можно скрыть / отобразить / свернуть / развернуть в целом.
  • Для дочерних окон могут быть реализованы такие функции, как «Плитка» и «Каскад».
  • Авторы кроссплатформенных приложений могут предоставить своим пользователям согласованное поведение приложения на разных платформах.
  • Если в оконной среде и ОС отсутствует хорошее управление окнами, автор приложения может реализовать это самостоятельно.
  • Модульность: расширенный оконный менеджер можно обновить независимо от приложений.

Недостатки

  • Без окна фрейма MDI плавающие панели инструментов из одного приложения могут загромождать рабочее пространство других приложений, потенциально запутывая пользователей беспорядком интерфейсов.
  • Может быть сложно реализовать на настольных компьютерах с использованием нескольких мониторов, поскольку родительскому окну может потребоваться охватить два или более мониторов, скрывая разделы.
  • Виртуальные рабочие столы не могут быть охвачены дочерними элементами MDI. Однако в некоторых случаях это можно решить, запустив другое родительское окно; это имеет место в Опера и Хром, например, который позволяет перетаскивать вкладки / дочерние окна за пределы родительского окна для запуска собственного родительского окна. В других случаях каждое дочернее окно также является родительским окном, образуя новый «виртуальный» MDI. [1].
  • MDI может усложнить работу с несколькими приложениями одновременно, ограничивая способы, которыми окна из нескольких приложений могут быть расположены вместе, не загораживая друг друга.
  • Общее меню может измениться, что может запутать некоторых пользователей.
  • Дочерние окна MDI ведут себя иначе, чем в единый документ интерфейс приложения, требующие от пользователей изучения двух тонко разных концепций работы с окнами. Точно так же родительское окно MDI во многих отношениях ведет себя как рабочий стол, но имеет достаточно различий, чтобы сбить с толку некоторых пользователей.
  • Глубоко вложенные, ветвящиеся иерархии дочерних окон могут сбивать с толку.
  • Многие оконные менеджеры имеют встроенную поддержку для управления группами отдельных окон, которая, как правило, более гибкая, чем MDI, поскольку окна можно группировать и разгруппировывать произвольно. Типичная политика - автоматически группировать окна, принадлежащие одному приложению. Это, возможно, делает MDI избыточным, поскольку дает решение той же проблемы.
  • Элементы управления и горячие клавиши, изученные для приложения MDI, могут не применяться к другим, тогда как с расширенным оконным менеджером больше настроек поведения и пользовательских предпочтений совместно используются клиентскими приложениями в одной системе.

Примеры применения

  • Adobe Acrobat: MDI до версии 7.0 (только для Windows); SDI по умолчанию в версии 8.0 (настраивается на MDI); SDI только в 9.0; MDI (с интерфейсом с вкладками) в версии 2015.
  • Corel Wordperfect: MDI. Пользователь может открыть несколько экземпляров WP с одним документом в каждом, если на его компьютере установлено несколько версий WordPerfect. Последние версии поддерживают список открытых документов для данного окна в строке состояния в нижней части окна, обеспечивая вариант TDI.
  • EmEditor: Опции для SDI или MDI.
  • GIMP: SDI с плавающими окнами (MDI доступен как опция под названием «Однооконный режим», начиная с версии 2.8 [2] ).
  • GIMPshop: А вилка GIMP стремится быть больше похожим на Adobe Photoshop. Версия для Windows имеет ограниченный MDI.[3]
  • Хром: Комбинация MDI и TDI.
  • Internet Explorer 6: типичное приложение SDI
  • KWrite: Еще один текстовый редактор, предназначенный для Компиляция программного обеспечения KDE, с упрощенным SDI, но разделяющим многие функции Кейт через общий задний конец
  • Катя: Текстовый редактор, предназначенный для Компиляция программного обеспечения KDE, с расширенными функциями и сложным MDI
  • Макромедиа Студия для Windows: гибридный интерфейс; TDI, если окна документов не развернуты. (По умолчанию они развернуты.)
  • Майкрософт Эксель 2003: SDI, если вы запускаете новые экземпляры приложения, но MDI, если вы щелкаете меню «Файл? Новый» (но дочерние окна необязательно появляются на панели задач ОС). Только SDI по состоянию на 2013 год.
  • Microsoft Word 2003: MDI до Microsoft Office 97. После 2000 года у Word появился Множественный интерфейс Windows верхнего уровня, таким образом подвергая оболочке отдельные экземпляры SDI, в то время как операционная система распознает его как отдельный экземпляр приложения MDI. В Word 2000 это был единственный доступный интерфейс, но 2002 и более поздние версии предлагают MDI в качестве опции. Классы Microsoft Foundation (на котором в общих чертах основан Office) поддерживает эту метафору, начиная с версии 7.0, как новую функцию в Visual Studio 2002. Только SDI по состоянию на 2013 год.
  • Fire Fox: TDI по умолчанию, может быть SDI
  • Блокнот ++, PSPad, TextMate и многие другие текстовые редакторы: TDI
  • Опера: Комбинация MDI и TDI (настоящий интерфейс MDI с панелью вкладок для быстрого доступа).
  • Paint.NET: На основе эскизов, TDI
  • UltraEdit: Комбинация MDI и TDI (настоящий интерфейс MDI с панелью вкладок для быстрого доступа).
  • ВЕДИТ: Комбинация MDI и TDI (настоящий интерфейс MDI с панелью вкладок для быстрого доступа). Специальные «полноразмерные» окна действуют как развернутые окна, но позволяют одновременно использовать меньшие перекрывающиеся окна. Можно запустить несколько экземпляров Vedit, что позволяет использовать его как приложение SDI.
  • Visual Studio .NET: MDI или TDI с меню "Окно", но не оба одновременно
  • Visual Studio 6 среда разработки: типичный современный MDI
  • mIRC: MDI по умолчанию, также может работать в режиме SDI
  • Adobe Photoshop: MDI под MS Windows. В более новых версиях панели инструментов могут перемещаться за пределы окна фрейма. Дочерние окна могут находиться вне кадра, если они не свернуты или развернуты.

Интерфейс в стиле IDE

Графические компьютерные приложения с IDE -стильный интерфейс (IDE) - это те окна, дочерние окна которых находятся под одним родительским окном (обычно за исключением модальные окна ). Интерфейс в стиле IDE отличается от интерфейса для работы с несколькими документами (MDI), поскольку все дочерние окна в интерфейсе в стиле IDE расширены за счет дополнительных функций, которые обычно не доступны в приложениях MDI. По этой причине приложения в стиле IDE можно рассматривать как функциональную надмножество и потомков приложений MDI.

Примеры расширенной функциональности дочернего окна:

  • Закрепляемые дочерние окна
  • Складные дочерние окна
  • Интерфейс документа с вкладками для субпанелей
  • Независимые субпанели родительского окна
  • Разделители графического интерфейса для изменения размера субпанелей родительского окна
  • Упорство для оформления окон

Складные дочерние окна

Распространенным соглашением для дочерних окон в приложениях в стиле IDE является возможность сворачивать дочерние окна, когда они неактивны, или когда это указано пользователем. Свернутые дочерние окна будут соответствовать одной из четырех внешних границ родительского окна с какой-либо меткой или индикатором, позволяющим их снова развернуть.

Интерфейс документа с вкладками для вложенных панелей

В отличие от приложений (MDI), которые обычно допускают использование единственного интерфейса с вкладками для родительского окна, приложения с интерфейсом в стиле IDE позволяют использовать вкладки для организации одной или нескольких субпанелей родительского окна.

Примеры приложений в стиле IDE

Macintosh

Mac OS и ее графический интерфейс ориентированы на документы, а не на окна или приложения. Каждое окно документа - это объект, с которым может работать пользователь. Строка меню изменится, чтобы отразить приложение, которому принадлежит переднее окно. Окна приложений могут быть скрыты, и ими можно управлять как группой, и пользователь может переключаться между приложениями (то есть группами окон) или между отдельными окнами, автоматически скрывая палитры, и большинство программ будут продолжать работать даже без открытых окон. Действительно, до Mac OS X, было намеренно невозможно чередовать окна из нескольких приложений.

Несмотря на это, некоторые необычные приложения, нарушающие руководство по интерфейсу человека (особенно Фотошоп ) демонстрируют другое поведение.

Смотрите также

внешняя ссылка