アクセス可能な Web リソースの作成
ソリューションにユーザー インターフェイス要素を提供する Web リソースを含める場合、障碍のある方でも Web リソースを使用できるようにするための要件が満たされていることを確認します。
アプリケーションのユーザー インターフェイス要素は、すべてのユーザーが同等の機能を使えるようにするための標準およびベスト プラクティスに従っています。 障碍のある方がアプリケーションを操作する場合、スクリーン リーダーやさまざま代替入力デバイスなどの支援技術 (AT) を使用することができます。
このトピックでは、障碍のある方がアクセス可能な Web リソース ユーザー インターフェイス要素の設計に役立つ一般的なガイダンスや多くのリソースへのリンクを紹介します。
支援技術
スクリーン リーダー、点字ターミナル、音声認識ソフトウェアなどのさまざまな支援技術 (AT) アプリケーションがあります。 これらのアプリケーションは、ユーザー インターフェイス要素を、AT アプリケーションを使用するユーザーがプログラムを使用できるようにするための手段を提供します。
Windows アプリケーションの場合、Microsoft UI オートメーション (UIA) クラスは、ユーザー インターフェイス要素へのプログラムでのアクセスを可能にします。 これらのクラスは自動化テストと AT の両方をサポートします。 開発者が定義して UIA を通じて公開したプロパティおよび要素を、AT アプリケーションが使用できます。 Windows アプリケーション開発者は、UIA を使用することで、どの程度 UI 要素を公開するかをかなりの割合で制御できます。
Web アプリケーションでは、特定の HTML 要素は、ドキュメント オブジェクト モデル (DOM) を通じて公開されます。 ブラウザーで、DOM 要素をプロパティおよびイベントと共に UIA オブジェクトに変換します。プロパティとイベントは、AT により使用され、ユーザーが Web アプリケーションを使用することができるようになります。 開発者が、UIA を使用するブラウザーで公開する UI 要素をどの程度制御できるかには制限があります。
アクセス可能な HTML Web リソース
Web リソースの HTML は、ブラウザーで処理され、AT アプリケーションで使用できるようになります。
考慮すべき最初の点は、HTML が所定の使用パターンに従っていることを確認することです。 たとえば、HTML button
要素とまったく同じように機能するクリック イベントのある HTML div
要素を定義できます。 ただし、ブラウザーは div
要素がボタンとして使用されることは想定しておらず、AT アプリケーションに同じプロパティやイベントを公開することはありません。
ユーザーが Web リソースで行える種類の操作に対して、正しい HTML 要素を使用することが重要です。 これをセマンティック HTML と言います。
ただし、それ以上のことは、セマンティック HTML では行えません。 近代の Web アプリケーションには、一般に、連携して動作する多くの HTML 要素で構成されているカスタム コントロールが含まれています。 非同期 JavaScript を使用して動的に頻繁に更新されるページ コンテンツは、セマンティック HTML のみに頼った AT アプリケーションにとっては分かりづらいものです。 Accessible Rich Internet Applications (ARIA) テクノロジは HTML を独自のセマンティックなやり取りを行う属性の追加により拡張することでソリューションを実現します。
ARIA は、コントロールまたは「ウィジェット」で使用される HTML 要素に適用できる拡張属性の標準セットを提供します。これらの属性は、コントロール内で HTML 要素が果たす役割を記述します。 ARIA はまた、ナビゲーション操作を改善する機能を備えており、ユーザーが動的に更新可能な要素に対応できるようにします。 推奨される方法は、ARIA をセマンティック HTML 上のレイヤーにすることです。
AT のサポートのほかに、検討する必要のある他の要件があります。 たとえば、ユーザーがテキスト サイズを大きくしたときの UI の調整方法などです。 UI で、作業を行う際にユーザーは色を区別する必要がありますか。 すべての操作は、キーボードを使用して実行できますか。 詳細については、「Web アクセシビリティの概要」を参照してください。
アクセシビリティのテスト用ツール
次の一覧は、一般に公開されているアクセシビリティのテスト用ツールの一部です。
Visual Studio アクセシビリティ チェッカー
HTML Web リソース ファイルを編集するために Visual Studio を使用している場合、アクセシビリティに関する問題をチェックするための組み込みツールがあります。 ツールメニューで、アクセシビリティのテストを選択し、アクセシビリティ関連の問題に関するガイダンスを提供するレポートを表示します。
UI Accessibility Checker
UI Accessibility Checker (AccChecker) は、テスターが簡単に Microsoft Active Accessibility (MSAA) や他のユーザー インターフェイス (UI) の Windows への実装に関するアクセシビリティの問題を発見できます。 AccChecker は、既存の実装についての詳細を提供する Windows API ツール (Inspect など) の実現から生まれましたが、実装が正しいかどうかについての情報はありません。
Inspect (Inspect.exe)
Inspect (Inspect.exe) は Windows ベースのツールで、任意の UI 要素を選択してその要素のユーザー補助データを表示できます。 Microsoft UI オートメーションのプロパティおよびコントロール パターンに加え、Microsoft Active Accessibility プロパティも表示できます。 Inspect はまた、UI オートメーション ツリーのオートメーション要素のナビゲーション構造、および Microsoft Active Accessibility 階層のアクセス可能オブジェクトをテストできます。
Accessible Event Watcher (AccEvent.exe)
Accessible Event Watcher (AccEvent) ツールは、開発者やテスターが、UI の変更が起こったときにアプリケーションの UI 要素が適切な Microsoft UI オートメーションおよび Microsoft Active Accessibility イベントを発生させるかを検証することができます。 UI の変更は、フォーカスが変更したときや、UI 要素の呼び出し、選択、状態またはプロパティの変更が行われたときに発生する可能性があります。
その他のリソース
次の Web リソースは、リソースをアクセシブルにするための条件を定義するための開始点を提供します。
- Web アクセシビリティの概要
- Visual Studio および ASP.NETにおけるアクセシビリティ
- アクセシビリティの概要
- ユーザー補助 - W3C
- Web コンテンツのアクセシビリティに関するガイドライン (WCAG) 2.0