🙄

Windows フォームから WPF へ移行すべきか? メリットとデメリットを解説します!

2022/01/20に公開

こんにちは!

テクニカルコンサルティングチームの古堅です。

本記事では、Windows フォームから WPF へ移行を検討している方へ向けた記事となります。

本当に Windows フォームから WPF に移行する必要があるのか? メリットはあるのか? 本記事で解説します。

結論

大規模、モダンな UI のアプリケーションを作るなら WPF の移行
小規模、シンプルな UI であれば Windows フォームのままで良い

WPF に移行すべきか?「モダンな UI を作りたい」「画面を一新してユーザーに快適な UX を提供したい」「大規模アプリケーションの UI の保守性を高めたい」であれば WPF の採用をおすすめしますが、小規模でシンプルな UI であれば移行の必要はありません。

WPF と Windows フォームの最大の違いは、UI に関わる部分が、ほとんどを占めています。

WPF に移行したからといってビジネスロジックが大幅に性能アップ!なんて事もありません。

その代わり、WPF は「UI の開発効率の向上」や「UI のメンテナンス性向上」が期待できます。なぜなら、そのために作られたプラットフォームだからです。

Windows フォームに対する WPF の優位性について

前提としてWindows フォームで出来ることは WPF でも実現可能

まず、移行の気になるポイントとしては「今まで出来ていたことが出来なくなるのではないか?」という観点があるかと思いますが、安心してください。

前提として Windows フォームで実現出来ていた仕様は、WPF でも実現できます。

どちらも Windows OS 上で動作し、Windows API の利用や、ローカルリソースへのアクセスも出来ます。

image.png

UI に対する開発効率やメンテナンス性の違いについて

UI に対する開発効率や、メンテナンス性は WPF が圧倒している部分だと言っても良いでしょう。

Windows フォームは、GUI を操作し「自動生成されたプログラム」でレイアウトを構築する。

WPF は、XAML を通して「テキストベース」でレイアウトを構築する。

例えば、類似画面を作る際に、いずれもコピーペーストで作成できますが、WPF はテキストのコピーペーストなので、より簡単に作業を行う事ができます。

また、既存の画面レイアウトを変更する場合など

「ボタンの位置を変更したつもりが、誤操作で、意図しないコントロールに変更が発生している」

といった場面を思い出してください。

その場合、Windows フォームの場合、あるあるなお悩みかと思いますが、自動生成されたプログラムの差分チェックを行う必要があり、ソースコードのどの行に変更が発生しているのか、見落としてしまう事もあるかと思います。

WPF の場合では、UI の情報は全てテキストベースなので、Windows フォームと比べると差分が明確で、意図しない変更内容も見つけやすいです。

上記のような点が、UI に対する開発効率や、メンテナンス性に大きく作用しています。

画面描画性能の向上 (GPU)

WPF の優位性としては、ハード面での優位性もあげられます。

Windows フォームは描画技術は「GDI」または「GDI+」であり、その性能は CPU に依存しています。

WPF では、「Direct3D」により、GPU でも描画処理が行われ、CPU の負担が軽減されています。

これらは、エンドユーザーがアプリケーションを利用する快適さに大きく影響します。

特に、デベロッパーが注意しないといけない点としては、エンドユーザーが利用しているマシンスペックは、デベロッパーのマシンほど良いものではないと意識すべき点です。

開発時には、デベロッパーのマシンスペックの高性能により気付かなかった不都合が、エンドユーザーのマシンスペックだと表面化されるという経験をされた方も、多いのではないでしょうか。

エンドユーザーのマシンスペックをフルに活かせるのも、WPF の優位性のひとつとして挙げられます。

image.png

レスポンシブ対応 (複数の解像度) 対応

Windows フォームのよくある問題として、現在利用されている高解像度のディスプレイにうまく対応できていない。という問題があったりします。

理由としては、UI を作成するプロセスに原因があります。

Windows フォームは、ドラッグアンドドロップで"絶対位置"でコントロールを配置して、UIを作成します。

WPF は、XAML (レイアウトファイル)に"相対位置"で記載することで、相対位置をベースに作成します。

image.png

image.png

WPF への移行の最大の懸念点は「学習コスト」

XAML や データバインディング、MVVM アーキテクチャの学習コスト

WPF アプリケーションを作成する為には、「XAML」や「データバインディング」、「MVVM」といった新しく学ばなければならない項目が幾つかあります。

「XAML」は、XML形式で画面が構築できる記載方法で、Xamarin などでも採用されています。

「データバインディング」や「MVVM」アーキテクチャを採用すると、UI とそれ以外を切り離した、非常にクリーンなアプリケーションを構築できます。Web の世界だと「Angular」や「Vue.js」などのモダンな JavaScript フレームワークでも採用されているデザインパターン (設計手法) です。

デメリットとしては、Windows フォーム時代には無かった機能・設計であるため学習コストがかかります。身に付ければ非常に強力な機能となりますが、使いこなすまでの学習コストが掛かります。

弊社では WPF の基礎知識の習得に役立つ「WPF 入門 技術トレーニング」を提供していますので、こういったトレーニングをお受け頂く事で、学習コストを低く抑えることも検討頂くのも良いかと思います。

移行計画について

一度に全ての業務システムを移行する必要はない

WPF には、Windows フォームを WPF アプリケーションの中の、1つのコントロールのように取り扱える技術があります。

https://docs.microsoft.com/ja-jp/dotnet/desktop/wpf/advanced/walkthrough-hosting-a-windows-forms-control-in-wpf?view=netframeworkdesktop-4.8

この技術を活用することにより、WPF への移行も段階を踏んで移行することができます。

例えば、現行システムが 100 画面あったとしましょう。そのうち、メイン 30 画面とアプリケーションのフレーム(ヘッダーやメニューなど) を WPF で作成し、残りの 70 画面は、WPF アプリケーション内で、現行の Windows フォームの画面をそのまま表示する。などの実現が可能です。

大規模アプリケーションほど、一度に移行するのは大きくコストが掛かります。

そのため、段階的に移行する、それが可能な WPF は、移行の大きな助けとなってくれるでしょう。

まとめ

WPF は Windows フォームと比較すると、初期コストは高くつくが、一度学習すれば、開発効率・保守性が高いアプリケーションが作成できます。

一方、シンプルが画面であれば、無理に Windows フォームへの移行を進める必要も無いかと思います。

弊社では、 WPF の特性や基礎知識を学習できる 「WPF 入門 技術トレーニング」を提供していますので、ご興味がある方は是非お気軽にお問合せください!

開発全般に関するご相談はお任せください!

インフラジスティックス・ジャパンでは、各プラットフォームの特別技術トレーニングの提供や、開発全般のご支援を行っています。

https://jp.infragistics.com/service-and-support/professional-service

「古い技術やサポート終了のプラットフォームから脱却する必要があるが、その移行先のプラットフォームやフレームワークの検討が進まない、知見がない。」

「新しい開発テクノロジーを採用したいが、自社内にエキスパートがいない。日本語リソースも少ないし、開発を進められるか不安。」

「自社のメンバーで開発を進めたいが、これまで開発フェーズを外部ベンダーに頼ってきたため、ツールや技術に対する理解が乏しい。」

「UIを刷新したい。UIデザインやUI/UXに関する検討の進め方が分からない。外部のデザイン会社に頼むと、開発が難しくなるのではないか、危惧している。」

といったご相談を承っています。

お問い合せはこちらからお気軽にご相談ください。

Discussion