Anchor Docking Step by step example/ru

From Free Pascal wiki

English (en) русский (ru)

Anchor Docking : Пошаговый пример

Warning-icon.png

Предупреждение: ЭТОТ ПРИМЕР РАБОТАЕТ НЕ НА 100%, КАК БЫЛО ЗАДУМАНО. См. раздел Отладка для получения дополнительной информации.

У нас теперь есть мануал по anchor docking ... но я знаю, что люди учатся на методом тыка, а не посредством чтения ... итак, давайте делать это.

Сначала я создам новое приложение с нуля, а затем (надеюсь) мы увидим, сможем ли мы "преобразовать" в него существующее приложение (которое работало по старому способу выравнивания "Panel").

Для первого проекта я создам приложение, которое должно выглядеть так:

 +-----------------------------+
 | Main menu                   |
 +-----------------------------+
 | Toolbar (open, save etc.)   |
 +-----+-----------------------+
 | __= |                       |
 |     |                       |
 |  T  |   Main Application    |
 |  o  |                       | 
 |  o  |                       |
 |  l  +-----------------------+
 |  s  |   Output Messages     |
 +-----+-----------------------+

С панелью инструментов (Toolbar), инструментами (Tools) (несколько страниц), «Вывода сообщений» ( Output Messages) все части становятся «пристыковываемыми» (dockable). Поскольку механизм "drag-and-drop" еще не реализован, я не собираюсь пытаться добавить функциональность для перемещения частей. (Компиляция примера показывает, как это можно сделать) ... Этот проект будет лишь демонстрировать состояние «закреплено» или «не закреплено» для каждой из этих частей. (Этот проект может быть выполнен только с панелями.)

Шаг 1: Создание главной страницы

По сути, мы просто создадим новую форму, добавим в форму главное меню, а затем добавим в форму dockmanager. Я также добавляю stringgrid, чтобы показать, как она будет выглядеть.

  • Создайте новый проект
  • В Lazarus перейдите в File -> New ... -> Выберите "Application"
  • Первая форма (unit1.pas) будет частью "Main Application".
    • Перетащите компонент TMainMenu на форму.
      • Дважды щелкните компонент TMainMenu и создайте:
        • Main - File
        • FileSub - Exit
        • Main - Windows
        • WindowsSub - Dock/Undock Active Window (Пристыковать/Отстыковать активное окно) (добавьте шоткат к F11 - чтобы он был у нас)
        • WindowsSub - Save Window Positions (Сохранить позиции окна)
    • Создайте событие «OnCreate» для формы
      • Выберите форму в конструкторе форм
      • В инспекторе объектов перейдите на вкладку "events" (события) и дважды щелкните событие «OnCreate»
    • Создайте диспетчер стыковки
      • Добавьте этот код в событие OnCreate: `DockingManager:=TLazDockingManager.Create(Self);`
      • Добавьте переменную dockmanager к классу основной формы.
        • Нажмите Ctrl+ Shift+ (это приведет вас к определению события OnCreate в классе формы.)
        • Добавьте этот код в определение класса раздела public: `DockingManager: TLazDockingManager; `
    • Добавьте модуль стыковки и XMLPropStorage в раздел uses,
      • Прокрутите редактор кода до раздела uses
      • Добавьте `, LDockCtrl, XMLPropStorage` в раздел uses
    • Теперь мы просто добавим материал, чтобы он выглядел как приложение
      • Добавьте компонент StringGrid
        • Сделайте Align = Client в инспекторе объектов

Шаг 2: Создание своей панели инструментов

Я не собираюсь притворяться, что знаю, как создать правильную панель инструментов ... аля excel или что-то в стиле Офиса (прим.перев.: очевидно, имеется ввиду M$Office). Поэтому я просто создам форму со speedbutton'ами, которые выровнены по левому краю, и добавлю к ней несколько значков. Также добавьте к нему элемент управления док-станцией.

  • Создайте новую форму (File -> New Form)
    • Измените ее размер так, чтобы она выглядела «реалистично» по размеру. Высота - 61.
    • Добавьте к ней несколько кнопок загрузки/сохранения (добавьте несколько значков, если хотите) и Align = Left для них. Я добавил speedbuttons Load и Save, получил несколько глифов из Lazarus/images/menu. В моем другом проекте я добавил новую панель и поместил туда combobox. Делай что хочешь!
    • Добавьте панель управления.
      • В событие OnCreate добавьте:
     ControlDocker1:=TLazControlDocker.Create(Self);
     ControlDocker1.Name:='ToolbarForm';
     ControlDocker1.Manager:=Form1.DockingManager;
    • Добавьте соответствующие модули в раздел uses. (unit1, LDockCtrl)
    • Добавьте переменную в раздел public определения класса формы: ControlDocker1: TLazControlDocker;

Шаг 3: Наши страницы инструментов

Мы просто создадим 2 разные формы, которые узнаваемо отличаются друг от друга. И добавьте к нему элемент управления док-станцией. Сделайте следующее дважды:

  • Создайте новую форму (File -> New Form)
    • Измените ее размер, чтобы она выглядела «реалистично» по размеру. (Я только что сделал это около 150 px в ширину)
    • Обозначьте ее. (Я помещаю на нее label, где пишу "окно инструментов" 1 и 2).
    • Добавьте панель управления.
      • В событии OnCreate добавьте:
 
     ControlDocker1:=TLazControlDocker.Create(Self);
     ControlDocker1.Name:='Toolwindow1Form';  // (или 2 для второго)
     ControlDocker1.Manager:=Form1.DockingManager;
    • Добавьте соответствующие модули в разделе uses(unit1, LDockCtrl)
    • Добавьте переменную в разделе public определния класса формы: ControlDocker1: TLazControlDocker;

Шаг 4: Наше Окно Сообщений

Просто наша последняя форма ... Форма вывода. Выполните те же действия, что и раньше ...

  • Создайте новую форму (File -> New Form)
    • Измените ее размер, чтобы она выглядела "реалистично" по размеру. (Я только что сделал его около 100 px высотой и довольно широким)
    • Добавьте компонент memo, и выровняйте align = client
    • Добавьте control docker
      • В событии OnCreate добавьте:
     ControlDocker1:=TLazControlDocker.Create(Self);
     ControlDocker1.Name:='OutputForm';  // (или 2 для второго)
     ControlDocker1.Manager:=Form1.DockingManager;
    • Добавьте соответствующие модули в разделе uses(unit1, LDockCtrl)
    • Добавьте переменную в разделе public определния класса формы: ControlDocker1: TLazControlDocker;

Шаг 5: Собираем все вместе

Теперь мы просто добавим все вместе в основную форму ... и посмотрим, что из этого получится.

  • Добавьте все модули в раздел об использовании вашего основного модуля. (unit2, unit3, unit4, unit5)
  • Далее мы хотим добавить это в диспетчер стыковки ... но проблема в том, что формы еще не созданы в событии "OnCreate" основной формы. Итак, я перенесу «присвоение» свойств окнам пристыковки на событие «OnActivate» и просто установлю флаг, что это было сделано (чтобы он не делал это снова)
  • Итак: добавьте переменную Initialized в класс form1: Initialized: boolean;
  • В OnCreate мы установим ее значение в «False», а затем установим в «True» во время метода OnActivate.
  • Текущий метод «OnActivate».
procedure TForm1.FormActivate(Sender: TObject);
begin
  if initialized then exit;
  Initialized := true;
  // Устанавливаем панель инструментов вверху
  DockingManager.Manager.InsertControl(Form2,alTop,Form1);
  
  // Устанавливаем окно инструментов слева
  DockingManager.Manager.InsertControl(Form3,alLeft,Form1);
  
  // Устанавливаем второе окно инструментов ВНУТРИ первого
  DockingManager.Manager.InsertControl(Form4,alClient,Form3);
  
  // Устанавливаем второй элемент управления сообщениями снизу
  DockingManager.Manager.InsertControl(Form5,alBottom,Form1);
end;

Отладка

Это не сработало на 100%, как ожидалось.

Вещи, которые заработали, как ожидалось:

  1. Панель инструментов выглядела правильно и потрясающе
  2. Ширина окна инструмента была ожидаемой

Вещи, которые не сработали должным образом:

  1. Второе окно инструментов не работало должным образом, там был page control, но вторая страница не была назначена, а первой странице было назначено ВТОРОЕ окно инструментов
  2. Главное меню отсутствовало
  3. Memo исчезло ... хотя форма Form5 была там (может, нет? "title" не прочитан "Form5")
  4. Form5 занял все пространство, предназначенное для основного приложения. Возможно, исправит ситуацию добавление ограничений в главное окно.