加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

flex – ItemRenderer更改背景颜色

发布时间:2020-12-15 01:48:16 所属栏目:百科 来源:网络整理
导读:我有一个项目渲染器,我想更改默认颜色: s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" initialize="init(event)" creationComplete="created(event)"
我有一个项目渲染器,我想更改默认颜色:

<s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
                xmlns:s="library://ns.adobe.com/flex/spark"
                xmlns:mx="library://ns.adobe.com/flex/mx"
                initialize="init(event)"
                creationComplete="created(event)"
                dataChange="created(event)"
                width="100%"
                maxWidth="{FlexGlobals.topLevelApplication.width}"
                contentBackgroundColor.hovered="0xff0018"
                focusColor="0xff00ff"
                contentBackgroundAlpha="0.8">

        <s:states>
            <s:State name="normal"/>
            <s:State name="hovered"/>
            <s:State name="selected"/>
        </s:states>

上述代码中的样式无效.

我也尝试将contentBackgroundColor添加到List元素,但只更改了列表的背景而不是项目.

css也不起作用:

s|ItemRenderer{
    backgroundColor:#2e2e2e;
}

如何更改项呈示器的背景颜色?

我知道我可以去皮,但这对于一个简单的颜色变化来说是一种过度杀伤,而且我很肯定我几年前都没有过皮肤.

解决方法

起初总是有点混乱.在我看来,样式名称选择不当.血腥细节都在ItemRenderer类的drawBackground()方法中.

您可以在List组件本身上设置contentBackgroundColor样式,它对渲染器没有影响.它将填充列表的背景颜色,但通常渲染器占据所有区域,因此您永远不会看到它.例如,如果您的列表很高但只有1或2个项目(因此底部的空间不被渲染器覆盖),它将是可见的.

设置渲染器的背景颜色:

而不是使用contentBackgroundColor,使用alernatingItemColors样式.此样式需要一组值.如果您只想要一种颜色,只需在数组中放入一个元素:

alternatingItemColors="[#c0c0c0]"

通过查看drawBackground()中的代码,如果要在背景颜色上设置alpha,则必须自己绘制背景(参见下文).

您可能希望设置的其他背景相关样式:

> downColor
> selectionColor
> rollOverColor

要绘制自己的背景颜色:

将autoDrawBackground属性设置为false.这意味着您现在必须为所有各种渲染器状态(“正常”,“选定”,“悬停”等)绘制自己的颜色.幸运的是,您可以在渲染器中使用与您在上面选择的背景对象上使用的相同状态语法(“Rect”等).

<s:ItemRenderer autodrawBackground="false">
    <s:states>
        <s:State name="normal"/>
        <s:State name="hovered"/>
        <s:State name="selected"/>
    </s:states>
    <s:Rect id="theBackgroundObject" top="0" bottom="0" left="0" right="0">
        <s:fill>
            <s:SolidColor color="#FF0000" color.hovered="#00FF00"
                alpha="1" alpha.hovered=".5" />
        </s:fill>
    </s:Rect>
</s:ItemRenderer>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读