Библиотека визуальных компонентов - Visual Component Library

Библиотека визуальных компонентов (VCL)
Автор (ы) оригинала Borland
Разработчики) Embarcadero Technologies
Первый выпуск 1995 ; 26 лет назад ( 1995 )
Операционная система Кроссплатформенность ( Microsoft Windows , macOS , iOS , Android )
Тип GUI
Лицензия Коммерческий
Веб-сайт www .embarcadero .com / kr / products / rad-studio
docwiki .embarcadero .com / RADStudio / XE6 / en / VCL _Обзор

Библиотека визуальных компонентов ( VCL ) - это объектно-ориентированная среда на основе визуальных компонентов для разработки пользовательского интерфейса приложений Microsoft Windows . Он написан на Object Pascal .

История

VCL был разработан Borland для использования в его инструментах Delphi и C ++ Builder RAD и тесно интегрирован с ними .

В 1995 году Borland выпустила Delphi, свой первый выпуск IDE и языка Object Pascal . До этого момента Turbo Pascal от Borland для DOS и Windows был в основном процедурным языком с минимальными объектно-ориентированными функциями и построением фреймворков пользовательского интерфейса с языком, необходимым с использованием таких фреймворков, как Turbo Vision и Object Windows Library . OWL, структура, аналогичная MFC , требовала написания кода для создания объектов пользовательского интерфейса.

Ключевой целью VCL в сочетании с языком Delphi было изменение требований к созданию пользовательского интерфейса. (Для контекста, вариант Pascal для Delphi имел ряд инновационных объектно-ориентированных функций, таких как свойства и информация о типах среды выполнения, вдохновленных Modula и Smalltalk.) В то время большая часть работы над кодом пользовательского интерфейса требовала создания классов, унаследованных от других классов, а настраиваемые объекты часто нельзя было повторно использовать (например, кнопку, которая выполняет определенное действие, нельзя повторно использовать в другом приложении). Код пользовательского интерфейса также был сложным, заставляя программиста понимать и использовать Windows API, управлять ресурсами GDI и т. д. Наконец, визуальный пользовательский интерфейс, возможно, должен быть разработан визуально, и все же большинство инструментов для этого - в то время, в основном Visual Basic - делали это с точки зрения вывода кода дизайнером, создавая хрупкую, нередактируемую вручную ситуацию - проблема, которая все еще сохраняется сегодня во многих фреймворках пользовательского интерфейса, особенно основанных на C ++, таких как Qt.

Комбинация языка Delphi и инфраструктуры VCL, написанной на этом языке, решает следующие проблемы:

  • Фреймворк потоковой передачи, позволяющий передавать объект и подобъекты в текстовый или двоичный формат - TComponent, корневой класс фреймворка VCL.
  • Конструктор форм, сохраняющий в потоке описание объектов, а не код, необходимый для их создания, с объектами, способными к самосозданию при потоковой передаче описания обратно в
  • Языковые функции, которые позволяли настраивать экземпляры класса без создания подклассов двумя способами: во-первых, с помощью свойств, позволяющих экземплярам объекта иметь собственные поля (например, заголовок), легко изменяемые с помощью потоковой передачи; во-вторых, позволяя другим объектам обрабатывать события - указатели методов, вызываемые в определенных местах кода; то есть указатели методов были прикреплены к экземпляру объекта. Другими словами, это создает «настраиваемое поведение посредством делегирования вместо наследования».
  • Элементы управления, содержащие собственные элементы управления Windows, в структуре, которая управляет ресурсами.

Комбинация всего этого привела к визуальному дизайнеру, который транслировал описание; форма (окно), построенная на основе этого описания, включая создание всех других компонентов в этой форме; и код, написанный в одном месте (методы в форме), которые могут быть вызваны элементами пользовательского интерфейса в ответ на определенные действия, такие как нажатие кнопки, вызывающее обработчик событий OnClick, реализованный в коде формы. В то время это было революционно, а сегодня это подход, используемый несколькими другими фреймворками, такими как WinForms и Cocoa.

Это также позволило легко писать новые компоненты - новые визуальные или невизуальные классы. VCL основан на Windows, и его реализации общих элементов управления являются оболочками Windows API, поэтому они близки к основам и являются полностью нативными. Новые элементы управления могут быть реализованы с нуля или могут использовать существующие элементы управления Windows.

С выпуском C ++ Builder компилятор Delphi мог генерировать файлы заголовков C ++ для скомпилированных модулей языка Delphi, и поэтому гибкость потоковой, визуально разработанной инфраструктуры пользовательского интерфейса стала доступной для C ++. Фактически компоненты VCL могут быть написаны на C ++, но в конечном итоге унаследованы от предков Delphi, поскольку компилятор и компоновщик C ++ Builder могут использовать объектные и заголовочные файлы, созданные Delphi. Это был один из первых примеров межъязыковой совместимости, невиданный до .Net.

Сегодня VCL включает несколько сотен визуальных и невизуальных компонентов, которые можно использовать как на языках Delphi, так и на C ++.

Технология

VCL формирует иерархию классов с общим предком , классом TComponent (который наследуется от TObject, корневого класса в Delphi Object Pascal ). Это общий подход, используемый языком программирования Java , Smalltalk , C # и многими другими объектно-ориентированными языками программирования.

Компоненты VCL охватывают элементы управления Windows, такие как окна ( класс TForm ), элементы управления (например, TButton, TCheckBox, классы TLabel), а также доступ к базе данных (например, компоненты ADO или IBX) или подключения к Интернету ( компоненты Indy ). Компонентный подход позволяет программистам расширять VCL множеством визуальных и невизуальных дополнительных компонентов. Существует большое количество бесплатных и коммерческих пакетов компонентов. Среди них JEDI , TMS , Developer Express , Mitov Software , Raize Software , TurboPower , IOComp , SDL , DA-SOFT Technologies и многие другие.

Хотя не все компоненты VCL являются потокобезопасными , VCL также поддерживает многопоточность . Одним из примеров является встроенная поддержка многопоточности библиотеки OpenWire VCL.

VCL обеспечивает встроенную поддержку модели PME (свойства, методы и события) на уровне .NET .

Большая часть дизайна .NET , особенно WinForms, смоделирована по образцу VCL. Один из главных архитекторов первых версий Delphi, Андерс Хейлсберг , был нанят Microsoft и стал одним из главных архитекторов .NET. Это стало предметом судебного процесса: в то время (1996 г.) «Borland утверждала, что Microsoft наняла 34 сотрудника Borland за последние 30 месяцев, чтобы украсть коммерческую тайну Borland. Borland также утверждал, что Microsoft предлагала и поставляла Borland дорогие приманки. рабочих. В двух случаях были задействованы льготы на сумму, превышающую 1 миллион долларов ". Согласно delphi.about.com, в случае с Андерсом бонус составил три миллиона долларов. Многие разработчики Delphi находят C # довольно знакомым из-за сходства дизайна.

Связанные фреймворки

Кроссплатформенный эквивалент VCL, названный CLX (Component Library for Cross Platform), позже был разработан для использования в Delphi , C ++ Builder и Kylix в 2000–2001 годах. Однако от него отказались.

Вторая кроссплатформенная среда, FireMonkey , была интегрирована в Delphi и C ++ Builder XE2 в 2011 году. FireMonkey - это векторная WPF-подобная платформа для пользовательского интерфейса в Windows, OSX, iOS и Android.

У проекта Lazarus есть переносимый (* nix, OS / X, Win32 / 64 + wince) эквивалент под названием LCL , который уже работал, когда появились Kylix и CLX. Проект продолжал развиваться и игнорировал Kylix (а позже и FMX).

OpenOffice.org и, следовательно, LibreOffice содержат несвязанную графическую библиотеку под названием Visual Class Library (VCL).

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

использованная литература

внешние ссылки