桌面空气应用辅助功能

时间:2013-05-24 07:03:41

标签: flex air accessibility desktop narrator

我正在尝试为我的应用添加辅助功能。我仍然无法弄清楚火花组件的可访问性是如何工作的 我在窗口的平台上启用了叙述者功能。 我想要做的就是用可访问性的不同名称命名这三个字段,以便用户知道该怎么做。 我试图使用声明来定义辅助功能属性,但似乎它总是只说出按钮的一个名称。因此,我采用了另一种方法,并尝试在创建完成时创建辅助功能属性。似乎叙述者有时会在开始时选择正确的辅助功能名称,然后很快,当我转到按钮时,它将替换所有名称并将其称为“搜索按钮”。知道为什么吗?!?!我很困惑。任何帮助将不胜感激。

<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" 
                       xmlns:s="library://ns.adobe.com/flex/spark" 
                       xmlns:mx="library://ns.adobe.com/flex/mx"
                       xmlns:accessbility="flash.accessibility.*" initialize="onInit()" creationComplete="onComplete()">
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->

    </fx:Declarations>

    <fx:Script>
        <![CDATA[

        import com.modernista.swffocus.SWFFocus;

        private function onComplete():void {
            var ap1:AccessibilityProperties = new AccessibilityProperties();
            ap1.name = "search";
            searchInput.accessibilityProperties = ap1;
            var ap2:AccessibilityProperties = new AccessibilityProperties();
            ap2.name = "name input";
            nameInput.accessibilityProperties = ap2;
            var sb:AccessibilityProperties = new AccessibilityProperties();
            sb.name = "search button";
            searchSubmit.accessibilityProperties = sb;
            Accessibility.updateProperties();
        }
        // this helps Firefox capture and release keyboard focus
        private function onInit():void {
        SWFFocus.init(systemManager.stage as Stage);

        }

        ]]>
    </fx:Script>
    <mx:Form defaultButton="{searchSubmit}">
        <mx:HBox width="100%" height="100%" horizontalAlign="center" verticalAlign="middle" > 
            <mx:TextInput id="searchInput" width="540">
            </mx:TextInput>
            <mx:TextInput id="nameInput" width="540">
            </mx:TextInput>
            <mx:Button id="searchSubmit" label="search" />
        </mx:HBox>
    </mx:Form>
</s:WindowedApplication>

1 个答案:

答案 0 :(得分:1)

  

我想要做的就是用可访问性的不同名称命名这三个字段,以便用户知道该怎么做。我试图使用声明来定义辅助功能属性,但似乎它总是只说出按钮的一个名称。

MS讲述者是您只有在没有其他选项时才使用的工具之一。想想那个令人毛骨悚然的老加油站,当你在没有的地方。我会使用与JAWS一样好的NVDA, a free screen reader来测试应用程序,并且更容易接受(NVDA v。 MS讲述人)的测试。

  

因此,我采用了另一种方法,并尝试在创建完成时创建辅助功能属性。似乎叙述者有时会在开始时选择正确的辅助功能名称,然后很快,当我转到按钮时,它将替换所有名称并将其称为“搜索按钮”

我更多地将这归因于叙述者的不满。

看起来您还没有包含辅助功能库,但我不是Flex开发人员,因此我不知道是否需要它们,就像在Flash中一样。

您的代码

  var sb:AccessibilityProperties = new AccessibilityProperties();
        sb.name = "search button";

我会在这里取出按钮。大多数辅助技术都会添加元素类型,因此该按钮将被宣布为搜索按钮按钮

进一步阅读: