2013-01-21 69 views
1

如何在時間軸上訪問TextField的* .htmlText屬性?我正在尋找能夠返回所有格式信息的內容,就像它在運行時在ActionScript 3.0中所做的一樣。如何從JSFL中的TextField獲取HTML格式字符串

例子:

<TEXTFORMAT LEADING="2"> 
    <P ALIGN="CENTER"> 
     <FONT FACE="Verdana" 
       SIZE="64" 
       COLOR="#FF0000" 
       LETTERSPACING="0" 
       KERNING="1"> 
      <B>This is a </B> 
      <FONT COLOR="#000000"> 
       <B>bold</B> 
       <FONT SIZE="33"> 
        <B>example</B> 
       </FONT> 
      </FONT> 
     </FONT> 
    </P> 
</TEXTFORMAT> 
+0

即將推出解決方案......再一次!完成後將發佈解決方案。 – bigp

回答

2

只好從頭開始寫了!所以在這裏,它是:

/* 

    Usage: 
    var labelHTML = HTMLUtils.convertToHTML(someLabel); 
    trace("The HTML of the selected label in the IDE is:\n" + labelHTML); 

*/ 

var _TAG_TEMPLATE = "<$0$1>$2</$0>"; 

HTMLUtils = { 

    convertToHTML: function(pTextField) { 
     var runs = pTextField.textRuns, 
      run, content, output, 
      leading; 

     this.rootNode = new HTMLElement("ROOT"); 

     for (var r=0, rLen=runs.length; r<rLen; r++) { 
      run = runs[r]; 
      content = run.characters; 

      this.convertAttrsToHTML(run.textAttrs, content); 
     } 

     this.currentTextFormat = null; 

     return this.rootNode.toHTML(true); 
    }, 

    convertAttrsToHTML: function(pTextAttrs, pContent) { 
     var contentLines = pContent.split("\r"); 
     var masterFontNode; 

     if(!this.currentTextFormat) { 
      masterFontNode = this.createNewTextFormat(pTextAttrs); 
     } else { 
      masterFontNode = this.currentTextFormat.childAt(0,0); 
     } 

     var fontNode = new HTMLFont(); 
     fontNode.addNode(new HTMLText(pContent)); 
     this.assignFontAttributes(fontNode, pTextAttrs); 

     masterFontNode.addNode(fontNode); 

     //trace(pTextAttrs.toTrace()); 

     this.currentTextFormat.attributes.leading = String(pTextAttrs.lineSpacing); 
     this.currentTextFormat.children[0].attributes.align = String(pTextAttrs.alignment); 

     if(contentLines.length>1) { 
      this.currentTextFormat = null; // 
     } 
    }, 

    createNewTextFormat: function(pTextAttrs) { 
     this.currentTextFormat = new HTMLElement("TEXTFORMAT"); 
     this.rootNode.addNode(this.currentTextFormat); 

     var paragraph = new HTMLElement("P"); 
     this.currentTextFormat.addNode(paragraph); 

     var fontNode = new HTMLFont(); 
     paragraph.addNode(fontNode); 

     this.assignFontAttributes(fontNode, pTextAttrs); 

     return fontNode; 
    }, 

    assignFontAttributes: function(pFontNode, pTextAttrs) { 
     pFontNode.attributes.face = String(pTextAttrs.face); 
     pFontNode.attributes.size = String(pTextAttrs.size); 
     pFontNode.attributes.letterSpacing = String(pTextAttrs.letterSpacing); 
     pFontNode.attributes.color = String(pTextAttrs.fillColor); 
     pFontNode.isBold =  pTextAttrs.bold; 
     pFontNode.isItalic = pTextAttrs.italic; 
    } 
}; 


HTMLElement = Class.extend({ 
    init: function(pName) { 
     this.name = pName; 
     this.children = []; 
     this.parent = null; 
     this.attributes = {}; 
    }, 

    clone: function(pOnlyThis) { 
     var theClone = new HTMLElement(this.name); 
     theClone.attributes = this.attributes.copy(); 
     return theClone; 
    }, 

    addNode: function(pNode) { 
     this.children.push(pNode); 
     pNode.parent = this; 

     return pNode; 
    }, 

    childAt: function() { 
     var current = this; 
     for (var a=0, aLen=arguments.length; a<aLen; a++) { 
      var index = arguments[a]; 

      current = current.children[index]; 
     } 

     return current; 
    }, 

    parentOfType: function(pName) { 
     var currentNode = this.parent; 
     while(currentNode && currentNode.name!=pName) { 
      currentNode = currentNode.parent; 
     } 

     return currentNode; 
    }, 

    childrenHTML: function() { 
     var theHTML = ""; 
     var theChildren = this.children, 
      theChild; 

     for (var c=0, cLen=theChildren.length; c<cLen; c++) { 
      theChild = theChildren[c]; 
      theHTML += theChild.toHTML(); 
     } 

     return theHTML; 
    }, 

    toHTML: function(pInnerOnly) { 
     var theHTML = this.childrenHTML(); 

     if(pInnerOnly) { 
      return theHTML; 
     } 

     var theAttributes = []; 
     var theAttrProperties = this.attributes.getProperties(); 

     for(var a=0, aLen=theAttrProperties.length; a<aLen; a++) { 
      var attr =  theAttrProperties[a]; 
      var attrBIG = attr.toUpperCase(); 
      var attrValue = this.attributes[attr]; 
      theAttributes.push(attrBIG + "=\"" + attrValue + "\""); 
     } 

     if(theAttributes.length==0) { 
      theAttributes = ""; 
     } else { 
      theAttributes = " " + theAttributes.join(" "); 
     } 

     return _TAG_TEMPLATE.inject(this.name, theAttributes, theHTML); 
    } 
}); 

HTMLFont = HTMLElement.extend({ 
    init: function() { 
     this._super("FONT"); 
    }, 
    toHTML: function(pInnerOnly) { 
     var parentFont = this.parentOfType("FONT"); 
     if(parentFont) { 
      //Find differences in attributes: 
      var parentAttrs = parentFont.attributes; 
      var myAttrs =  this.attributes; 

      var theAttrProperties = myAttrs.getProperties(); 
      var differentAttrs = []; 

      for (var a=0, aLen=theAttrProperties.length; a<aLen; a++) { 
       var attr =   theAttrProperties[a]; 
       var attrValue =  myAttrs[attr]; 
       var parentValue = parentAttrs[attr]; 

       if(parentValue==null || parentValue==attrValue) { 
        continue; 
       } 

       differentAttrs.push(attr.toUpperCase() + "=\"" + attrValue + "\""); 
      } 

      var theHTML = this.childrenHTML(); 

      if(this.isBold) { theHTML = "<B>" + theHTML + "</B>"; } 
      if(this.isItalic) { theHTML = "<I>" + theHTML + "</I>"; } 

      if(differentAttrs.length==0) { 
       return theHTML; 
      } else { 
       differentAttrs = " " + differentAttrs.join(" "); 
      } 

      return _TAG_TEMPLATE.inject(this.name, differentAttrs, theHTML); 
     } 
     return this._super(pInnerOnly); 
    } 
}); 

HTMLText = HTMLElement.extend({ 
    init: function(pContent) { 
     this._super("TEXT"); 
     this._content = pContent; 
    }, 
    toHTML: function() { 
     return this._content; 
    } 
}); 

注:對於部分被定義延長他們,你可以從這個網站獲得的功能:John Resig's Inheritance Script for JavaScript - based on Prototype。對於任何基於JavaScript的語言來說,這是一個很棒的腳本,它簡化了OOP!

+0

可能有一些我忘記包含的依賴項,但基本上對於任何對象迭代(例如:通過'屬性'屬性),在JavaScript中,您可以簡單地執行一個for-in循環,其中鍵將是屬性名稱,而object [key]是值。 – bigp

+0

您是否在Java中找到過相同功能的任何內容? – tymspy

+0

自從我觸及這段代碼之後已經有一段時間了,更不用說處理Flash中的HTML文本了,Java:(對不起,不知道是否存在類似的解決方案。 – bigp

相關問題