2011-08-05 49 views
1
<mx:TileList id="tl" allowMultipleSelection="true">    
    <mx:itemRenderer> 
     <mx:Component>      
     <mx:VBox height="100%"width="100%" borderSides="borderStyle="solid"> 
      <mx:Text id="txt1" text="{getText(XML(data))}" selectable="{_selectable}" /> 
      <mx:Script> 
     <![CDATA[ 
     import mx.controls.listClasses.IListItemRenderer; 

      public override function set data(obj:Object):void{ 
      //this override function works alright 
      } 

      private function getText(data:XML):String{ 
      // some logic inside this function. Works fine. 
      } 


    override protected function drawSelectionIndicator(indicator:Sprite, x:Number, y:Number, width:Number, height:Number, color:uint, itemRenderer:IListItemRenderer):void{ 
     //this function gives me compile error - "Method marked override must override another method"       } 


      ]]> 
     </mx:Script> 
     </mx:VBox> 
     </mx:Component> 
    </mx:itemRenderer> 
    </mx:TileList> 

现在我知道我可以做其他类和扩展的TileList和覆盖此方法有,它会正常的工作,因为它会找到方法在超被覆盖类的范围。但我实际上想在组件级别进行内联操作(我不想创建另一个文件,每次我必须在tilelist,datagrid等中进行小修改)。TileList中的itemRenderer错误:标记覆盖必须覆盖另一种方法

-------------------------- FULL CODE Prototype(with function logic not written)---------

<mx:VBox horizontalAlign="center" verticalAlign="middle"> 
    <mx:HorizontalList id="headerList" width="100%" columnCount="7" paddingBottom="0" selectable="false" columnWidth="98" rowHeight="40"> 
    <mx:dataProvider> 
         <mx:Array> 
         <mx:String>Sunday</mx:String> 
         <mx:String>Monday</mx:String> 
         <mx:String>Tuesday</mx:String> 
         <mx:String>Wednesday</mx:String> 
         <mx:String>Thursday</mx:String> 
         <mx:String>Friday</mx:String> 
         <mx:String>Saturday</mx:String> 
         </mx:Array> 
     </mx:dataProvider> 
<mx:itemRenderer> 
<mx:Component> 
<mx:VBox backgroundAlpha="0.8" height="100%" width="100%" horizontalAlign="center" paddingTop="0" verticalAlign="middle" borderSides="bottom left right" borderStyle="solid"> 
          <mx:Label text="{data}" fontWeight="bold"/> 
         </mx:VBox> 
        </mx:Component> 
       </mx:itemRenderer> 
       </mx:HorizontalList> 
       <mx:TileList id="tl" allowMultipleSelection="true" mouseOver="tl.setStyle('backgroundColor','0xFFFFFF')" paddingTop="0" height="100%" width="100%" borderSides="none" dataProvider="{IndividualData.w.s}" maxRows="4" maxColumns="7" columnCount="7" rowCount="4" rowHeight="110" columnWidth="98">     
       <mx:Script> 
        <![CDATA[ 
         import mx.controls.listClasses.IListItemRenderer; 
         protected override function drawSelectionIndicator(indicator:Sprite, x:Number, y:Number, width:Number, height:Number, color:uint, itemRenderer:IListItemRenderer):void{ 
          return;    
         } 
        ]]> 
       </mx:Script> 
       <mx:itemRenderer> 
        <mx:Component>      
         <mx:VBox height="100%" horizontalAlign="center" width="100%" borderSides=" top bottom left right" borderStyle="solid" 
          click="outerDocument.onItemClick(event,XML(data));onEdit()" doubleClickEnabled="true" doubleClick="onScheduleDetail([email protected])" 
          verticalAlign="middle" mouseOver="onMouseOver()" mouseOut="onMouseOut()" 
          backgroundColor="{_bgColor}"> 
          <mx:Text id="txt1" text="{getText(XML(data))}" selectable="{_selectable}" /> 
          <mx:Script> 
          <![CDATA[ 
           import mx.controls.listClasses.IListItemRenderer; 
           import mx.core.UIComponent; 
           import com.smartLinx.utils.DateUtils; 
           import com.smartLinx.utils.Helper; 
           import com.smartLinx.utils.DateUtils; 
           import com.smartLinx.ScheduleOptimizer.components.ScheduleDetail; 
           import mx.managers.PopUpManager; 
           [Bindable] private var _bgAlpha:Number; 
           [Bindable] private var _selectable:Boolean; 
           [Bindable] private var _bgColor:uint;  
           [Bindable] private var _pastDated:Boolean;  

           /* override protected function drawSelectionIndicator(indicator:Sprite, x:Number, y:Number, width:Number, height:Number, color:uint, itemRenderer:IListItemRenderer):void 
           { 
             return; 
           } */ 
           private function getText(data:XML):String 
            { 
            //         } 

            private function onMouseOver():void{ 
             } 

            private function onMouseOut():void{ 

             } 

            private function onEdit():void{ 
            } 

            public override function set data(obj:Object):void 
            { 

             super.data = obj;         
            }         

           private function onScheduleDetail(work_date:String):void 
           { 
           } 
           ]]> 
          </mx:Script> 
         </mx:VBox> 
        </mx:Component> 
       </mx:itemRenderer> 

       </mx:TileList> 
      </mx:VBox> 
     </mx:VBox> 

回答

2

试试这个:

<mx:TileList id="tl" allowMultipleSelection="true">    
     <mx:Script> 
    <![CDATA[ 
    import mx.controls.listClasses.IListItemRenderer; 
override protected function drawSelectionIndicator(indicator:Sprite, x:Number, y:Number, width:Number, height:Number, color:uint, itemRenderer:IListItemRenderer):void{ 
    //this function gives me compile error - "Method marked override must override another method"       } 


     ]]> 
    </mx:Script> 
<mx:itemRenderer> 
    <mx:Component>      
    <mx:VBox height="100%"width="100%" borderSides="borderStyle="solid"> 
     <mx:Text id="txt1" text="{getText(XML(data))}" selectable="{_selectable}" /> 
     <mx:Script> 
    <![CDATA[ 
     public override function set data(obj:Object):void{ 
     //this override function works alright 
     } 
     ]]> 
    </mx:Script> 
    </mx:VBox> 
    </mx:Component> 
</mx:itemRenderer> 
</mx:TileList> 

你的情况,你想重写VBox的方法,它不存在。

扩大后门柱编辑:

Flex的规则#1,我始终遵循的是:

Avoid inline MXML components.

系列组件增加复杂性并降低可读性。它只能用于快速原型(只是简单的标记无代码),当你明确知道你在做什么。所以你需要丰富的实践技巧。

但你的代码至少有三个simptoms避免内嵌部件:

  1. 它有一个以上的联组件。
  2. 它具有用于内联组件的ActionScript代码。
  3. 整个MXML类是相当大和复杂的阅读。

所以我建议你两两件事:

  1. 在当前的代码摆脱内嵌组件。在单独的MXML类中提取组件。
  2. 不要再使用它们了。当你有足够的技能,你可以明智地打破这个规则:)
+0

我已经尝试过 - 认为在父节点它可能工作 - 但同样的错误。 – Tintin

+0

你在开玩笑或做错事。在我的IDE中成功完成。 – Constantiner

+0

仍然是一样的错误。我的tilelist深入VBox的内部。我不知道我做错了什么? – Tintin