0

我有一个 ItemRenderer,其中应禁用选定状态(我正在使用渲染器状态,但没有选定状态)。问题是列表(火花)会在单击时重置项目渲染器状态,即使我没有“选定”状态。

我想完全防止这种行为,但我不知道如何。我的渲染器将 autoDrawBackground 设置为 false,但必须启用它(尽管 enabled=false 修复了此问题)此外,渲染器有几个子级,包括它自己的列表。在渲染器上设置 mouseEnabled="false" 会修复渲染器本身,但不会修复其子级,我需要一些子级启用鼠标。

编辑:

以下是我的项目渲染器的摘录:

<?xml version="1.0" encoding="utf-8"?>
<s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" 
                xmlns:mx="library://ns.adobe.com/flex/mx" 
                xmlns:s="library://ns.adobe.com/flex/spark"
                width="100%" autoDrawBackground="false">

    <s:states>
        <s:State name="normal" />
        <s:State name="suitable" />
        <s:State name="mine" />
        <s:State name="deleted" />
    </s:states>

    <s:Rect id="rect" top="0" right="0" bottom="0" left="0">
        <s:fill>
            <s:SolidColor id="background"
                          alpha=".8" alpha.deleted=".4"
                          color="0xff0000" color.suitable="0x00ff00" color.mine="0x0000ff" />
        </s:fill>
    </s:Rect>

    <s:Label id="name" left="4" top="4" right="40" />

    <s:List id="myList" left="4" top="40" right="4"
            contentBackgroundAlpha="0" borderVisible="false" horizontalScrollPolicy="off">
        <s:layout>
            <s:VerticalLayout gap="3" paddingBottom="4" requestedMinRowCount="2" />
        </s:layout>
    </s:List>
</s:ItemRenderer>

第二次编辑:

我在鼠标悬停状态下遇到了同样的问题,但这似乎有一个解决方法:

override protected function set hovered(value:Boolean) : void
{
    // do nothing (prevent current state from changing to "hovered" state)
}
4

1 回答 1

0

我不清楚您是否要阻止选择某个项目;或者只是阻止与选择的项目一起出现的视觉属性。

处理视觉方面;我会尝试覆盖 getCurrentRendererState() 方法。像这样的东西:

override protected function getCurrentRendererState():String{
  if (selected && hasState("selected"))){
    return "normal"; // or whatever state you want it to be
  }
  if (selected && down && hasState("downAndSelected")){
     return "normal"; // or whatever state you want it to be
  }        

  super.getCurrentRendererState()

}

从理论上讲,这应该可以防止您的渲染器进入选定状态。

于 2013-10-17T12:45:26.020 回答