0

高度なデータグリッドがあり、カスタム ソートを実装しています。私の adv.data グリッドは、結果として生じるソートごとに遅くなります...そして、ノードが開かれていると、単にタイムアウトします。

私のデータは次のようになります (g = ID の grp)*

ID    f_name    l_name   fld1    fld2
(g)
--------------------------------------
1        A1        B1      xyx    xyz
         A6        B6      xyx    xyz
--------------------------------------
2        A3        B3      xyx    xyz
         A8        B8      xyx    xyz
--------------------------------------

F_NAME または L_NAME で並べ替えると、並べ替え ArrayCollection は次のようにデータを並べ替えて表示する必要があります (g = ID の grp)*:

ID        f_name    l_name   fld1    fld2
(g)
-----------------------------------------
1(1)        A1        B1      xyx    xyz
2(2)        A3        B3      xyx    xyz
-----------------------------------------
1(3)        A6        B6      xyx    xyz
2(4)        A6        B6      xyx    xyz
-----------------------------------------

これを行うために、次のようなソートイベントを採用しています

protected function adg1_headerReleaseHandler(event:AdvancedDataGridEvent):void
{
 event.preventDefault();

 sort_dir = !sort_dir;
 var sort:Sort = new Sort();
 sort.fields = [new SortField(event.dataField, true,sort_dir),new SortField('ID', true,sort_dir)]  
 _ds.sort = sort;
 _ds.refresh();

 adg1.dataProvider = null;
 var previousRegId:int = 0;
 var counter:int = 0;

 for each (var item:DueInVO in _ds) {
  if (previousRegId != item.ID) {
   counter++;
   previousRegId = item.ID
  }
  item.uid = counter;
 }

 /*
 var previousRegId:int = 0;
 var counter:int = 0;
 var csr:IViewCursor = DataSource.createCursor();
 while(!csr.afterLast){
  if (previousRegId != csr.current.registration_id) {
   counter++;
   previousRegId = csr.current.registration_id
  }

  csr.current.uid = counter;
  csr.moveNext();
 }
 */
 setGrouping(['uid']);
 //csr = null;
}

setGrouping 関数は次のようになります。

protected function setGrouping(columnNames:Array):void{
 var _groupingColumns:Array = [];
 var gc:GroupingField;
 if (columnNames.length > 0) {
  var _groupedData:GroupingCollection2 = new GroupingCollection2();
  var _grouping:Grouping = new Grouping();

  for (var i:int=0;i<columnNames.length;i++) {
   gc = new GroupingField(columnNames[i]);
   //gc.numeric = true;
   //gc.compareFunction = compareFunc;
   //gc.groupingFunction = groupFunc;
   _groupingColumns.push(gc);

  }
  _groupedData.source = _ds;
  _grouping.fields = _groupingColumns;
  _groupedData.grouping = _grouping
  _groupedData.refresh();
  adg1.dataProvider = _groupedData;
 } else {
  adg1.dataProvider = _ds;
 }
}

ただし、結果として生じる並べ替えの各要求は、解決にますます時間がかかっています。前述のように、グループ化のノードが開いていると、Flash Player がクラッシュする可能性が高くなります。

どこかにメモリリークがあると思いますが、指を置くことはできません。

誰かが完全なコードを必要とする場合は、喜んで提供します..

すべてのヘルプは大歓迎です

4

2 に答える 2

0

これを行う代わりに、単にsortCompareFunctionを ADG 列に提供する必要があります。ヘッダー クリック イベントなどをすべてキャプチャする必要はありません。それはすでにあなたのために行われています。特定の列の比較がどのように行われるかを指定するだけです。

于 2010-11-17T00:48:34.293 に答える
0

私はそれを手に入れました!...ロブストは、私をやや正しい方向に向けてくれてありがとう。私の場合の提案の問題は、構成ファイルから列を生成しているため、このグリッドコンポーネントを再利用できるようにすることです。そのため: 1. labelFunction を使用しています 2. column.sortCompareFunction = myfunc コールバックは、Adobe API ドキュメントから引用されているように機能しません。

しかし、あなたが言ったように、複雑なコードを書いていました。gc.compareFunction = myCompare; を追加する必要がありました。次のコードに (上記と比較してください):

protected function setGrouping(columnNames:Array):void{ _groupingColumns = [];

            if (columnNames.length > 0) {
                _groupedData = new GroupingCollection2();

                _grouping = new Grouping();

                for (var i:int=0;i<columnNames.length;i++) {
                    var gc:GroupingField = new GroupingField(columnNames[i]);
                    gc.descending = _sort_direction;

                    gc.compareFunction = myCompare;

                    _groupingColumns.push(gc);

                }
                _groupedData.source = _ds;
                _grouping.fields = _groupingColumns;
                _groupedData.grouping = _grouping
                _groupedData.refresh();
                _data = _groupedData;
            } else {
                _data = _ds;
            }

            setGridColumns();
        }

それが完了したら、次のように、AdvancedDataGrid リスナーでソート イベントをリッスンし、そこから setGrouping([abc]) を呼び出す必要がありました。

protected function adg1_sortHandler(event:AdvancedDataGridEvent):void
            {
                _sortField = event.dataField;
                if (temp.length == 0) {
                    temp.push(DefaultGroupColumn);
                } 

                setGrouping(temp)
                _sort_direction = !_sort_direction;

これが誰かに役立つことを願っています!AAP

于 2010-11-18T03:11:53.087 に答える