Как установить фон строки динамически с помощью flex? - PullRequest
0 голосов
/ 18 января 2010

Смотри мой источник:

  • Шаблон:

[код]

<mx:Script source="ListStatus.as" />

<!-- Template -->
<mx:DataGrid id="grid" width="100%" height="100%" doubleClick="editRecord();">
    <mx:columns  >
        <mx:DataGridColumn width="30" resizable="false" draggable="false">
            <mx:itemRenderer>
                <mx:Component>
                    <mx:LinkButton icon="@Embed('assets/img/delete.png')" click="outerDocument.deleteRecord(event);" />
                </mx:Component>
            </mx:itemRenderer>
        </mx:DataGridColumn>
        <mx:DataGridColumn headerText="Nome" dataField="name" />
        <mx:DataGridColumn headerText="Nome de exibição" dataField="displayName" />
        <mx:DataGridColumn headerText="Cor" dataField="color" />            
    </mx:columns>
</mx:DataGrid>

[/ Код]

  • ActionScript:

[код] импортное топливо. Аякс; импортное топливо. Модуль; import fuel.window.Window;

import mx.controls.Alert; import mx.events.ModuleEvent; import mx.modules.ModuleLoader;

public var win: Window;

/ ** * Конструктор * * Получить данные от контроллера турбо передач * / публичная функция init (): void {
showLoading (); Ajax.requestJSON ('/ access / status / getList', {}, функция (obj: Object): void { hideLoading (); grid.dataProvider = obj.results; }); }

/ ** * Форма звонка для редактирования записи * / публичная функция editRecord (): void {

try {
    grid.selectedItem.id;                   
} catch(e:Error) {
    Alert.show("Você deve selecionar um registro válido", "Atenção");
    return;
}

var module:ModuleLoader = new ModuleLoader();
module.url = "access/CreateStatus.swf";
module.applicationDomain = ApplicationDomain.currentDomain;
module.addEventListener( ModuleEvent.READY, onModuleReady );

var title_bar:String = "Edição de Status (" + grid.selectedItem.id + ")";

if( this.window ){
    win = this.window.openChild(title_bar, module, 410, 250);
} else {
    win = (parentApplication as Admin).winManager.openWindow(title_bar, module, 410, 250);
}

}

/ ** * Вызов контроллера для удаления записи * / приватная функция actionDeleteRecord (соответственно: Object): void { if (resp.detail == Alert.YES) { grid.enabled = false;

    Ajax.requestJSON( "/access/status/delete", { 'id' : grid.selectedItem.id }, function( obj:Object ):void {
        if (obj.error == false) {
            Alert.show("Registro deletado com sucesso", "Confirmação");
        } else {
            Alert.show(obj.msg, "Erro");
        }

        init();             
    });

    grid.enabled = true;
}

}

/ ** * Запрос вызова для удаления записи * / публичная функция deleteRecord (событие: событие): пустота { Alert.show ("Операция по удалению сообщений. \ NDeseja Mesmo Remover o status \" "+ grid.selectedItem.displayName +" \ "?", "Подтверждение", Alert.YES | Alert.NO, this, actionDeleteRecord); }

публичная функция onModuleReady (событие: ModuleEvent): пусто {
var loader: ModuleLoader = event.target as ModuleLoader;

var m:* = loader.child as IModule;
if( m ) m.addEventListener( Event.RENDER, function runModule(e:Event):void{
    m.setId(grid.selectedItem.id);
    m.window = win;                 
    m.removeEventListener( Event.RENDER, runModule );
});

}; [/ Код]

Мне нужно установить фон строки, используя значение цвета, которое существует в dataProvider.

Извините за мое невежество, это мой первый проект с использованием flex.

Спасибо'S!

1 Ответ

0 голосов
/ 20 января 2010

Решение состоит в том, чтобы создать класс, расширяющий DataGrid, и переопределить метод drawRowBackground, который отвечает за рисование цветного прямоугольника за элементами строки.

Метод drawRowBackground передаетсяцвет по умолчанию, а также индекс вашего текущего элемента данных, чтобы вы могли получить текущий элемент, получить из него пользовательское свойство цвета и передать этот цвет в вызов super.drawRowBackground ().

override protected function drawRowBackground(s:Sprite, rowIndex:int, 
                                                y:Number, height:Number,
                                                color:uint, dataIndex:int):void 
{
    if (dataIndex < dataProvider.length && dataProvider[dataIndex])
    {
        color = dataProvider[dataIndex].color;
    }
    super.drawRowBackground(s, rowIndex, y, height, color, dataIndex);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...