- PVSM.RU - https://www.pvsm.ru -

Citrus: Набор стилей для AvaloniaUI

citrus avalonia

В комментариях к новостям об изменениях и улучшениях в новых версиях кроссплатформенного GUI-фреймворка AvaloniaUI [1] довольно часто можно увидеть критику [2] тем оформления, используемых по умолчанию. Дело в том, что данные темы были созданы на основе Metro — художественного стиля оформления графического интерфейса, используемого в Windows 8 и Windows 8.1. Данный стиль обрёл как поклонников, так и противников. Темы оформления MahApps.Metro [3] для WPF по-прежнему остаются одними из наиболее популярных, имея более 6 с половиной тысяч звёзд на GitHub [4], догоняя MaterialDesignInXaml [5] с его 8-ю тысячами поклонников.

Поскольку в Avalonia тема оформления является обособленным компонентом и может быть совершенно безболезненно заменена на любую другую, имело смысл порадовать противников Metro и сделать альтернативный набор стилей. Стоит заметить, что силами сообщества уже была изготовлена alpha-версия темы Material [6] с переключателями и анимациями [7], поэтому в процессе было решено попробовать задизайнить велосипед в современном плоском стиле. В Avalonia 0.9.0 была добавлена поддержка сенсорного ввода [8], поэтому было бы неплохо улучшить UX для пользователей с сенсорными экранами. В результате получилась тема Citrus.Avalonia [9].

Начало работы

Для подключения тем оформления [10] в Avalonia обычно достаточно установить интересующий пакет NuGet и добавить одну или две строчки в секцию Styles файла App.xaml, если необходимо перекрасить всё приложение сразу. Если нужно изменить оформление только одного окна или другого элемента управления, добавьте теги <StyleInclude /> в секцию Window.Styles или UserControl.Styles соответственно. Для подключения темы Citrus.Avalonia установим необходимый пакет [11]:

dotnet add package Citrus.Avalonia --version 1.2.0

Затем, изменим файл App.xaml нашего приложения:

<Application xmlns="https://github.com/avaloniaui"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             x:Class="YourNamespace.App">
  <Application.Styles>
    <!-- Строчка ниже — единственное, что необходимо добавить
         для подключения нашей темы оформления. А вот всё, что
         было в секции Application.Styles раньше, лучше убрать! -->
    <StyleInclude Source="avares://Citrus.Avalonia/Citrus.xaml"/>

    <!-- Для использования других цветовых схем:
         1. Закомментируйте *все* блоки <StyleInclude /> в файле.
         2. Раскомментируйте *один* из блоков <StyleInclude /> ниже.  -->
    <!-- <StyleInclude Source="avares://Citrus.Avalonia/Sea.xaml"/> -->
    <!-- <StyleInclude Source="avares://Citrus.Avalonia/Rust.xaml"/> -->
    <!-- <StyleInclude Source="avares://Citrus.Avalonia/Candy.xaml"/> -->
    <!-- <StyleInclude Source="avares://Citrus.Avalonia/Magma.xaml"/> -->
  </Application.Styles>
</Application>

Использование новых стилей

После установки темы, стили всех элементов управления по умолчанию будут изменены. Дополнительно, станут доступны несколько дополнительных классов, например, для карточек. Примеры вёрстки можно найти в песочнице [12], в файле MainWindow.xaml [12]. Таким образом, рендер следующей XAML-разметки:

<Border Classes="Card">
  <StackPanel>
    <TextBlock Classes="Heading" Text="Heading class" />
    <TextBlock Classes="Caption" Text="Caption class" />
    <TextBlock Margin="0 5" 
               Text="Hi, I'm a tooltip! Please, hover over me."
               ToolTip.Tip="Hello, this is magic!" />
    <Grid ColumnDefinitions="*,*">
      <RadioButton Grid.Column="0" Content="Radio option" />
      <RadioButton Grid.Column="1" IsChecked="True" Content="Another one" />
    </Grid>
  </StackPanel>
</Border>

Будет иметь вид:

Citrus: Набор стилей для AvaloniaUI - 2

Цветовые палитры

В пакете Citrus.Avalonia доступно несколько цветовых схем: Citrus, Sea, Rust, Candy, Magma.

Citrus: Набор стилей для AvaloniaUI - 3

При желании Вы можете создавать свои собственные цветовые схемы, подключив свою цветовую палитру в секцию Application.Styles. В качестве основы можно взять файл темы CitrusPalette.xaml [13], изменить цвета на свой вкус и подключить его в проект, как AvaloniaResource. Между прочим, если добавить следующие строки в файл проекта (.csproj), то все xaml-файлы в папке с проектом будут встроены в сборку, как ресурсы Avalonia:

<ItemGroup>
  <Compile Update="***.xaml.cs">
    <DependentUpon>%(Filename)</DependentUpon>
  </Compile>
  <AvaloniaResource Include="***.xaml">
    <SubType>Designer</SubType>
  </AvaloniaResource>
</ItemGroup>

Для подключения собственной палитры измените App.xaml.cs следующим образом:

<Application xmlns="https://github.com/avaloniaui"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             x:Class="YourNamespace.App">
  <Application.Styles>
    <StyleInclude Source="avares://Citrus.Avalonia/Citrus.xaml"/>
    <!-- Добавьте собственную цветовую палитру после подключения темы. -->
    <StyleInclude Source="avares://YourNamespace/YourPalette.xaml"/>
  </Application.Styles>
</Application>

Динамическое переключение тем

В случае, если Вы хотите предложить пользователям своего приложения выбирать тему оформления, одним из вариантов реализации такого поведения может стать переопределение ресурсов корневого окна. Например, так:

var theme = "avares://Citrus.Avalonia/Citrus.xaml";
var self = new Uri("resm:Styles?assembly=Citrus.Avalonia.Sandbox");
var include = new StyleInclude(self) {
    Source = new Uri(theme)
};

// При изменении коллекции window.Styles все кисти,
// используемые внутри окна, на которое ссылается 
// переменная window, будут обновлены.
window.Styles.Add(include);

Такая логика может быть, например, инкапсулирована в сервис [14].

Задачи, которые можно порешать

В настоящее время стиль Metro, упомянутый в начале статьи, и подключённый в Avalonia по умолчанию, эволюционировал в систему Fluent Design [15] и теперь используется в продуктах Microsoft, включая операционную систему Windows 10 и приложениях Office для Android и iOS. Поэтому если Вы вдруг захотите сделать свою тему оформления для приложений Avalonia, можно начать эксперименты с портирования Fluent Design. Упражняться можно, например, на standalone каталоге [16] элементов управления.

Исходный код темы Citrus.Avalonia доступен на GitHub [9], PR с исправлениями визуальных багов категорически приветствуются. Поддержку от разработчиков Avalonia и всех сочувствующих можно получить в Telegram (ru) [17] и Gitter (en) [18], а документация по стилизации элементов управления доступна тут [19].

Автор: worldbeater

Источник [20]


Сайт-источник PVSM.RU: https://www.pvsm.ru

Путь до страницы источника: https://www.pvsm.ru/c-2/345575

Ссылки в тексте:

[1] AvaloniaUI: http://github.com/avaloniaui

[2] критику: https://habr.com/ru/post/349394

[3] MahApps.Metro: https://github.com/MahApps/MahApps.Metro

[4] 6 с половиной тысяч звёзд на GitHub: https://github.com/MahApps/MahApps.Metro/stargazers

[5] MaterialDesignInXaml: https://github.com/MaterialDesignInXAML/MaterialDesignInXamlToolkit

[6] Material: https://habr.com/ru/news/t/475256/

[7] анимациями: https://github.com/Roflyanochka/AvaloniaRipple

[8] поддержка сенсорного ввода: https://habr.com/ru/post/481102/

[9] Citrus.Avalonia: https://github.com/worldbeater/citrus.avalonia

[10] тем оформления: https://habr.com/ru/post/471046/

[11] пакет: https://www.nuget.org/packages/Citrus.Avalonia/

[12] песочнице: https://github.com/worldbeater/Citrus.Avalonia/blob/master/src/Citrus.Avalonia.Sandbox/MainWindow.xaml

[13] CitrusPalette.xaml: https://github.com/worldbeater/Citrus.Avalonia/blob/master/src/Citrus.Avalonia/Palette/CitrusPalette.xaml

[14] сервис: https://github.com/worldbeater/Citrus.Avalonia/blob/master/src/Citrus.Avalonia.Sandbox/StyleManager.cs

[15] Fluent Design: https://www.microsoft.com/design/fluent/#/

[16] standalone каталоге: https://github.com/AvaloniaUI/ControlCatalogStandalone

[17] Telegram (ru): http://t.me/avalonia

[18] Gitter (en): https://gitter.im/AvaloniaUI/Avalonia

[19] тут: https://avaloniaui.net/docs/styles/styles

[20] Источник: https://habr.com/ru/post/487000/?utm_campaign=487000&utm_source=habrahabr&utm_medium=rss