クライアントサイド・デコレーション
クライアントサイド・デコレーション(英語: client-side decoration、略称: CSD)とは、グラフィカルなアプリケーションソフトウェアにおけるウィンドウ・デコレーションの描画について、歴史的にウィンドウマネージャが担当していたのに対し、各アプリケーションが独自に担当することを許容するという概念である[1]。
伝統的なタイトルバーを持たないアプリケーションを指すためにクライアントサイド・デコレーションという語句が用いられることがあるが、これは誤用であり、最小限のタイトルバーを持つアプリケーションでもクライアント側でのデコレーションは可能である[2]。
伝統的なサーバサイド・デコレーションの代わりにクライアントサイド・デコレーションを使用することにより、各アプリケーションが独自のタイトルバーを描画できるため、ウィンドウ・デコレーションの広範囲なカスタマイズや、標準的なウィンドウマネージャでウィンドウを最大化した場合に広大な空きスペースとなっていた領域への機能(GUIウィジェット)の追加などが実現できる[3]。
定義
[編集]LinuxやUnix系のオペレーティングシステムでは、「クライアントサイド・デコレーション」という呼称はX Window Systemに由来し、クライアントとはすなわちウィンドウを生成してXサーバに送るアプリケーションである。その逆は「サーバサイド・デコレーション」(server-side decoration、SSD)と呼ばれるが、X Window Systemであっても実際にデコレーションを描画するのはウィンドウマネージャであり、「サーバ」ではない。
実装
[編集]ウィジェット・ツールキット
[編集]GTK
[編集]GTKは、GtkHeaderBarウィジェットにより、Linuxで最初にクライアントサイド・デコレーションを実装したGUIツールキットである[4]。
GtkHeaderBarでは、より多くの領域をアプリケーション本体に割り当て、無駄な空白部分の面積をできる限り削減するために、タイトルバー、メニューバー、ツールバーを統合して単一の水平のバーとして描画する。これにより、アプリケーションから伝統的なデスクトップでの使用を前提としていた箇所が削除され、デスクトップPCからスモールフォームファクタ機器まで、様々なフォームファクタを通じたUIの柔軟性やUXの一貫性の確保に貢献する。これらはGNOME Shellで最優先にサポートされるほか、GNOME applicationsでも幅広く使用されている。
UWP
[編集]ユニバーサルWindowsプラットフォーム(UWP)アプリケーションでは、独自のタイトルバーを描画する方式が選択できる[5]。
macOS
[編集]macOSでは、Application KitベースのアプリケーションがNSWndowウィジェットを使用する場合に、クライアントサイド・デコレーションをサポートする[6]。
Electron
[編集]Electronにはフレームレス・ウィンドウ(ツールバー・メニューバー・タブを描画しない)のオプションがあり、アプリケーション側で独自に陰影の描画を担当する[7]。
Deepin Tool Kit
[編集]Deepin Tool KitはQt5ベースのウィジェット・ツールキットであり、Deepin Desktop Environmentで使用されている。
アプリケーション
[編集]クライアントサイド・デコレーションをサポートする著名なアプリケーションを以下に挙げる。
- Steam - 「VGUI」と呼ばれる独自ウィジェット・ツールキットを使用する。
- Firefox
- Google Chrome
ディスプレイサーバ
[編集]Wayland
[編集]Waylandは(ウィンドウ陰影を含め)クライアントサイド・デコレーションを前提として設計されているが、xdg-decorationとして知られるプロトコルもオプションでサポートしており、これはアプリケーション(クライアント)がウィンドウマネージャに対してサーバサイド・デコレーションをサポートしているかどうかを照会し、もしサポートしていればクライアントに使用させるというものである[8]。GNOME Shellで使用されるコンポジタであるMutterは、Waylandのもとではクライアントサイド・デコレーションのみをサポートするが[9]、KWinはクライアントサイドおよびサーバサイドのいずれのデコレーションもサポートする。
歴史
[編集]- 2008年、アドビはクライアントサイド・デコレーションを採用するPhotoshop CS4をリリースした。
- 2012年、マイクロソフトはMetroデザイン言語でクライアントサイド・デコレーションを採用し、「戻る」ボタンなどのツールバー・オブジェクトをウィンドウのタイトルバーに配置した。
- 2013年、GTKプロジェクトはクライアントサイド・デコレーションのサポートが追加されたGTK 3.10をリリースした[10]。
脚注
[編集]- ^ “Client-side decorations, continued” (英語). blogs.gnome.org. 2019年1月17日閲覧。
- ^ “A small note on window decorations | Florian Müllner” (英語). 2019年11月13日閲覧。
- ^ “The CSD Initiative Is Pushing For Apps To Abandon Title Bars In Favor Of Header Bars - Phoronix”. Phoronix. 2018年1月28日閲覧。
- ^ “GtkHeaderBar: GTK+ 3 Reference Manual”. developer.gnome.org. 2019年1月17日閲覧。
- ^ mijacobs. “Title bar customization - Windows UWP applications” (英語). docs.microsoft.com. 2019年1月17日閲覧。
- ^ “NSWindow - AppKit | Apple Developer Documentation”. developer.apple.com. 2019年6月7日閲覧。
- ^ “Frameless Window | Electron” (英語). electronjs.org. 2019年1月17日閲覧。
- ^ Wayland protocol development, Wayland, (2019-10-07) 2019年11月13日閲覧。
- ^ Bernard, Tobias. “Introducing the CSD Initiative – Space and Meaning”. GNOME. 2018年1月28日閲覧。
- ^ “GTK+ 3.10 released [LWN.net]”. lwn.net. 2019年1月17日閲覧。