то вы гарантируете, что при переопределении размеров формы данная кнопка будет сохранять свое положение относительно правого края формы.
Свойство Dock
Другой особенностью программирования Windows Forms является возможность задать
Таблица 21.14. Значения DockStyle
Значение | Описание |
---|---|
Bottom | Нижний край элемента управление стыкуется с нижним краем контейнерного элемента управления |
Fill | Все края элемента управления стыкуются со всеми краями контейнерного элемента управления, и соответствующим образом изменяется размер |
Left | Левый край элемента управления стыкуется с левым краем контейнерного элемента управления |
None | Элемент управления не стыкуется с краем контейнерного элемента управления |
Right | Правый край элемента управления стыкуется с правым краем контейнерного элемента управления |
Top | Верхний край элемента управления стыкуется с верхним краем контейнерного элемента управления |
Например, если вы хотите, чтобы данный элемент всегда располагался по левому краю формы, вы должны написать следующее.
// Этот элемент всегда размещается по левому краю формы,
// независимо от текущих размеров формы.
myButton.Dock = DockStyle.Left;
Чтобы понять, во что "выливается" установка свойств Anchor и Dock, рассмотрите проект AnchoringControls, который содержится в загружаемом файле примеров для этой книги. После компоновки и запуска этого приложения вы сможете использовать его систему меню для установки различных значений AnchorStyles и DockStyle, чтобы наблюдать изменения, происходящие при этом в поведении типа Button (рис. 21.37).
Не забудьте переопределить размеры формы при изменении свойства Anchor, чтобы выяснить, как на это отвечает Button.
Исходный код. Проект AnchoringControls размещен в подкаталоге, соответствующем главе 21,
Рис. 21.37. Приложение AnchoringControls
Табличное и потоковое размещение элементов
В .NET 2.0 предлагается еще один способ управления размещением элементов управления в форме – с помощью одного из двух администраторов размещения. Типы TableLayoutPanel и FlowLayoutPanel могут использоваться в области клиента формы с целью управления размещением внутренних элементов управления. Предположим, например, что в окне проектирования формы вы поместили в форму новый элемент FlowLayoutPanel и настроили его на стыковку со всеми краями родительской формы (рис. 21.38).
Рис. 21.38. Стыковка FlowLayoutPanel в форме
В режиме проектирования формы добавьте в FlowLayoutPanel десять новых типов Button. Если теперь выполнить приложение, вы заметите, что ваши десять кнопок автоматически распределятся в форме, и это очень напоминает стандартный HTML.
С другой стороны, если вы создаете форму, содержащую TableLayoutPanel, вы можете построить пользовательский интерфейс, который будет поделен на "ячейки" (рис. 21.39).
Рис. 21.39. Тип TableLayoutPanel
Если вы выберете пункт Edit Rows and Columns (Редактировать строки и столбцы) из меню встроенного редактора элемента в окне проектирования формы (как показано на рис. 21.39), то вы сможете изменить формат TableLayoutPanel для каждой ячейки (рис. 21.40).
Рис. 21.40. Настройка ячеек типа TableLayoutPanel
Правда, единственной возможностью увидеть результат такой настройки типа TableLayoutPanel является проверка вручную. Предлагаем заинтересованным читателям выполнить это задание самостоятельно.
Резюме
Эта глава расширяет ваше понимание пространства имен Windows Forms путем рассмотрения возможностей элементов графического интерфейса пользователя, от самых простых (таких как Label) до "экзотических" (таких как TreeView). После изучения множества типов, соответствующих элементам управления, была рассмотрена задача построения пользовательских элементов управления, включая их интеграцию в среду проектирования.