Предыдущая лекция |   | Следующая лекция :----------------:|:----------:|:----------------: [Поиск, сортировка](./wpf_search_sort.md) | [Содержание](../readme.md#тема-8-оконные-приложения) | [Стили, триггеры и темы](./wpf_style.md) # Вывод данных согласно макета (ListBox, Image). В реальных проектах **DataGrid** используется редко. Обычно используется компонент **ListBox**. Пример из задания одного из прошедших демо-экзаменов: ![](../img/product_list_layout.jpg) Вверху уже знакомый нам **WrapPanel**, а вот основная информация выводится в виде блоков Для создания такого макета используется элемент **ListBox** В разметке вместо **DataGrid** вставляем **ListBox**: ```xml ``` Внутри него вставляем шаблон для элемента списка (*ListBox.ItemTemplate*): пока у нас только прямоугольная рамка со скруглёнными углами (в этом макете вроде скрулять не надо, возможно осталось от другого шаблона) ```xml ``` Внутри макета вставляем **Grid** из трёх колонок: для картинки, основного содержимого и ещё чего-нибудь. ```xml ``` **В первой** колонке выводим изображение: ```xml ``` Обратите внимание, в классе **Cat** нет поля *ImageBitmap*. Для получения картинки я использую вычисляемое свойство *ImageBitmap* - в геттере проверяю есть ли такая картинка, т.к. наличие названия в модели не означает наличие файла на диске. Если файла нет, то возвращается `null` и рисуется картинка по-умолчанию, которую надо зашить в ресурсы приложения. >В реальных проектах, конечно, изображения получают с сервера, но на демо-экзамене на реализацию этого функционала времени нет, поэтому картинки кладутся в каталог с проектом (не в ресурсы, а в каталог с исполняемым файлом). Нам нужно найти картинки для нашей предметной области и добавить в поле _photo_ Добавьте в класс **Cat** вычисляемое свойство: ```cs public class Cat { public Uri? ImageBitmap { get { var imageName = Environment.CurrentDirectory + "/img/" + (photo ?? ""); return System.IO.File.Exists(imageName) ? new Uri(imageName) : null; } } } ``` Изображение по-умолчанию задается в ресурсах окна ```xml ``` тут, как раз, указывается путь к изображению в ресурсах (в моём случае в приложении создан каталог `Images`) **Во второй** колонке вывожу основную информацию о кошке: _кличку_ и _породу_. Так как данные выводятся в несколько строк, то заворачиваю их в **StackPanel** (тут можно использовать и **Grid**, но их и так уже много в разметке) ```xml ``` **В третьей** колонке выводим возраст ```xml ``` На данный момент приложение выглядит примерно так ![](../img/cs005.png) Видно, что размер элемента зависит от содержимого. Чтобы это исправить нужно добавить в **ListBox** стиль для элемента контейнера, в котором задать горизонтальное выравнивание по ширине: ```xml ... ``` Теперь окно должно выглядеть как положено: ![](../img/cs006.png) # Вывод данных "плиткой" Такое задание было на одном из прошлых чемпионатов, вполне вероятно что появится и на демо-экзамене. Компоненты **ListBox** и **ListView** по умолчанию инкапсулируют все элементы списка в специальную панель **VirtualizingStackPanel**, которая располагает все элементы по вертикали. Но с помощью свойства **ItemsPanel** можно переопределить панель элементов внутри списка. Мы будем использовать уже знакомую вам **WrapPanel**: ```xml ``` >Атрибут *HorizontalAlignment* используем, чтобы "плитки" центрировались. ![](../img/01072.png) Как видим, элементы отображаются горизонтальным списком, но нет переноса. Для включения переноса элементов нужно в **ListBox** отключить горизонтальный скролл, добавив атрибут `ScrollViewer.HorizontalScrollBarVisibility="Disabled"`: ![](../img/01073.png) Свойство *ItemContainerStyle* уже не нужно и его можно убрать. Размеры наших элементов по-прежнему зависят от содержимого - тут надо править шаблон (ширина элемента **Grid** в **DataTemplate**). ![](../img/listbox001.png) Итоговая разметка для вывода "плиткой" должна выглядеть примерно так: ```xml ... ``` Предыдущая лекция |   | Следующая лекция :----------------:|:----------:|:----------------: [Поиск, сортировка](./wpf_search_sort.md) | [Содержание](../readme.md#тема-8-оконные-приложения) | [Стили, триггеры и темы](./wpf_style.md)