Хобрук: Ваш путь к мастерству в программировании

В чем смысл класса StatusBarItem в WPF?

Как класс StatusBarItem должен использоваться? Должен ли каждый элемент содержимого StatusBar быть обернут им?

Я не очень понимаю, как StatusBarItem влияет на макет StatusBar. Кажется, я могу использовать HorizontalAlignment в StatusBarItem, но не тогда, когда я помещаю элемент в StatusBar напрямую:

<StatusBar>
    <TextBlock HorizontalAlignment="Right" Text="Not right" />
    <StatusBarItem HorizontalAlignment="Center">
        <TextBlock Text="Center" />
    </StatusBarItem>
</StatusBar>

Также, если вы обернете Separator в StatusBarItem, Separator изменится на горизонтальное. Separators по умолчанию имеет вертикальное значение, когда помещается в StatusBar напрямую без оболочки StatusBarItem.


  • у меня была аналогичная проблема с использованием Separator с ToolBar stackoverflow.com/questions/1274370 20.01.2010
  • Не ответ, а ItemsControl, что означает, что вы можете привязать его к коллекции объектов и использовать DataTemplates, чтобы определить, как эти элементы отображаются в строке состояния. Вероятно, он предлагает лучшее поведение в StatusBar, чем стандартный ItemsControl. 20.01.2010

Ответы:


1

StatusBar есть ItemsControl. Все ItemsControl имеют класс контейнера. Для ListBoxes это ListBoxItem. Для StatusBar это StatusBarItem. Если вы явно не оберните свой элемент в StatusBarItem, он будет неявно заключен в один для вас.

Если вам нужно установить свойства контейнеров ItemsControl, вы можете использовать свойство ItemContainerStyle:

<StatusBar>
    <TextBlock>One</TextBlock>
    <TextBlock>Two</TextBlock>
    <TextBlock>Three</TextBlock>
    <StatusBar.ItemContainerStyle>
        <Style TargetType="StatusBarItem">
            <Setter Property="HorizontalAlignment" Value="Right"/>
        </Style>
    </StatusBar.ItemContainerStyle>
</StatusBar>

Наконец, обратите внимание, что StatusBar по умолчанию использует DockPanel для размещения своих дочерних элементов. Это может раздражать, когда вы делаете сложные макеты. См. мой пост в блоге здесь о том, как заменить его на Grid.

20.01.2010
  • Спасибо, что поделились записью в блоге! У меня сработало следующее <StatusBar.ItemsPanel> <ItemsPanelTemplate> <StackPanel Orientation="Horizontal"/> </ItemsPanelTemplate> </StatusBar.ItemsPanel> 20.01.2012
  • Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..