Как-то раз в одном чате прозвучала идея сравнить разные технологии для написания оконных приложений. В частности, под Windows. Используя средства языка C#. То есть, конечно, можно это сделать и с помощью C++, Python, Rust, JS и других языков, но мы же шарписты, нам интереснее именно то, что мы можем сами использовать, не меняя язык программирования.

Итак, оконные приложения на C#. Их можно написать, используя:

  • Windows Forms

  • WPF

  • WinUI

  • .NET MAUI

  • Avalonia

  • Uno Platform

Такое многообразие фреймворков обусловлено тем, что язык развивался, менялись подходы, совершенствовались технологии. А в какой-то момент к разработке подключились сторонние разработчики и к средствам Microsoft добавились Avalonia и Uno.

Таким образом, для того чтобы начать писать оконные приложения надо решить, используя какую технологию использовать. Но, кроме того, неплохо бы понимать, где будет приложение использоваться – только на Windows или есть необходимость в запуске на MacOS и Linux. А может быть еще и на IOS и Android?

В общем, в этой статье попробуем разобраться в возможностях этих фреймворков и сравним их. Сравнивать будем по таким критериям:

  • Платформы, в которых можно запустить приложение

  • Сложность разработки

  • Потребляемые ресурсы

  • Скорость запуска

Для корректности сравнения будем использовать одну логику для всех приложений. Более того, попытаемся сделать их максимально похожими друг на друга. 

Часть 1. Логика

Итак, чтобы не сравнивать пустые приложения без какой-либо функциональности, и при этом не перегружать излишним наполнением,   реализовал простейшую версию игры Крестики-Нолики. Логика самой игры простая: есть два игрока Х и О. Начинает игрок Х потом ходит О. Кто первым соберет три своих символа в ряд — выигрывает, если после последнего хода победителя нет, то ничья. Игра осуществляется с одного устройства, по очереди. 

Весь код логики практически один в один переходит из приложения в приложение, за исключением некоторых особенностей в разных фреймворках. Например, в Авалонии нет встроенного механизма отображения всплывающих окон (Message Box) и для того, чтобы он появился надо установить дополнительный пакет. Не сложно, но нюанс. В некоторых фреймворках нельзя напрямую посчитать кнопки из интерфейса и надо придумывать обходные пути.

Важно также отметить, что везде, кроме WinForms по-хорошему следует использовать паттерн MVVM, однако для простейшего приложения заморачиваться не стал и работает все напрямую.

Часть 2. Пользовательский интерфейс

Разработка UI в приложениях C# отличается не очень сильно друг от друга. Выделяется разве что WinForms, где элементы интерфейса размещаются обычно вручную в графическом редакторе, что в свою очередь весьма дружелюбно по отношению к людям без опыта. 

Еще можно размещать элементы вручную в WPF, однако рекомендуется все же выстраивать интерфейс вручную задавая параметры в коде страницы. 

Осложняет процесс разработки внешнего вида отсутствие интерактивного отображения получаемого результата в MAUI и WinUI – там посмотреть на результат можно только после сборки и запуска. Да, есть такая функция как Hot Reload, когда изменения будут появляться после горячей перезагрузки без перезапуска всего приложения, но тоже не без нюансов. Во-первых, при горячей перезагрузке теряется состояние приложения (если оно отдельно не сохраняется где-то), например при игре уже есть несколько крестиков и ноликов, то после Hot Reload они «забываются». Во-вторых, бывает, что изменения не отображаются и все равно приходится перезапускать приложение. Не баг, а фича, как говорится.

В целом же привыкнуть можно ко всему и даже потом возвращаться к WinForms становится тяжко – хочется все настраивать самому. 

В конечном итоге интерфейс готовых приложений получился таким:

  • Windows Forms

    WinForms
    WinForms
    • WPF 

WPF
WPF
  • WinUI

WinUi
WinUi
  • MAUI

MAUI
MAUI
  • Avalonia

    Avalonia
    Avalonia
  • Uno Platform

    Uno Platform
    Uno Platform

Я не сильно старался сделать их идентичными, потому что и задачи такой не было, да и на последующие измерения цвет кнопочек не повлияет. Более того, можно обратить внимание, что некоторые между собой похожи. Это результат применения в них компонентов WinUI. В MAUI дополнительно используются фирменные шрифты и MaterialDesign – поэтому кнопки со скругленными углами. А еще WinUI подтягивает основную тему из системы и поэтому все, кроме WinForms и WPF темные. Соответственно в первых двух нужно отдельно добавлять обработку светлой/темной темы.

Часть 3. Платформы

Тут мы подходим к глобальным возможностям всех фреймворков. Итак, таблица ниже показывает, под какие платформы может быть собрано приложение.

Фреймворки

Windows

MacOS

Linux

Android

iOS

WinForms

+

WPF

+

WinUI

+

.NET MAUI

+

+

+

+

Avalonia

+

+

+

+

+

Uno Platform

+

+

+

+

+


Как видим, что вполне логично, все шесть фреймворков позволяют писать оконные приложения для Windows. Но есть и различия. Они кроются как в кроссплатформенности MAUI, Avalonia и Uno, так и в компонентах, которые используются для отрисовки графического интерфейса. 

Углубляться сильно не будем в дебри, но стоит знать, что MAUI Авалония используют компоненты WinUI, Uno в свою очередь может реализовывать оконное приложение как в WPF варианте, так и WinUI. Это может быть полезно в отдельных случаях. 

Кроме того, нативные фреймворки WinForms, WPF и WinUI отличаются технически:

- Windows Forms использует GDI+ для отрисовки интерфейса

- WPF использует DirectX для рендеринга

- WinUI использует для рендеринга DirectX/DirectComposition

Так же, есть различие в используемых компонентах, библиотеках и подходах. Иными словами, все технологии, представленные в статье, имеют множество различий при схожей функциональности даже в рамках одной целевой платформы.


Часть 4. Ресурсы и скорость запуска

Сейчас мы подошли к той части «исследования», когда в дело вступают цифры. В данной части посмотрим на то, сколько приложения занимают места в оперативной памяти. Сравнивать будем в двух режимах: в Visual Studio в режиме Debug и в диспетчере задач запущенное опубликованное приложение (конфигурация Release).

WinForms

WPF

WinUI

.NET MAUI

Avalonia

Uno Platform

Debug (Mb)

15

80

80

132

82

62

Release

(Mb) 

6,1

19,6

26,2

54,4

32,6

13,6

 

Эти значения получены из Visual Studio при запуске отладки каждого приложения по отдельности. 

А вот релизную сборку я решил проверить более тщательно. Кроме того, стояла задача проверить скорость запуска каждого  приложения. Понятно, что все они с такой мизерной функциональностью не должны загружаться долго, однако различия в скорости есть. 

Для сбора данных я написал скрипт для PowerShell, который запускает приложение, ждет, когда оно загрузится (станет отзывчивым), дополнительно ждет пару секунд на случай неполной загрузки и выключает приложение. И так 100 раз подряд для каждого приложения. Попутно скрипт собирает данные об используемом объеме памяти и вычисляет скорость запуска. 

В процессе тестов, обратил внимание, что некоторые приложения занимают значительный объем в памяти. Поискал информацию, с чем это может быть связано и нашел вариант, где ответственность возлагалась на запаздывающую сборку мусора. Сомнительно, но ок — добавил в скрипт принудительный вызов GC.

[Console]::OutputEncoding = [System.Text.Encoding]::UTF8 $apps = @( "PATH_TO_TicTacToeUno.exe", "PATH_TO_TicTacToeMAUIApp.exe", "PATH_TO_TicTacToeWPF.exe", "PATH_TO_TicTacToeAvalonia.Desktop.exe", "PATH_TO_TicTacToeWinUI.exe", "PATH_TO_TicTacToeWinForms.exe" ) $results = @{} foreach ($app in $apps) { $appName = [System.IO.Path]::GetFileNameWithoutExtension($app) $times = @() $memoryUsages = @() for ($i = 1; $i -le 100; $i++) { Write-Host "Starting $appName (Iteration $i of 100)..." $start = Get-Date $process = Start-Process $app -PassThru # Ждем, пока главное окно приложения не станет отзывчивым while (-not $process.MainWindowHandle) { Start-Sleep -Milliseconds 100 } $end = Get-Date $duration = ($end - $start).TotalSeconds $times += $duration # Измеряем использование памяти Start-Sleep -Seconds 2 # Даем приложению время полностью загрузиться $memory = (Get-Process -Id $process.Id).PrivateMemorySize64 / 1MB $memoryUsages += $memory # Закрываем приложение Stop-Process $process.Id -Force while (-not $process.HasExited) { Start-Sleep -Milliseconds 100 } # Освобождение ресурсов и сборка мусора $process.Dispose() [System.GC]::Collect() [System.GC]::WaitForPendingFinalizers() # Ждем немного перед следующим запуском Start-Sleep -Seconds 5 } $averageTime = ($times | Measure-Object -Average).Average $averageMemory = ($memoryUsages | Measure-Object -Average).Average $results[$appName] = @{ Time = $averageTime Memory = $averageMemory } } # Вывод результатов Write-Host "`nResults after 100 launches:" $results.GetEnumerator() | Sort-Object {$_.Value.Time} | ForEach-Object { Write-Host ("{0,-30} : StartUp Time: {1:N3} seconds, Memory Usage: {2:N2} Mb" -f $_.Key, $_.Value.Time, $_.Value.Memory) }

Дополнительно отмечу, что скрипт я запускал по несколько раз с некоторыми изменениями, в частности брал данные о памяти как из process.WorkingSet64 так и process.PrivateMemorySize64, а так же для подстраховки продублировал тесты в Python-скрипте. Суммарно вышло что-то около 500-600 запусков каждого приложения, что в общем дает вполне понятную картину.

Еще, прежде чем показать результаты, оговорюсь относительно WinUI приложения — оно доставило больше всех хлопот, как ни странно,   поскольку запускалось уверенно в VS и даже тесты проходили в уже готовом и установленном приложении, однако по факту не запускалось. Ошибка с Windows.ui.xaml.dll вызываемая непонятно по какой причине, не давала мне покоя несколько дней. Несколько тестов были проведены с этой “особенностью”. Тем не менее глобально, после того, как проблема была решена, ничего в цифрах не поменялось кардинально. 

Итак, ниже скриншоты из PowerShell:

  1. 1 запуск:

PowerShell - 1 запуск
PowerShell - 1 запуск
  1.   5 запусков

    PowerShell - 5 запусков
    PowerShell - 5 запусков
  2. 10 запусков:

PowerShell - 10 запусков
PowerShell - 10 запусков
  1. 100 запусков:

PowerShell - 100 запусков
PowerShell - 100 запусков
  1. 10 запусков на Python:

Python - 10 запусков
Python - 10 запусков

Результаты интересные. По скорости запуска различия есть, но по сути на уровне погрешности — все запускаются быстро. Причем, когда наблюдаешь вживую за процессом выполнения скрипта, заметно, что первые 3-5 раз загрузка UI происходит дольше, чем последующие. Связано это с кэшированием на уровне ОС. Правда актуально это для ClickOnce-сборок в большей степени, но заметно и на WInUI, которую запускал без установки.

Гораздо интереснее ситуация с памятью. Тут и явный лидер — неожиданно - Uno Platform, и явный аутсайдер - WPF. 

Самый последний тест, при котором все уже работало и не падало - 100 итераций в PowerShell. Там же и минимальное значение задействованных ресурсов - в среднем 1,46 Мб. Тоже, скорее всего, связано с каким-то кэшированием, потому что в других тестах стабильно требовал ~ 8Мб.

Но всегда, во всех тестах, больше всего памяти отъедал WPF. Скорее всего это связано с тем, что учитываются “общие ресурсы” используемые другими приложениями в это же время в системе. По-крайней мере именно из-за этого вносил изменение в скрипт для получения данных из PrivateMemorySize64, однако тесты показали, что разницы нет. Возможна ли тут ошибка? Да, вполне может быть. Но и Python-скрипт показал такие же данные, поэтому я склоняюсь все же к тому, что WPF действительно самый ресурсоемкий фреймворк. 

Но я предполагал, что им окажется MAUI. И по используемым ресурсам, MAUI лишь WPF уступил в объеме задействованной памяти. В это же время, скорость запуска во всех тестах у MAUI была самой низкой. 

Часть 5. Сложность разработки

На самом деле, оценить сложность разработки в каждом конкретном фреймворке нельзя. Когда он, фреймворк, для тебя новый — сложно. Со временем становится сильно проще. Впрочем, как и в любом другом деле. Поэтому сказать однозначно, что в MAUI сложнее разрабатывать десктопное приложение, чем в WinUI, например, нельзя. 

Но совершенно точно WinForms - самый простой из представленных фреймворков в освоении. Тому есть два объяснения — графический редактор (дизайнер) и отсутствие необходимости в использовании MVVM паттерна и бесконечного числа биндингов. 

Но, опять же, все зависит от сложности проекта. В моем тестовом проекте везде было одинаково несложно. Даже с учетом того, что опыта с Uno и WinUI до последнего времени у меня не было. 

Часть 6. Сборка и развертывание

Пару слов про то, насколько сложно подготовить проект к публикации и использовать его потом. 

В целом, процесс должен быть не очень сложным везде. На практике, есть множество нюансов. В частности, неожиданно WinUI преподнес неприятные сюрпризы. Различных решений проблемы я нашел множество, но ни одно так и не помогло и, в конечном счете, запускал приложение для тестов из папки Release. Остальные приложения собрались и установились без проблем.

Дополнительно надо иметь в виду, что приложению требуется сертификат. То есть да, можно не подписывать приложение вовсе, но и распространять его будет сложнее - Windows на сторонних компьютерах будет ругаться при установке. Поэтому, хотя бы тестовым сертификатом подписать приложение стоит. А вот полноценный сертификат стоит денег, а в текущих условиях еще и надо найти, где его приобрести.

Конечно, это всё нюансы и наверно есть какие-то пути решения вопроса, да и вопрос сам не первоочередной важности. Но знать об этом стоит.

Часть 7. Итог

Что ж, стоит подвести итоги нашего небольшого исследования-сравнения. Для кого вообще оно делалось? Для тех, кто не занимался разработкой оконных приложений, но хотел бы понять, какие есть актуальные технологии. И вот эти технологии мы рассмотрели. Весьма поверхностно, конечно, но и задачи писать энциклопедию о том, как написать оконное приложение со всеми тонкостями, не стояло. А вот сделать вывод о том, с чего начать вкатываться в мир разработки приложений под Windows, а потом и других платформ, вполне можно. 

Мое видение, основанное на имевшемся ранее и полученном сейчас такое:

- Начинать стоит все-таки с базы – с Windows Forms. Да, технология не нова, даже можно ее считать устаревшей. Но она живая и функциональная. Многие приемы на ней можно отработать, да и собрать действительно сложное приложение с графическим интерфейсом вполне реально. Да чего там – так делали, делали много и долго.

- Вторым шагом стоит изучить WPF. Эта технология позволит развить понимание паттерна MVVM, проектирование интерфейса в XAML и откроет путь к более современным стекам. 

- Дальше путь открыт ко всему. Я был приятно удивлен возможностям Uno Platform, не ожидал. Кроме того, что можно написать приложение под любую актуальную ОС, в том числе и мобильную, так еще и весьма бережно эта технология относится, как оказалось, к ресурсам. Не то, чтобы это сильно критично, но, когда проект большой и нужно бороться за производительность, приложение, потребляющее меньше ресурсов будет выглядеть предпочтительнее на мой взгляд. 

Еще из важного – возможность собрать дизайн приложения Uno в Figma и импортировать код интерфейса прямо в проект в виде XAML-кода! Такого нет ни у кого из других рассмотренных фреймворков.

И, напоследок, пару слов о размере приложения на диске.

PowerShell - размер папок с установщиками
PowerShell - размер папок с установщиками

Здесь в папках располагаются установщики. WinForms - ожидаемо, самое “легкое” приложение. MAUI - без комментариев. Хотя нет, уточню, что в сборке MAUI отсутствуют билды под другие платформы, то есть это именно Windows-приложение. 

На этом все. Делайте свои выводы, пробуйте разрабатывать оконные приложения и успехов!

P.S. исходный код всех проектов доступен по ссылке: https://github.com/algmironov/WinAppFrameworksComparison

Комментарии (27)


  1. freemorger
    15.08.2024 17:21
    +1

    Uno выглядит неплохо для разработки на линукс. Хотя для линукса легче уж GTK или Qt использовать


  1. kovserg
    15.08.2024 17:21
    +13

    Все эти чудо технологии надо сравнивать с Delphi7 что бы стыдно было.


    1. maxzh83
      15.08.2024 17:21
      +2

      Разрабатывал на обоих и уверенно могу сказать, что WinForm сломает об колено Delphi 7.


    1. questfulcat
      15.08.2024 17:21
      +1

      helloworld приложение:

      • Delphi 7: ~380 KB, только windows

      • WinForms .NET Framework 4.0: ~9 KB, windows, а так же linux/MacOS через mono


  1. xtraroman
    15.08.2024 17:21
    +4

    Будущее за Linux. Начинать в 2024 проект который будет работать только под Windows - бесперспективно.

    Дельфи и Winforms были хороши для своего времени. Мввм паттерн и биндинги там не поддерживаются. Поэтому не стоит их использовать даже для обучения или как первый проект. Научитесь плохому)

    Ещё один красный флаг - технологии от Майкрософт. Они каждый год являют миру новый UI фреймворк. Забросят этот маюай прежде чем вы проект закончите.

    Моя рекомендация - только Авалония


    1. d00m911
      15.08.2024 17:21
      +3

      Пока в линукс-подобных системах не доведут процесс установки ПО до схемы "установка двумя кликами по одному файлу" (утрирую, понятное дело), за будущее Windows как ведущей ОС можно не волноваться. А пока даже в самой дружественной Ubuntu процесс установки deb-пакетов - это рулетка, с высокой вероятностью ведущая в терминал)


      1. bar2104
        15.08.2024 17:21

        Ну, установка пакета из deb файла по факту мало чем отличается от установщик на винде. Про apt молчу, да, надо команду прописать, но уже и гуишка есть, по сути то от Microsoft store мало чем отличается, только вот MSStore почему-то не особо использую.

        По поводу дороги в терминал в некоторых случаях: да, бывает, что зависимости не встают, бывает конфликт версий, да, решать через терминал зачастую. НО! Решить можно, в отличии от вины, в которой бывает, что dllка куда ни будь пропадёт. А на моем компе у меня почему то сломалась установка и удаление через msi. То есть я физически не могу поставить нужные мне программы, которые только так поставляются. А уж поверьте, раз я на линуксе сижу половину времени, некоторый опыт в гуглинге и решении проблем с компом имею. Так что этот косяк обоих систем касается

        И да, я молчу о самом главном косяке винды - кодироооовки, мне кажется хоть раз в жизни(кроме случаев, когда заранее предупредили), называл пользователя кириллицей, а потом узнавал, что винду надо к чертям сносить, ибо переименовать то можно, но вот с системными папками сложнее


      1. xtraroman
        15.08.2024 17:21

        Проблема инсталлеров Линукс конечно есть, но ее научились решать. Сходу можно провести примеры: установщик Steam, установщик Cura. Вполне дружелюбные. Многочисленные пользователи их осилили.


    1. piton_nsk
      15.08.2024 17:21
      +4

      Дельфи и Winforms были хороши для своего времени. Мввм паттерн и биндинги там не поддерживаются.

      Да ладно.

                  this.data = new DataSourceForButton() { StringData = "Lol" };
                  button1.DataBindings.Add(new Binding("Text", this.data, "StringData", true, DataSourceUpdateMode.OnPropertyChanged));
                  button1.DataContext = this.data;


      1. xtraroman
        15.08.2024 17:21

        Привязки к view model в коде выглядят громоздко. Попробуйте то же самое написать на xaml платформах. Получится гораздо элегантнее. Не стоит откапывать winforms, оставьте его в покое )


        1. piton_nsk
          15.08.2024 17:21
          +1

          Я писал на XAML и знаю что там и как, речь о биндингах в Winforms, которые "не поддерживаются".


          1. xtraroman
            15.08.2024 17:21

            Можно ли сказать что winforms формально поддерживает mvvm? Да можно. Вы правы.

            Можно ли это рекомендовать для обучения и для новых проектов?

            Нет.

            Код который вы показали - плохой. Его долго писать. Долго читать.


      1. stan1901
        15.08.2024 17:21
        +3

        Годами использовал биндинги в WinForms, а его нет, оказывается :) Работал он не идеально, но работал. Проблема у WinForms была в другом - он на каждый элемент управления создавал окно Windows, из-за чего сложные формы тормозили. Интереса ради как-то сделал форму с большим количеством полей ввода на WinForms и такую же на HTML - HTML-форма в Google Chrome работала гораздо быстрее WinForms.

        В-общем, если не нужны изыски отрисовки, то даже "голый" WinForms без специальных стилизованных элементов управления способен решать многие задачи (кроме разве что табличного ввода - он без доработки напильником не работал).


  1. bar2104
    15.08.2024 17:21
    +2

    Эх, ещё QT не хватает. Было бы с чем кросс платформ сравнить


  1. suprunchuk
    15.08.2024 17:21
    +2

    Ничего лучше tauri пока не нашел. Да не C# ваш. Но это мега крутой фреймворк.

    Tsx + Rust.

    Жирный плюс по сравнению с тем же Electron в том, что tauri переиспользует уже установленный webview в систему. на windows это edge, на mac это WebKit.. А electron каждый раз пихает в сборку .exe свой движок. За что размер приложения со старта 5 Мб на таури, и 180 Мб у электрона.
    Всем советую Tauri!


  1. Einherjar
    15.08.2024 17:21
    +7

    Хорошии обзор, но имхо крестики-нолики слишком простой пример для сравнения фреймворков, фактически это 9 кнопок и все, это так или иначе по силам любому фреймворку. Вот какая-н таблица с сортировкой и, скажем, комбобоксами в ячейках, и привязанная к данным тысячи хотя бы на три строчек сразу отделяет мух от котлет и показывает с каким фреймворком можно работать, а какой упоминать можно разве что только ради шутки. Две трети сойдут с дистанции еще на этапе разработки. Но конечно такой пример 6 раз для статьи сделать может быть весьма трудоемко


    1. comradeleet
      15.08.2024 17:21

      Два примера хватит, один под формы, второй под mvvm, + немного подкрутить индивидуально


    1. piton_nsk
      15.08.2024 17:21

      Тут уже больше зависит от библиотек, одно дело дефолтный грид, другое девэкспресс.


      1. Einherjar
        15.08.2024 17:21

        Наличие сторонних библиотек, степень их убогости и суммы которые за них хотят (и заплатив которые все равно придется потратить на пляски с бубном с воркараундами вокруг бесчисленных багов в них столько же времени сколько на написание собственных контролов) это тоже вполне себе важные критерии для оценки UI-фреймворка.


    1. Zerpico
      15.08.2024 17:21

      Было бы неплохо ещё оценить нагрузку в контейнерах, например списки, таблицы и т.п. Желательно около 1000 элементов в них и посмотреть нагрузки, память, скорость прокрутки, есть ли кэш или отложенная загрузка.


  1. miksmiks
    15.08.2024 17:21

    Мне к примеру нужен редактор с подсветкой синтаксиса. Есть ли в Avalonia или MAUI такое?


    1. xtraroman
      15.08.2024 17:21
      +1

      https://github.com/AvaloniaUI/AvaloniaEdit


    1. zarnii
      15.08.2024 17:21

      Можно писать код в Visual Studio, используя Avalonia или MAUI


  1. questfulcat
    15.08.2024 17:21

    Как я понял, startup time измеряется так:

    # Ждем, пока главное окно приложения не станет отзывчивым

    while (-not $process.MainWindowHandle)...

    Мне кажется, тут довольно скользкий момент. Не понятно, в каком фреймворке как это устроено. В одних оно может стать отзывчивым до момента инициализации и отрисовки, в других - после. Я бы просто добавил вызов Close() в конце конструктора формы, после всех инициализаций, чтобы приложение запускалось, инициализировалось и сразу закрывалось. И измерил бы общее время работы процесса. Просто как вариант...

    И жаль, что нет сборки WinForms под .NET Framework 4.x. Они совсем ведь разные фреймворки с .NET


  1. Superzoos
    15.08.2024 17:21

    Статья очень вовремя, как раз перехожу с C++ и Windows Forms на C# и WPF. Uno Platform раньше даже не слышал. Спасибо за статью!


  1. Wolfdp
    15.08.2024 17:21

    По опыту замечу что "простота winforms" крайне обманчива. Как только пытаешься в что-то сложнее крестиков-ноликов, то сложность работы через графический редактор крайне возрастает. XAML в плане организации UI гораздо лучше, хоть и приходиться потратить время на "разобраться".

    Также отмечу что WPF поддерживает графическое ускорение, что позволяет с легкостью переваривать 100500 элементов в окне. Для форм такое издевательство нередко превращается в слайдшоу.

    Дополнительный минус для winforms, что размеры контролов окна работают в разрезе 16 бит, причем в коде Size или Point имеют 32 битные поля и никаких ошибок в процессе не получаешь. Просто при переполнении, элемент улетает в непонятную часть окна.

    И как вишенка на торте, я не завидую тому человеку, которому придеться поддерживать hight dpi на winforms.

    С учетом всего этого, я очень скептически отношусь к идеи связываться с winforms, когда есть альтернатива в виде wpf. Особено в плане обучения. XAML всеже больше про разметку через теги, а не работу в графическом редакторе. В итоге приходиться ломать привычные подходы на новые.

    P.S. Возможно из плюсов будет тот факт, что в winforms довольно просто нарисовать свой произвольный элемент. Хотя я не особо разбирался насколько это сложно в wpf.


  1. ilyachudin
    15.08.2024 17:21

    1. Поддержку win нужно делить на Win XP/7+ и Win10+ (да xp имеет место жить в кровавом энтерпрайзе)

    2. Avalonia не использует WinUi (!) - там честный кросплатформенный рендеринг на векторах