2012-01-22 4 views
1

이전처럼 hostComponent가 작동을 멈춘 것처럼 보입니다. SkinnableContainer를 말하고 기본 스킨을 적용하는 데 기반하는 사용자 정의 comp를 작성하면 스킨에서 Bindable/public 변수에 대한 공동 힌트를 볼 수 없습니다. 아래 코드를 설명하십시오.Flex 4.6 hostComponent가 더 이상 작동하지 않습니까?

무엇이 여기에 있습니까? 다른 구성 요소/스킨에서도 같은 현상이 발생합니다. 최신 플래시 빌더 (4.6)를 사용하고 있습니다.

< --------- 부품 --------------->

<?xml version="1.0" encoding="utf-8"?> 
<s:SkinnableContainer xmlns:fx="http://ns.adobe.com/mxml/2009" 
         xmlns:s="library://ns.adobe.com/flex/spark" 
         xmlns:mx="library://ns.adobe.com/flex/mx" 
         width="400" height="300" skinClass="skins.testSkin"> 
    <fx:Declarations> 
     <!-- Place non-visual elements (e.g., services, value objects) here --> 
    </fx:Declarations> 

    <fx:Script> 
     <![CDATA[ 

      [Bindable] 
      public var test:String = "Test"; 

     ]]> 
    </fx:Script> 
</s:SkinnableContainer> 

< ----------- ------ 스킨 -------------->

<?xml version="1.0" encoding="utf-8"?> 
<s:Skin xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" 
    xmlns:fb="http://ns.adobe.com/flashbuilder/2009" alpha.disabled="0.5"> 

    <fx:Metadata> 
    <![CDATA[ 
     /** 
     * @copy spark.skins.spark.ApplicationSkin#hostComponent 
     */ 
     [HostComponent("spark.components.SkinnableContainer")] 
    ]]> 
    </fx:Metadata> 

    <fx:Script fb:purpose="styling"> 
     <![CDATA[   
      /** 
      * @private 
      */ 
      override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number) : void 
      { 
       this.hostComponent 
       // Push backgroundColor and backgroundAlpha directly. 
       // Handle undefined backgroundColor by hiding the background object. 
       if (isNaN(getStyle("backgroundColor"))) 
       { 
        background.visible = false; 
       } 
       else 
       { 
        background.visible = true; 
        bgFill.color = getStyle("backgroundColor"); 
        bgFill.alpha = getStyle("backgroundAlpha"); 
       } 

       super.updateDisplayList(unscaledWidth, unscaledHeight); 
      } 
     ]]>   
    </fx:Script> 

    <s:states> 
     <s:State name="normal" /> 
     <s:State name="disabled" /> 
    </s:states> 

    <!--- Defines the appearance of the SkinnableContainer class's background. --> 
    <s:Rect id="background" left="0" right="0" top="0" bottom="0"> 
     <s:fill> 
      <!--- @private --> 
      <s:SolidColor id="bgFill" color="#FFFFFF"/> 
     </s:fill> 
    </s:Rect> 

    <!-- 
     Note: setting the minimum size to 0 here so that changes to the host component's 
     size will not be thwarted by this skin part's minimum size. This is a compromise, 
     more about it here: http://bugs.adobe.com/jira/browse/SDK-21143 
    --> 
    <!--- @copy spark.components.SkinnableContainer#contentGroup --> 
    <s:Group id="contentGroup" left="0" right="0" top="0" bottom="0" minWidth="0" minHeight="0"> 
     <s:layout> 
      <s:BasicLayout/> 
     </s:layout> 
    </s:Group> 

</s:Skin> 
+0

코드 힌트를 얻으려는 경우 스킨의'[HostComponent ("spark.components.SkinnableContainer")] 지시어는 사용자 정의 구성 요소 (예 :'MyComponent')를 지정해야하며 단순히 SkinnableContainer를 지정해야합니다. vars 및 방법에. 귀하의 질문에 오타가 있습니까? – merv

+0

오타가 없습니다. 간단합니다 :) 마지막으로 hostComponent를 사용했는데 코드를 직접 작성한 것 같습니다. Flash Builder가 사용자 정의 hostComponent를 추가하지 않는 이유는 무엇입니까? "[HostComponent ("spark.components.SkinnableContainer ")]"를 사용하는 데는 어떤 용도가 있습니까? 대답 주셔서 감사합니다, 그걸로 추가하고 동의합니다! :) – DominicM

답변

1

Flash Builder에서 공개 메서드 및 속성에 대한 코드 힌트 맞춤 구성 요소 인 경우 맞춤 구성 요소는 스킨 내의 HostComponent metadata directive에 지정되어야합니다. 현재 사용자가 제공 한 스킨 코드는 다음과 같습니다.

맞춤 구성 요소가 무엇이든 변경하십시오. com.mydomain.MyComponent.

관련 문제